Skip to content

Commit

Permalink
Merge pull request #186 from catenax-ng/DST_PIP10_ITR2
Browse files Browse the repository at this point in the history
[sde|v2.1.0]
  • Loading branch information
adityagajbhiye9 authored Aug 29, 2023
2 parents 479591f + 4e7d77b commit 0285c5a
Show file tree
Hide file tree
Showing 30 changed files with 472 additions and 165 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -37,20 +37,20 @@ private CommonConstants() {
public static final String MANUFACTURER_ID = "manufacturerId";
public static final String CUSTOMER_PART_ID = "customerPartId";
public static final String ASSET_LIFECYCLE_PHASE = "assetLifecyclePhase";
public static final String HTTP = "http";
public static final String HTTP = "HTTP";
public static final String HTTPS = "HTTPS";
public static final String ENDPOINT_PROTOCOL_VERSION = "0.1";
public static final String ENDPOINT_PROTOCOL_VERSION = "1.1";
public static final String PREFIX = "urn:uuid:";

public static final String INTERFACE_EDC = "EDC";
public static final String SUB_PROTOCOL = "IDS";
public static final String SUB_PROTOCOL = "DSP";
public static final String SUBMODEL_CONTEXT_URL = "/submodel";

public static final String AS_PLANNED = "AsPlanned";

public static final String EXTERNAL_REFERENCE = "ExternalReference";
public static final String GLOBAL_REFERENCE = "GlobalReference";
public static final String BODY_ENCODING = "plain";
public static final String INTERFACE = "https://admin-shell.io/aas/API/3/0/SubmodelServiceSpecification/SSP-003";
public static final String INTERFACE = "SUBMODEL-3.0";

}
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
/********************************************************************************
* Copyright (c) 2023 T-Systems International GmbH
* Copyright (c) 2023 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.sde.digitaltwins.entities.common;

import java.util.List;

import com.fasterxml.jackson.annotation.JsonIgnoreProperties;

import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;

@Data
@Builder
@AllArgsConstructor
@NoArgsConstructor
@JsonIgnoreProperties(ignoreUnknown = true)
public class ExternalSubjectId {

private String type;

private List<Keys> keys;

}
Original file line number Diff line number Diff line change
Expand Up @@ -21,15 +21,31 @@

package org.eclipse.tractusx.sde.digitaltwins.entities.common;

import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
import com.fasterxml.jackson.annotation.JsonInclude;
import com.fasterxml.jackson.databind.ObjectMapper;

import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.SneakyThrows;

@Data
@NoArgsConstructor
@Builder
@AllArgsConstructor
@NoArgsConstructor
@JsonIgnoreProperties(ignoreUnknown = true)
@JsonInclude(JsonInclude.Include.NON_NULL)
public class KeyValuePair {

private String name;
private String value;
private ExternalSubjectId externalSubjectId;

@SneakyThrows
public String toJsonString() {
final ObjectMapper mapper = new ObjectMapper();
return mapper.writeValueAsString(this);
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,44 @@
/********************************************************************************
* Copyright (c) 2023 T-Systems International GmbH
* Copyright (c) 2023 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.sde.digitaltwins.entities.common;

import java.util.List;

import com.fasterxml.jackson.annotation.JsonIgnoreProperties;

import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;

@Data
@Builder
@AllArgsConstructor
@NoArgsConstructor
@JsonIgnoreProperties(ignoreUnknown = true)
public class LookupQuery {

private String type;
private List<KeyValuePair> assetIds;
private List<String> semanticIds;



}
Original file line number Diff line number Diff line change
Expand Up @@ -45,4 +45,6 @@ public class ProtocolInformation {
private String subProtocol;
private String subprotocolBody;
private String subprotocolBodyEncoding;
private List<SecurityAttributes> securityAttributes;

}
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
/********************************************************************************
* Copyright (c) 2023 T-Systems International GmbH
* Copyright (c) 2023 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.sde.digitaltwins.entities.common;

import com.fasterxml.jackson.annotation.JsonIgnoreProperties;

import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;

@Data
@Builder
@AllArgsConstructor
@NoArgsConstructor
@JsonIgnoreProperties(ignoreUnknown = true)
public class SecurityAttributes {


private String type;
private String key;
private String value;

}
Original file line number Diff line number Diff line change
Expand Up @@ -23,9 +23,11 @@

import java.util.List;

import org.eclipse.tractusx.sde.digitaltwins.entities.common.KeyValuePair;
import org.eclipse.tractusx.sde.digitaltwins.entities.common.MultiLanguage;

import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
import com.fasterxml.jackson.annotation.JsonInclude;
import com.fasterxml.jackson.annotation.JsonInclude.Include;
import com.fasterxml.jackson.databind.ObjectMapper;

import lombok.AllArgsConstructor;
Expand All @@ -38,13 +40,15 @@
@NoArgsConstructor
@AllArgsConstructor
@Getter
@JsonIgnoreProperties(ignoreUnknown = true)
@JsonInclude(Include.NON_NULL)
public class ShellDescriptorRequest {

private String idShort;
private String id;
private List<MultiLanguage> description;
private String globalAssetId;
private List<KeyValuePair> specificAssetIds;
private List<Object> specificAssetIds;

@SneakyThrows
public String toJsonString() {
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
/********************************************************************************
* Copyright (c) 2023 T-Systems International GmbH
* Copyright (c) 2023 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.sde.digitaltwins.entities.request;

import org.eclipse.tractusx.sde.digitaltwins.entities.common.LookupQuery;

import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Getter;
import lombok.NoArgsConstructor;

@Builder
@NoArgsConstructor
@AllArgsConstructor
@Getter
public class ShellLookupQueryRequest {

private LookupQuery query;




}
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@
import java.util.Base64;
import java.util.List;

import org.apache.commons.lang3.StringUtils;
import org.eclipse.tractusx.sde.common.exception.ServiceException;
import org.eclipse.tractusx.sde.digitaltwins.entities.request.CreateSubModelRequest;
import org.eclipse.tractusx.sde.digitaltwins.entities.request.ShellDescriptorRequest;
Expand Down Expand Up @@ -55,20 +56,24 @@ public class DigitalTwinsFacilitator {
@Value(value = "${digital-twins.api:/api/v3.0}")
private String dtApiUri;

@Value(value = "${manufacturerId}")
public String manufacturerId;

public List<String> shellLookup(ShellLookupRequest request) throws ServiceException {
return shellLookupFromDDTR(request, null);
return shellLookupFromDDTR(request, null, manufacturerId);
}

@SneakyThrows
public List<String> shellLookupFromDDTR(ShellLookupRequest request, String ddtrUrl) throws ServiceException {
public List<String> shellLookupFromDDTR(ShellLookupRequest request, String ddtrUrl, String edcBpn)
throws ServiceException {

URI dtURL = (ddtrUrl == null || ddtrUrl.length() <= 0) ? getDtURL(digitalTwinsHost) : getDtURL(ddtrUrl);
URI dtURL = StringUtils.isAllEmpty(ddtrUrl) ? getDtURL(digitalTwinsHost) : getDtURL(ddtrUrl);

List<String> shellIds = List.of();

try {
ResponseEntity<ShellLookupResponse> response = digitalTwinsFeignClient.shellLookup(dtURL,
request.toJsonString());
request.toJsonString(), edcBpn);

ShellLookupResponse body = response.getBody();
if (response.getStatusCode() == HttpStatus.OK && body != null) {
Expand Down Expand Up @@ -106,17 +111,17 @@ public List<ShellDescriptorResponse> getShellDescriptorsWithSubmodelDetails(List

List<ShellDescriptorResponse> items = new ArrayList<>();
for (String shellId : shellIds) {
items.add(getShellDetailsById(shellId, ddtrUrl));
items.add(getShellDetailsById(shellId, ddtrUrl, manufacturerId));
}
return items;
}

public ShellDescriptorResponse getShellDetailsById(String shellId, String ddtrUrl) {
public ShellDescriptorResponse getShellDetailsById(String shellId, String ddtrUrl, String edcBpn) {

URI dtURL = (ddtrUrl == null || ddtrUrl.length() <= 0) ? getDtURL(digitalTwinsHost) : getDtURL(ddtrUrl);
URI dtURL = StringUtils.isAllEmpty(ddtrUrl) ? getDtURL(digitalTwinsHost) : getDtURL(ddtrUrl);

ResponseEntity<ShellDescriptorResponse> shellDescriptorResponse = digitalTwinsFeignClient
.getShellDescriptorByShellId(dtURL, encodeShellIdBase64Utf8(shellId));
.getShellDescriptorByShellId(dtURL, encodeShellIdBase64Utf8(shellId), edcBpn);
return shellDescriptorResponse.getBody();
}

Expand All @@ -142,6 +147,18 @@ public ShellDescriptorResponse createShellDescriptor(ShellDescriptorRequest requ
return responseBody;
}

public void updateShellSpecificAssetIdentifiers(String shellId, List<Object> specificAssetIds) {

digitalTwinsFeignClient.deleteShellSpecificAttributes(getDtURL(digitalTwinsHost),
encodeShellIdBase64Utf8(shellId), manufacturerId);

ResponseEntity<List<Object>> registerSubmodel = digitalTwinsFeignClient.createShellSpecificAttributes(
getDtURL(digitalTwinsHost), encodeShellIdBase64Utf8(shellId), manufacturerId, specificAssetIds);
if (registerSubmodel.getStatusCode() != HttpStatus.CREATED) {
log.error("Error in shell SpecificAssetIdentifiers deletion: " + registerSubmodel.toString());
}
}

public void createSubModel(String shellId, CreateSubModelRequest request) {

request.setDescription(List.of());
Expand Down
Loading

0 comments on commit 0285c5a

Please sign in to comment.