BrokersController.java 5.9 KB

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