KafkaConnectController.java 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. package com.provectus.kafka.ui.controller;
  2. import com.provectus.kafka.ui.api.KafkaConnectApi;
  3. import com.provectus.kafka.ui.model.Connect;
  4. import com.provectus.kafka.ui.model.Connector;
  5. import com.provectus.kafka.ui.model.ConnectorAction;
  6. import com.provectus.kafka.ui.model.ConnectorPlugin;
  7. import com.provectus.kafka.ui.model.ConnectorPluginConfigValidationResponse;
  8. import com.provectus.kafka.ui.model.FullConnectorInfo;
  9. import com.provectus.kafka.ui.model.NewConnector;
  10. import com.provectus.kafka.ui.model.Task;
  11. import com.provectus.kafka.ui.service.KafkaConnectService;
  12. import java.util.Map;
  13. import javax.validation.Valid;
  14. import lombok.RequiredArgsConstructor;
  15. import lombok.extern.log4j.Log4j2;
  16. import org.springframework.http.ResponseEntity;
  17. import org.springframework.web.bind.annotation.RestController;
  18. import org.springframework.web.server.ServerWebExchange;
  19. import reactor.core.publisher.Flux;
  20. import reactor.core.publisher.Mono;
  21. @RestController
  22. @RequiredArgsConstructor
  23. @Log4j2
  24. public class KafkaConnectController implements KafkaConnectApi {
  25. private final KafkaConnectService kafkaConnectService;
  26. @Override
  27. public Mono<ResponseEntity<Flux<Connect>>> getConnects(String clusterName,
  28. ServerWebExchange exchange) {
  29. return kafkaConnectService.getConnects(clusterName).map(ResponseEntity::ok);
  30. }
  31. @Override
  32. public Mono<ResponseEntity<Flux<String>>> getConnectors(String clusterName, String connectName,
  33. ServerWebExchange exchange) {
  34. Flux<String> connectors = kafkaConnectService.getConnectors(clusterName, connectName);
  35. return Mono.just(ResponseEntity.ok(connectors));
  36. }
  37. @Override
  38. public Mono<ResponseEntity<Connector>> createConnector(String clusterName, String connectName,
  39. @Valid Mono<NewConnector> connector,
  40. ServerWebExchange exchange) {
  41. return kafkaConnectService.createConnector(clusterName, connectName, connector)
  42. .map(ResponseEntity::ok);
  43. }
  44. @Override
  45. public Mono<ResponseEntity<Connector>> getConnector(String clusterName, String connectName,
  46. String connectorName,
  47. ServerWebExchange exchange) {
  48. return kafkaConnectService.getConnector(clusterName, connectName, connectorName)
  49. .map(ResponseEntity::ok);
  50. }
  51. @Override
  52. public Mono<ResponseEntity<Void>> deleteConnector(String clusterName, String connectName,
  53. String connectorName,
  54. ServerWebExchange exchange) {
  55. return kafkaConnectService.deleteConnector(clusterName, connectName, connectorName)
  56. .map(ResponseEntity::ok);
  57. }
  58. @Override
  59. public Mono<ResponseEntity<Flux<FullConnectorInfo>>> getAllConnectors(
  60. String clusterName,
  61. String search,
  62. ServerWebExchange exchange
  63. ) {
  64. return Mono.just(ResponseEntity.ok(kafkaConnectService.getAllConnectors(clusterName, search)));
  65. }
  66. @Override
  67. public Mono<ResponseEntity<Map<String, Object>>> getConnectorConfig(String clusterName,
  68. String connectName,
  69. String connectorName,
  70. ServerWebExchange exchange) {
  71. return kafkaConnectService.getConnectorConfig(clusterName, connectName, connectorName)
  72. .map(ResponseEntity::ok);
  73. }
  74. @Override
  75. public Mono<ResponseEntity<Connector>> setConnectorConfig(String clusterName, String connectName,
  76. String connectorName,
  77. @Valid Mono<Object> requestBody,
  78. ServerWebExchange exchange) {
  79. return kafkaConnectService
  80. .setConnectorConfig(clusterName, connectName, connectorName, requestBody)
  81. .map(ResponseEntity::ok);
  82. }
  83. @Override
  84. public Mono<ResponseEntity<Void>> updateConnectorState(String clusterName, String connectName,
  85. String connectorName,
  86. ConnectorAction action,
  87. ServerWebExchange exchange) {
  88. return kafkaConnectService.updateConnectorState(clusterName, connectName, connectorName, action)
  89. .map(ResponseEntity::ok);
  90. }
  91. @Override
  92. public Mono<ResponseEntity<Flux<Task>>> getConnectorTasks(String clusterName, String connectName,
  93. String connectorName,
  94. ServerWebExchange exchange) {
  95. return Mono.just(ResponseEntity
  96. .ok(kafkaConnectService.getConnectorTasks(clusterName, connectName, connectorName)));
  97. }
  98. @Override
  99. public Mono<ResponseEntity<Void>> restartConnectorTask(String clusterName, String connectName,
  100. String connectorName, Integer taskId,
  101. ServerWebExchange exchange) {
  102. return kafkaConnectService.restartConnectorTask(clusterName, connectName, connectorName, taskId)
  103. .map(ResponseEntity::ok);
  104. }
  105. @Override
  106. public Mono<ResponseEntity<Flux<ConnectorPlugin>>> getConnectorPlugins(
  107. String clusterName, String connectName, ServerWebExchange exchange) {
  108. return kafkaConnectService.getConnectorPlugins(clusterName, connectName)
  109. .map(ResponseEntity::ok);
  110. }
  111. @Override
  112. public Mono<ResponseEntity<ConnectorPluginConfigValidationResponse>>
  113. validateConnectorPluginConfig(
  114. String clusterName, String connectName, String pluginName, @Valid Mono<Object> requestBody,
  115. ServerWebExchange exchange) {
  116. return kafkaConnectService
  117. .validateConnectorPluginConfig(clusterName, connectName, pluginName, requestBody)
  118. .map(ResponseEntity::ok);
  119. }
  120. }