Skip to content

Commit

Permalink
Merge branch 'main' into portal_autosetup_2405
Browse files Browse the repository at this point in the history
  • Loading branch information
sachinargade123 authored May 27, 2024
2 parents 74b0cfb + 2bddc72 commit 58e526f
Show file tree
Hide file tree
Showing 11 changed files with 940 additions and 35 deletions.
14 changes: 9 additions & 5 deletions DEPENDENCIES
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,8 @@ maven/mavencentral/com.nimbusds/nimbus-jose-jwt/9.24.4, Apache-2.0, approved, cl
maven/mavencentral/com.nimbusds/oauth2-oidc-sdk/9.43.3, Apache-2.0, approved, clearlydefined
maven/mavencentral/com.sun.istack/istack-commons-runtime/4.1.2, BSD-3-Clause, approved, #2590
maven/mavencentral/com.sun.mail/javax.mail/1.6.2, CDDL-1.0 AND Apache-2.0, approved, CQ18739
maven/mavencentral/com.sun.xml.bind/jaxb-core/4.0.5, BSD-3-Clause, approved, ee4j.jaxb-impl
maven/mavencentral/com.sun.xml.bind/jaxb-xjc/4.0.5, BSD-3-Clause, approved, ee4j.jaxb-impl
maven/mavencentral/com.vaadin.external.google/android-json/0.0.20131108.vaadin1, Apache-2.0, approved, CQ21310
maven/mavencentral/com.zaxxer/HikariCP/5.0.1, Apache-2.0, approved, clearlydefined
maven/mavencentral/commons-codec/commons-codec/1.16.1, Apache-2.0 AND (Apache-2.0 AND BSD-3-Clause), approved, #9157
Expand Down Expand Up @@ -58,10 +60,12 @@ maven/mavencentral/org.apiguardian/apiguardian-api/1.1.2, Apache-2.0, approved,
maven/mavencentral/org.aspectj/aspectjweaver/1.9.22, Apache-2.0 AND BSD-3-Clause AND EPL-1.0 AND BSD-3-Clause AND Apache-1.1, approved, #7695
maven/mavencentral/org.assertj/assertj-core/3.24.2, Apache-2.0, approved, #6161
maven/mavencentral/org.awaitility/awaitility/4.2.1, Apache-2.0, approved, #14178
maven/mavencentral/org.bouncycastle/bcpkix-jdk18on/1.77, MIT, approved, #11593
maven/mavencentral/org.bouncycastle/bcprov-jdk18on/1.77, MIT AND CC0-1.0, approved, #11595
maven/mavencentral/org.bouncycastle/bcutil-jdk18on/1.77, MIT, approved, #11596
maven/mavencentral/org.eclipse.persistence/eclipselink/3.0.3, EPL-2.0 OR BSD-3-Clause, approved, ee4j.eclipselink
maven/mavencentral/org.bouncycastle/bcpkix-jdk18on/1.78.1, MIT, approved, #14434
maven/mavencentral/org.bouncycastle/bcprov-jdk18on/1.78.1, MIT AND CC0-1.0, approved, #14433
maven/mavencentral/org.bouncycastle/bcutil-jdk18on/1.78.1, MIT, approved, #14435
maven/mavencentral/org.checkerframework/checker-qual/3.42.0, MIT, approved, clearlydefined
maven/mavencentral/org.eclipse.angus/angus-activation/2.0.2, EPL-2.0 OR GPL-2.0-only with Classpath-exception-2.0, approved, ee4j.angus
maven/mavencentral/org.eclipse.persistence/eclipselink/4.0.3, EPL-2.0 OR BSD-3-Clause, approved, ee4j.eclipselink
maven/mavencentral/org.flywaydb/flyway-core/9.22.3, Apache-2.0, approved, #10349
maven/mavencentral/org.freemarker/freemarker/2.3.32, Apache-2.0, approved, #6764
maven/mavencentral/org.glassfish.jaxb/jaxb-core/4.0.5, BSD-3-Clause, approved, ee4j.jaxb-impl
Expand All @@ -78,7 +82,7 @@ maven/mavencentral/org.junit.jupiter/junit-jupiter-params/5.10.2, EPL-2.0, appro
maven/mavencentral/org.junit.jupiter/junit-jupiter/5.10.2, EPL-2.0, approved, #13393
maven/mavencentral/org.junit.platform/junit-platform-commons/1.10.2, EPL-2.0, approved, #9715
maven/mavencentral/org.junit.platform/junit-platform-engine/1.10.2, EPL-2.0, approved, #9709
maven/mavencentral/org.mapstruct/mapstruct/1.4.2.Final, Apache-2.0, approved, #2483
maven/mavencentral/org.mapstruct/mapstruct/1.5.5.Final, Apache-2.0, approved, #6277
maven/mavencentral/org.mockito/mockito-core/5.7.0, MIT AND (Apache-2.0 AND MIT) AND Apache-2.0, approved, #11424
maven/mavencentral/org.mockito/mockito-junit-jupiter/5.7.0, MIT, approved, #11423
maven/mavencentral/org.objenesis/objenesis/3.3, Apache-2.0, approved, clearlydefined
Expand Down
12 changes: 6 additions & 6 deletions pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -38,16 +38,16 @@
<properties>
<java.version>17</java.version>
<spring-cloud.version>4.1.1</spring-cloud.version>
<org.mapstruct.version>1.4.2.Final</org.mapstruct.version>
<org.mapstruct.processor.version>1.4.2.Final
<org.mapstruct.version>1.5.5.Final</org.mapstruct.version>
<org.mapstruct.processor.version>1.5.5.Final
</org.mapstruct.processor.version>
<log4j2.version>2.17.1</log4j2.version>
</properties>
<dependencies>
<dependency>
<groupId>org.eclipse.persistence</groupId>
<artifactId>eclipselink</artifactId>
<version>3.0.3</version>
<version>4.0.3</version>
<exclusions>
<exclusion>
<groupId>org.eclipse.persistence</groupId>
Expand Down Expand Up @@ -212,17 +212,17 @@
<dependency>
<groupId>org.bouncycastle</groupId>
<artifactId>bcpkix-jdk18on</artifactId>
<version>1.77</version>
<version>1.78.1</version>
</dependency>
<dependency>
<groupId>org.bouncycastle</groupId>
<artifactId>bcprov-jdk18on</artifactId>
<version>1.77</version>
<version>1.78.1</version>
</dependency>
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-compress</artifactId>
<version>1.26.1</version>
<version>1.26.2</version>
</dependency>
<dependency>
<groupId>commons-io</groupId>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -36,8 +36,8 @@
import org.eclipse.tractusx.autosetup.model.Customer;
import org.eclipse.tractusx.autosetup.model.SelectedTools;
import org.eclipse.tractusx.autosetup.portal.proxy.PortalIntegrationProxy;
//import org.eclipse.tractusx.autosetup.utility.JsonObjectProcessingUtility;
//import org.eclipse.tractusx.autosetup.utility.KeyCloakTokenProxyUtitlity;
import org.eclipse.tractusx.autosetup.utility.JsonObjectProcessingUtility;
import org.eclipse.tractusx.autosetup.utility.KeyCloakTokenProxyUtitlity;
import org.eclipse.tractusx.autosetup.utility.LogUtil;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.retry.annotation.Backoff;
Expand Down Expand Up @@ -77,7 +77,7 @@ public class ConnectorRegistrationManager {

private final AutoSetupTriggerManager autoSetupTriggerManager;
private final PortalIntegrationProxy portalIntegrationProxy;
//private final KeyCloakTokenProxyUtitlity keyCloakTokenProxyUtitlity;
private final KeyCloakTokenProxyUtitlity keyCloakTokenProxyUtitlity;

@Retryable(retryFor = {
ServiceException.class }, maxAttemptsExpression = "${retry.maxAttempts}", backoff = @Backoff(delayExpression = "#{${retry.backOffDelay}}"))
Expand Down Expand Up @@ -106,7 +106,7 @@ public Map<String, String> registerConnector(Customer customerDetails, SelectedT
body.add(SUBSCRIPTION_ID, subscriptionIdVal);
Map<String, String> header = new HashMap<>();
header.put("Authorization",
"Bearer " + "");
"Bearer " + keyCloakTokenProxyUtitlity.getKeycloakToken(clientId, clientSecret, tokenURI));

String connectorId = checkSubcriptionHaveConnectorRegister(header, subscriptionIdVal);

Expand Down Expand Up @@ -175,13 +175,13 @@ private String checkSubcriptionHaveConnectorRegister(Map<String, String> header,
if (subcriptionWithConnectors != null && subcriptionWithConnectors.isArray()) {
for (JsonNode jsonNode : subcriptionWithConnectors) {

String remoteSubscriptionId = "";//JsonObjectProcessingUtility.getValueFromJsonNode(jsonNode,
//SUBSCRIPTION_ID);
String remoteSubscriptionId = JsonObjectProcessingUtility.getValueFromJsonNode(jsonNode,
SUBSCRIPTION_ID);

if (subscriptionId.equalsIgnoreCase(remoteSubscriptionId) && jsonNode!=null) {
if (subscriptionId.equalsIgnoreCase(remoteSubscriptionId)) {

JsonNode connectorIds = null;//JsonObjectProcessingUtility.getArrayNodeFromJsonNode(jsonNode,
//"connectorIds");
JsonNode connectorIds = JsonObjectProcessingUtility.getArrayNodeFromJsonNode(jsonNode,
"connectorIds");

if (connectorIds != null && connectorIds.isArray() && connectorIds.size() > 0)
return connectorIds.get(0).asText();
Expand Down Expand Up @@ -214,7 +214,7 @@ public Map<String, String> deleteConnector(SelectedTools tool, Map<String, Strin

Map<String, String> header = new HashMap<>();
header.put("Authorization",
"Bearer " + "");
"Bearer " + keyCloakTokenProxyUtitlity.getKeycloakToken(clientId, clientSecret, tokenURI));

autoSetupTriggerDetails.setStatus(TriggerStatusEnum.SUCCESS.name());
portalIntegrationProxy.deleteConnector(connectorRegistrationUrl, header, connectorId);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@
import org.eclipse.tractusx.autosetup.portal.model.TechnicalUserDetails;
import org.eclipse.tractusx.autosetup.portal.model.TechnicalUsers;
import org.eclipse.tractusx.autosetup.portal.proxy.PortalIntegrationProxy;
//import org.eclipse.tractusx.autosetup.utility.KeyCloakTokenProxyUtitlity;
import org.eclipse.tractusx.autosetup.utility.KeyCloakTokenProxyUtitlity;
import org.eclipse.tractusx.autosetup.utility.LogUtil;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.retry.annotation.Backoff;
Expand Down Expand Up @@ -68,7 +68,7 @@ public class PortalIntegrationManager {

private final AutoSetupTriggerManager autoSetupTriggerManager;

//private final KeyCloakTokenProxyUtitlity keyCloakTokenProxyUtitlity;
private final KeyCloakTokenProxyUtitlity keyCloakTokenProxyUtitlity;

@Value("${portal.url}")
private URI portalUrl;
Expand Down Expand Up @@ -115,7 +115,7 @@ public Map<String, String> postServiceInstanceResultAndGetTenantSpecs(Customer c

Map<String, String> header = new HashMap<>();
header.put(AUTHORIZATION,
BEARER + "");
BEARER + keyCloakTokenProxyUtitlity.getKeycloakToken(clientId, clientSecret, tokenURI));

ServiceInstanceResultRequest serviceInstanceResultRequest = ServiceInstanceResultRequest.builder()
.requestId(subscriptionId).offerUrl(applicationURL).build();
Expand Down Expand Up @@ -186,8 +186,7 @@ private void handlePortalServiceExcutionResponse(Map<String, String> inputData,

technicalUserData.forEach(technicalUser -> {
TechnicalUserDetails technicalUserDetails = technicalUser.getTechnicalUserDetails();
if (technicalUser.getName().contains("dim")
&& technicalUser.getPermissions().contains("Identity Wallet Management")) {
if (technicalUser.getPermissions().contains("Identity Wallet Management")) {
inputData.put("dimClientId", technicalUserDetails.getClientId());
inputData.put("dimClientSecret", technicalUserDetails.getSecret());
} else {
Expand Down Expand Up @@ -248,7 +247,7 @@ private ServiceInstanceResultResponse verifyIsAlreadySubcribedActivatedAndGetDet
try {

header.put(AUTHORIZATION,
BEARER + "");
BEARER + keyCloakTokenProxyUtitlity.getKeycloakToken(clientId, clientSecret, tokenURI));

serviceInstanceResultResponse = portalIntegrationProxy.getAppServiceInstanceSubcriptionDetails(
portalUrl, header, appServiceURIPath, offerId, subscriptionId);
Expand Down Expand Up @@ -292,7 +291,7 @@ private void readTechnicalUserDetails(Map<String, String> header,
if (serviceInstanceResultResponse.getTechnicalUserData() != null) {

header.put(AUTHORIZATION,
BEARER + "");
BEARER + keyCloakTokenProxyUtitlity.getKeycloakToken(clientId, clientSecret, tokenURI));

serviceInstanceResultResponse.getTechnicalUserData().forEach(elel -> {
try {
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
/********************************************************************************
* Copyright (c) 2024 T-Systems International GmbH
* Copyright (c) 2024 Contributors to the Eclipse Foundation
*
* See the NOTICE file(s) distributed with this work for additional
* information regarding copyright ownership.
*
* This program and the accompanying materials are made available under the
* terms of the Apache License, Version 2.0 which is available at
* https://www.apache.org/licenses/LICENSE-2.0.
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*
* SPDX-License-Identifier: Apache-2.0
********************************************************************************/

package org.eclipse.tractusx.autosetup.utility;

import com.fasterxml.jackson.databind.JsonNode;

import lombok.SneakyThrows;


public class JsonObjectProcessingUtility {

private JsonObjectProcessingUtility() {}

@SneakyThrows
public static String getValueFromJsonNode(JsonNode jsonNode, String propertyId) {
if (jsonNode != null && jsonNode.get(propertyId) != null)
return jsonNode.get(propertyId).asText();
else
return "";
}


@SneakyThrows
public static JsonNode getArrayNodeFromJsonNode(JsonNode jsonnode, String propertyId) {
if (jsonnode != null && jsonnode.get(propertyId) != null)
return jsonnode.get(propertyId);
else
return null;
}


}
Original file line number Diff line number Diff line change
@@ -0,0 +1,55 @@
/********************************************************************************
* Copyright (c) 2024 T-Systems International GmbH
* Copyright (c) 2024 Contributors to the Eclipse Foundation
*
* See the NOTICE file(s) distributed with this work for additional
* information regarding copyright ownership.
*
* This program and the accompanying materials are made available under the
* terms of the Apache License, Version 2.0 which is available at
* https://www.apache.org/licenses/LICENSE-2.0.
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations
* under the License.
*
* SPDX-License-Identifier: Apache-2.0
********************************************************************************/

package org.eclipse.tractusx.autosetup.utility;

import java.net.URI;

import org.eclipse.tractusx.autosetup.portal.proxy.PortalIntegrationProxy;
import org.springframework.stereotype.Service;
import org.springframework.util.LinkedMultiValueMap;
import org.springframework.util.MultiValueMap;

import lombok.RequiredArgsConstructor;
import lombok.SneakyThrows;

@Service
@RequiredArgsConstructor
public class KeyCloakTokenProxyUtitlity {

private final PortalIntegrationProxy portalIntegrationProxy;

@SneakyThrows
public String getKeycloakToken(String clientId, String clientSecret, URI tokenURI) {

MultiValueMap<String, Object> body = new LinkedMultiValueMap<>();
body.add("grant_type", "client_credentials");
body.add("client_id", clientId);
body.add("client_secret", clientSecret);
var resultBody = portalIntegrationProxy.readAuthToken(tokenURI, body);

if (resultBody != null) {
return resultBody.getAccessToken();
}
return null;

}

}
Loading

0 comments on commit 58e526f

Please sign in to comment.