Skip to content

Commit

Permalink
[huaweicloud#1387] fixed cross engine authentication failed at dual-a…
Browse files Browse the repository at this point in the history
…z servicecomb engine problem (huaweicloud#1392) (huaweicloud#1394)
  • Loading branch information
chengyouling authored Oct 26, 2024
1 parent 9e5fa4e commit 5f97254
Show file tree
Hide file tree
Showing 4 changed files with 15 additions and 5 deletions.
2 changes: 1 addition & 1 deletion pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@
import spring-framework-bom. No need configure spring version. -->
<spring-cloud.version>2023.0.3</spring-cloud.version>
<spring-boot.version>3.3.2</spring-boot.version>
<servicecomb.version>2.8.19</servicecomb.version>
<servicecomb.version>2.8.21</servicecomb.version>
</properties>

<modules>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -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;
Expand Down Expand Up @@ -81,13 +82,17 @@ public class RBACRequestAuthHeaderProvider implements AuthHeaderProvider {

private int lastStatusCode = 401;

private ServiceCenterClient serviceCenterClient;

public RBACRequestAuthHeaderProvider(BootstrapProperties bootstrapProperties) {
this.discoveryProperties = bootstrapProperties.getDiscoveryBootstrapProperties();
this.serviceCombSSLProperties = bootstrapProperties.getServiceCombSSLProperties();
this.serviceCombRBACProperties = bootstrapProperties.getServiceCombRBACProperties();
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"));
Expand All @@ -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");

Expand All @@ -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());
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -34,14 +34,15 @@
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);

private final ServiceCombRBACProperties serviceCombRBACProperties = Mockito.mock(ServiceCombRBACProperties.class);

@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);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -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,
Expand Down Expand Up @@ -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();
Expand Down

0 comments on commit 5f97254

Please sign in to comment.