ClustersController.java 3.2 KB

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