BrokersController.java 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. package com.provectus.kafka.ui.controller;
  2. import com.provectus.kafka.ui.api.BrokersApi;
  3. import com.provectus.kafka.ui.mapper.ClusterMapper;
  4. import com.provectus.kafka.ui.model.BrokerConfigDTO;
  5. import com.provectus.kafka.ui.model.BrokerConfigItemDTO;
  6. import com.provectus.kafka.ui.model.BrokerDTO;
  7. import com.provectus.kafka.ui.model.BrokerLogdirUpdateDTO;
  8. import com.provectus.kafka.ui.model.BrokerMetricsDTO;
  9. import com.provectus.kafka.ui.model.BrokersLogdirsDTO;
  10. import com.provectus.kafka.ui.model.rbac.AccessContext;
  11. import com.provectus.kafka.ui.model.rbac.permission.ClusterConfigAction;
  12. import com.provectus.kafka.ui.service.BrokerService;
  13. import com.provectus.kafka.ui.service.audit.AuditService;
  14. import com.provectus.kafka.ui.service.rbac.AccessControlService;
  15. import java.util.List;
  16. import java.util.Map;
  17. import javax.annotation.Nullable;
  18. import lombok.RequiredArgsConstructor;
  19. import lombok.extern.slf4j.Slf4j;
  20. import org.springframework.http.ResponseEntity;
  21. import org.springframework.web.bind.annotation.RestController;
  22. import org.springframework.web.server.ServerWebExchange;
  23. import reactor.core.publisher.Flux;
  24. import reactor.core.publisher.Mono;
  25. @RestController
  26. @RequiredArgsConstructor
  27. @Slf4j
  28. public class BrokersController extends AbstractController implements BrokersApi {
  29. private static final String BROKER_ID = "brokerId";
  30. private final BrokerService brokerService;
  31. private final ClusterMapper clusterMapper;
  32. private final AuditService auditService;
  33. private final AccessControlService accessControlService;
  34. @Override
  35. public Mono<ResponseEntity<Flux<BrokerDTO>>> getBrokers(String clusterName,
  36. ServerWebExchange exchange) {
  37. var context = AccessContext.builder()
  38. .cluster(clusterName)
  39. .operationName("getBrokers")
  40. .build();
  41. var job = brokerService.getBrokers(getCluster(clusterName)).map(clusterMapper::toBrokerDto);
  42. return accessControlService.validateAccess(context)
  43. .thenReturn(ResponseEntity.ok(job))
  44. .doOnEach(sig -> auditService.audit(context, sig));
  45. }
  46. @Override
  47. public Mono<ResponseEntity<BrokerMetricsDTO>> getBrokersMetrics(String clusterName, Integer id,
  48. ServerWebExchange exchange) {
  49. var context = AccessContext.builder()
  50. .cluster(clusterName)
  51. .operationName("getBrokersMetrics")
  52. .operationParams(Map.of("id", id))
  53. .build();
  54. return accessControlService.validateAccess(context)
  55. .then(
  56. brokerService.getBrokerMetrics(getCluster(clusterName), id)
  57. .map(clusterMapper::toBrokerMetrics)
  58. .map(ResponseEntity::ok)
  59. .onErrorReturn(ResponseEntity.notFound().build())
  60. )
  61. .doOnEach(sig -> auditService.audit(context, sig));
  62. }
  63. @Override
  64. public Mono<ResponseEntity<Flux<BrokersLogdirsDTO>>> getAllBrokersLogdirs(String clusterName,
  65. @Nullable List<Integer> brokers,
  66. ServerWebExchange exchange) {
  67. List<Integer> brokerIds = brokers == null ? List.of() : brokers;
  68. var context = AccessContext.builder()
  69. .cluster(clusterName)
  70. .operationName("getAllBrokersLogdirs")
  71. .operationParams(Map.of("brokerIds", brokerIds))
  72. .build();
  73. return accessControlService.validateAccess(context)
  74. .thenReturn(ResponseEntity.ok(
  75. brokerService.getAllBrokersLogdirs(getCluster(clusterName), brokerIds)))
  76. .doOnEach(sig -> auditService.audit(context, sig));
  77. }
  78. @Override
  79. public Mono<ResponseEntity<Flux<BrokerConfigDTO>>> getBrokerConfig(String clusterName,
  80. Integer id,
  81. ServerWebExchange exchange) {
  82. var context = AccessContext.builder()
  83. .cluster(clusterName)
  84. .clusterConfigActions(ClusterConfigAction.VIEW)
  85. .operationName("getBrokerConfig")
  86. .operationParams(Map.of(BROKER_ID, id))
  87. .build();
  88. return accessControlService.validateAccess(context).thenReturn(
  89. ResponseEntity.ok(
  90. brokerService.getBrokerConfig(getCluster(clusterName), id)
  91. .map(clusterMapper::toBrokerConfig))
  92. ).doOnEach(sig -> auditService.audit(context, sig));
  93. }
  94. @Override
  95. public Mono<ResponseEntity<Void>> updateBrokerTopicPartitionLogDir(String clusterName,
  96. Integer id,
  97. Mono<BrokerLogdirUpdateDTO> brokerLogdir,
  98. ServerWebExchange exchange) {
  99. var context = AccessContext.builder()
  100. .cluster(clusterName)
  101. .clusterConfigActions(ClusterConfigAction.VIEW, ClusterConfigAction.EDIT)
  102. .operationName("updateBrokerTopicPartitionLogDir")
  103. .operationParams(Map.of(BROKER_ID, id))
  104. .build();
  105. return accessControlService.validateAccess(context).then(
  106. brokerLogdir
  107. .flatMap(bld -> brokerService.updateBrokerLogDir(getCluster(clusterName), id, bld))
  108. .map(ResponseEntity::ok)
  109. ).doOnEach(sig -> auditService.audit(context, sig));
  110. }
  111. @Override
  112. public Mono<ResponseEntity<Void>> updateBrokerConfigByName(String clusterName,
  113. Integer id,
  114. String name,
  115. Mono<BrokerConfigItemDTO> brokerConfig,
  116. ServerWebExchange exchange) {
  117. var context = AccessContext.builder()
  118. .cluster(clusterName)
  119. .clusterConfigActions(ClusterConfigAction.VIEW, ClusterConfigAction.EDIT)
  120. .operationName("updateBrokerConfigByName")
  121. .operationParams(Map.of(BROKER_ID, id))
  122. .build();
  123. return accessControlService.validateAccess(context).then(
  124. brokerConfig
  125. .flatMap(bci -> brokerService.updateBrokerConfigByName(
  126. getCluster(clusterName), id, name, bci.getValue()))
  127. .map(ResponseEntity::ok)
  128. ).doOnEach(sig -> auditService.audit(context, sig));
  129. }
  130. }