ClustersController.java 2.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. package com.provectus.kafka.ui.controller;
  2. import com.provectus.kafka.ui.api.ClustersApi;
  3. import com.provectus.kafka.ui.model.ClusterDTO;
  4. import com.provectus.kafka.ui.model.ClusterMetricsDTO;
  5. import com.provectus.kafka.ui.model.ClusterStatsDTO;
  6. import com.provectus.kafka.ui.model.rbac.AccessContext;
  7. import com.provectus.kafka.ui.service.ClusterService;
  8. import com.provectus.kafka.ui.service.rbac.AccessControlService;
  9. import lombok.RequiredArgsConstructor;
  10. import lombok.extern.slf4j.Slf4j;
  11. import org.springframework.http.ResponseEntity;
  12. import org.springframework.web.bind.annotation.RestController;
  13. import org.springframework.web.server.ServerWebExchange;
  14. import reactor.core.publisher.Flux;
  15. import reactor.core.publisher.Mono;
  16. @RestController
  17. @RequiredArgsConstructor
  18. @Slf4j
  19. public class ClustersController extends AbstractController implements ClustersApi {
  20. private final ClusterService clusterService;
  21. private final AccessControlService accessControlService;
  22. @Override
  23. public Mono<ResponseEntity<Flux<ClusterDTO>>> getClusters(ServerWebExchange exchange) {
  24. Flux<ClusterDTO> job = Flux.fromIterable(clusterService.getClusters())
  25. .filterWhen(accessControlService::isClusterAccessible);
  26. return Mono.just(ResponseEntity.ok(job));
  27. }
  28. @Override
  29. public Mono<ResponseEntity<ClusterMetricsDTO>> getClusterMetrics(String clusterName,
  30. ServerWebExchange exchange) {
  31. AccessContext context = AccessContext.builder()
  32. .cluster(clusterName)
  33. .build();
  34. return accessControlService.validateAccess(context)
  35. .then(
  36. clusterService.getClusterMetrics(getCluster(clusterName))
  37. .map(ResponseEntity::ok)
  38. .onErrorReturn(ResponseEntity.notFound().build())
  39. );
  40. }
  41. @Override
  42. public Mono<ResponseEntity<ClusterStatsDTO>> getClusterStats(String clusterName,
  43. ServerWebExchange exchange) {
  44. AccessContext context = AccessContext.builder()
  45. .cluster(clusterName)
  46. .build();
  47. return accessControlService.validateAccess(context)
  48. .then(
  49. clusterService.getClusterStats(getCluster(clusterName))
  50. .map(ResponseEntity::ok)
  51. .onErrorReturn(ResponseEntity.notFound().build())
  52. );
  53. }
  54. @Override
  55. public Mono<ResponseEntity<ClusterDTO>> updateClusterInfo(String clusterName,
  56. ServerWebExchange exchange) {
  57. AccessContext context = AccessContext.builder()
  58. .cluster(clusterName)
  59. .build();
  60. return accessControlService.validateAccess(context)
  61. .then(
  62. clusterService.updateCluster(getCluster(clusterName)).map(ResponseEntity::ok)
  63. );
  64. }
  65. }