diff --git a/pom.xml b/pom.xml index 97e237256..1abf7cfff 100644 --- a/pom.xml +++ b/pom.xml @@ -38,7 +38,7 @@ import spring-framework-bom. No need configure spring version. --> 2023.0.3 3.3.2 - 2.8.19 + 2.8.21 diff --git a/spring-cloud-huawei-service-engine/service-engine-common/src/main/java/com/huaweicloud/service/engine/common/transport/RBACRequestAuthHeaderProvider.java b/spring-cloud-huawei-service-engine/service-engine-common/src/main/java/com/huaweicloud/service/engine/common/transport/RBACRequestAuthHeaderProvider.java index aba11fa95..f4df7e5c6 100644 --- a/spring-cloud-huawei-service-engine/service-engine-common/src/main/java/com/huaweicloud/service/engine/common/transport/RBACRequestAuthHeaderProvider.java +++ b/spring-cloud-huawei-service-engine/service-engine-common/src/main/java/com/huaweicloud/service/engine/common/transport/RBACRequestAuthHeaderProvider.java @@ -26,6 +26,7 @@ import org.apache.commons.lang3.StringUtils; import org.apache.servicecomb.foundation.auth.AuthHeaderProvider; +import org.apache.servicecomb.http.client.event.EngineConnectChangedEvent; import org.apache.servicecomb.service.center.client.OperationEvents; import org.apache.servicecomb.service.center.client.ServiceCenterClient; import org.apache.servicecomb.service.center.client.model.RbacTokenRequest; @@ -81,6 +82,8 @@ public class RBACRequestAuthHeaderProvider implements AuthHeaderProvider { private int lastStatusCode = 401; + private ServiceCenterClient serviceCenterClient; + public RBACRequestAuthHeaderProvider(BootstrapProperties bootstrapProperties) { this.discoveryProperties = bootstrapProperties.getDiscoveryBootstrapProperties(); this.serviceCombSSLProperties = bootstrapProperties.getServiceCombSSLProperties(); @@ -88,6 +91,8 @@ public RBACRequestAuthHeaderProvider(BootstrapProperties bootstrapProperties) { this.microserviceProperties = bootstrapProperties.getMicroserviceProperties(); if (enabled()) { + serviceCenterClient = ServiceCenterUtils.serviceCenterClient(discoveryProperties, + serviceCombSSLProperties, Collections.emptyList()); EventManager.getEventBus().register(this); executorService = Executors.newFixedThreadPool(1, t -> new Thread(t, "rbac-executor")); @@ -113,6 +118,11 @@ public void onNotPermittedEvent(OperationEvents.UnAuthorizedOperationEvent event this.executorService.submit(this::retryRefresh); } + @Subscribe + public void onEngineConnectChangedEvent(EngineConnectChangedEvent event) { + cache.refresh(CACHE_KEY); + } + protected String createHeaders() { LOGGER.info("start to create RBAC headers"); @@ -136,9 +146,6 @@ protected String createHeaders() { } protected RbacTokenResponse callCreateHeaders() { - ServiceCenterClient serviceCenterClient = ServiceCenterUtils - .serviceCenterClient(discoveryProperties, serviceCombSSLProperties, - Collections.emptyList()); RbacTokenRequest request = new RbacTokenRequest(); request.setName(serviceCombRBACProperties.getName()); request.setPassword(serviceCombRBACProperties.getPassword()); diff --git a/spring-cloud-huawei-service-engine/service-engine-common/src/test/java/com/huaweicloud/service/engine/common/transport/RBACRequestAuthHeaderProviderTest.java b/spring-cloud-huawei-service-engine/service-engine-common/src/test/java/com/huaweicloud/service/engine/common/transport/RBACRequestAuthHeaderProviderTest.java index db89b1870..2a3a5a88d 100644 --- a/spring-cloud-huawei-service-engine/service-engine-common/src/test/java/com/huaweicloud/service/engine/common/transport/RBACRequestAuthHeaderProviderTest.java +++ b/spring-cloud-huawei-service-engine/service-engine-common/src/test/java/com/huaweicloud/service/engine/common/transport/RBACRequestAuthHeaderProviderTest.java @@ -34,7 +34,7 @@ public class RBACRequestAuthHeaderProviderTest { private final BootstrapProperties bootstrapProperties = Mockito.mock(BootstrapProperties.class); - private final DiscoveryBootstrapProperties discoveryProperties = Mockito.mock(DiscoveryBootstrapProperties.class); + private final DiscoveryBootstrapProperties discoveryProperties = new DiscoveryBootstrapProperties(); private final ServiceCombSSLProperties serviceCombSSLProperties = Mockito.mock(ServiceCombSSLProperties.class); @@ -42,6 +42,7 @@ public class RBACRequestAuthHeaderProviderTest { @BeforeEach public void setUp() { + discoveryProperties.setAddress("http://127.0.0.1:30100"); Mockito.when(bootstrapProperties.getDiscoveryBootstrapProperties()).thenReturn(discoveryProperties); Mockito.when(bootstrapProperties.getServiceCombSSLProperties()).thenReturn(serviceCombSSLProperties); Mockito.when(bootstrapProperties.getServiceCombRBACProperties()).thenReturn(serviceCombRBACProperties); diff --git a/spring-cloud-huawei-service-engine/service-engine-config/src/main/java/com/huaweicloud/config/ConfigService.java b/spring-cloud-huawei-service-engine/service-engine-config/src/main/java/com/huaweicloud/config/ConfigService.java index 1763b9383..1039daeed 100644 --- a/spring-cloud-huawei-service-engine/service-engine-config/src/main/java/com/huaweicloud/config/ConfigService.java +++ b/spring-cloud-huawei-service-engine/service-engine-config/src/main/java/com/huaweicloud/config/ConfigService.java @@ -152,6 +152,7 @@ private void initServiceCenterConfig(BootstrapProperties bootstrapProperties, bootstrapProperties.getServiceCombSSLProperties(), authHeaderProviders, HttpTransportFactory.defaultRequestConfig().build()); ConfigCenterClient configCenterClient = new ConfigCenterClient(addressManager, httpTransport); + configCenterClient.setEventBus(EventManager.getEventBus()); queryConfigurationsRequest = createQueryConfigurationsRequest(bootstrapProperties); firstPull(bootstrapProperties.getConfigBootstrapProperties(), configCenterClient, queryConfigurationsRequest, @@ -254,6 +255,7 @@ private void initKieConfig(BootstrapProperties bootstrapProperties, authHeaderProviders, requestBuilder.build()); KieConfiguration kieConfiguration = createKieConfiguration(bootstrapProperties); KieClient kieClient = new KieClient(kieAddressManager, httpTransport, kieConfiguration); + kieClient.setEventBus(EventManager.getEventBus()); KieConfigManager kieConfigManager = new KieConfigManager(kieClient, EventManager.getEventBus(), kieConfiguration, configConverter, kieAddressManager); kieConfigManager.firstPull();