Data Types for Payload General For metamodel elements like AssetAdministrationShell, Submodel, Identifier, etc. that are specified in Part 1 [1], please refer to the specification in the Bibliography. The AAS package format and the AAS Package type are defined in Part 5 [4]. This clause only defines additional classes that are needed for communication with the API. Metamodel Specification Details The following type definitions are used to describe specific metamodel elements like Asset Administration Shells and submodels regarding their network and deployment configuration. They use certain attributes copied from the model element itself to describe it – hence the name Descriptor. Descriptor Class Name Descriptor Explanation The self-describing information of a network resource. This class is not part of the metamodel. Inherits from — semanticId https://admin-shell.io/aas/API/DataTypes/Descriptor/3/1 Attribute Explanation Type Card. description Description or comments on the element The description can be provided in several languages MultiLanguageTextType 0..1 displayName Display name; can be provided in several languages MultiLanguageNameType 0..1 extension An extension of the element Extension 0..* AssetAdministrationShellDescriptor Class Name AssetAdministrationShellDescriptor Explanation Descriptor of an Asset Administration Shell Inherits from Descriptor semanticId https://admin-shell.io/aas/API/DataTypes/AssetAdministrationShellDescriptor/3/1 Attribute Explanation Type Card. administration Administrative information of the Asset Administration Shell AdministrativeInformation 0..1 assetKind Denotes whether the asset of the described Asset Administration Shell is of kind “Type” or “Instance” AssetKind 0..1 assetType The type of the asset described by the Asset Administration Shell of this Descriptor. See AssetInformation/assetType for further information. Identifier 0..1 endpoint Endpoint of the network resource Endpoint 0..* globalAssetId Global reference to the asset the AAS is representing Identifier 0..1 idShort Short name of the Asset Administration Shell NameType 0..1 id Globally unique identification of the Asset Administration Shell Identifier 1 specificAssetId Specific asset identifier SpecificAssetId 0..* submodelDescriptor Descriptor of a submodel of the Asset Administration Shell SubmodelDescriptor 0..* Note: the cardinality restriction for AssetAdministrationShellDescriptor/endpoint (optional: 0..*) allows a provider to skip the declaration of the location of an AssetAdministrationShell and directly point to the endpoints of the contained Submodels through the path AssetAdministrationShellDescriptor/submodelDescriptor→ SubmodelDescriptor/endpoint. A client, therefore, might decide to skip the lookup on the AssetAdministrationShell. Nevertheless, in case the information contained in the AssetAdministrationShellDescriptor deviates from the related AssetAdministrationShell, or attributes are missing, the AssetAdministrationShell is always the source of truth. SubmodelDescriptor Class Name SubmodelDescriptor Explanation A descriptor of a submodel Inherits from Descriptor semanticId https://admin-shell.io/aas/API/DataTypes/SubmodelDescriptor/3/1 Attribute Explanation Type Card. administration Administrative information of the Submodel AdministrativeInformation 0..1 endpoint Endpoint of the network resource Endpoint 1..* idShort Short name of the Submodel NameType 0..1 id Globally unique identification of the Submodel Identifier 1 semanticId Identifier of the semantic definition of the Submodel Reference 0..1 supplementalSemanticId Identifier of a supplemental semantic definition of the element called supplemental semantic ID of the element Reference 0..* Endpoint Class Name Endpoint Explanation The endpoint description of a network resource. This class is not part of the metamodel. Inherits from - semanticId https://admin-shell.io/aas/API/DataTypes/Endpoint/3/1 Attribute Explanation Type Card. protocolInformation Protocol information of the network resource endpoint ProtocolInformation 1 interface Name of the offered interface at the endpoint NameType 1 The following names will be used for the interfaces: Interface interface-shortName Asset Administration Shell Interface AAS Submodel Interface SUBMODEL Serialization Interface SERIALIZE AASX File Server Interface AASX-FILE Asset Administration Shell Registry Interface AAS-REGISTRY Submodel Registry Interface SUBMODEL-REGISTRY Asset Administration Shell Repository Interface AAS-REPOSITORY Submodel Repository Interface SUBMODEL-REPOSITORY Concept Description Repository Interface CD-REPOSITORY Asset Administration Shell Basic Discovery Interface AAS-DISCOVERY The value for the interface attribute shall be “{interface-shortName}-{interface-version}”. The interface-version of this specification is “3.1”, e.g. the entry for the Asset Administration Shell Interface is “AAS-3.1”. See the following example for descriptor endpoints: "endpoints": [ { "protocolInformation": { "endpointAddress": "https://localhost:1234/api/3/submodel", "endpointProtocolVersion": "1.1" }, "interface": "SUBMODEL-3.1" }, { "protocolInformation": { "endpointAddress": "https://localhost:5678/api/2/submodel", "endpointProtocolVersion": "1.1" }, "interface": "SUBMODEL-2.0" } ] ProtocolInformation Class Name ProtocolInformation Explanation The protocol information of a network resource endpoint will be defined in DIN SPEC 16593-2. After the release of DIN SPEC 16593-2, any required updates will be made. This class is not part of the metamodel. The information in this table is a 1:1 copy from DIN SPEC 16593-2. Required changes need to be made by the related DIN working group. Inherits from — semanticId https://admin-shell.io/aas/API/DataTypes/ProtocolInformation/3/0 Attribute Explanation Type Card. href The endpoint address as a URL LocatorType 1 endpointProtocol Either scheme of endpointAddress or scheme + further information. Scheme denotes the highest level of doubtless transmission. SchemeType 0..1 endpointProtocolVersion Array of strings, each entry represents one supported version at this very endpoint, the entry shall be formatted according to the regulations of the protocol specified in the href LabelType 0..* subprotocol Allows for referencing sub-protocols that may be used in the context of that endpoint e.g. “OPC Basic SOAP” or UA Binary ShortIdType 0..1 subprotocolBody If the sub-protocol field is present, a subprotocolBody might be given to hold extra information, e.g. node and namespace in an OPC UA server TextType 0..1 subprotocolBodyEncoding If subprotocolBody is present, the encoding might be explicitly defined, otherwise it shall default to subprotocols encoding scheme LabelType 0..1 securityAttributes Array of securityAttribute objects, each attribute has 3 properties: { type = Enum security type or standard: ‘NONE’, 'RFC_TLSA' - TLSA according to rfc6698 'W3C_DID' - W3C DID document , key = security attribute key according to standard definitions of the security type, value = security attribute value e.g. DANE TLSA Ressource Record } The securityAttribute objects are treated as possible alternatives (logical “or”) SecurityAttributeObject 0..* Class Name SecurityAttributeObject Explanation Security attributes as defined by DIN SPEC 16593-2. After the release of DIN SPEC 16593-2, any required updates will be made. This class is not part of the metamodel. The information in this table is derived from DIN SPEC 16593-2. Required changes need to be made by the related DIN working group. Inherits from — semanticId https://admin-shell.io/aas/API/DataTypes/SecurityAttributeObject/3/0 Attribute Explanation Type Card. type Enum security type or standard SecurityTypeEnum 1 key Security attribute key according to standard definitions of the security type string 1 value Security attribute value e.g. DANE TLSA Ressource Record string 1 Enumeration SecurityTypeEnum Explanation The security types as defined by DIN SPEC 16593-2. After the release of DIN SPEC 16593-2, any required updates will be made. This class is not part of the metamodel. The information in this table is derived from DIN SPEC 16593-2. Required changes need to be made by the related DIN working group. semanticId https://admin-shell.io/aas/API/DataTypes/SecurityTypeEnum/3/0 Literal ID Explanation NONE https://admin-shell.io/aas/API/DataTypes/SecurityTypeEnum/NONE/3/0 No predefined security type available RFC_TLSA https://admin-shell.io/aas/API/DataTypes/SecurityTypeEnum/RFC_TLSA/3/0 TLSA according to RFC 6698 W3C_DID https://admin-shell.io/aas/API/DataTypes/SecurityTypeEnum/W3C_DID/3/0 Decentralized Identifiers according to the W3C Recommendation [7] AssetLink Class Name AssetLink Explanation Asset identifier derieved from either SpecificAssetId or GlobalAssetId Inherits from - semanticId https://admin-shell.io/aas/API/DataTypes/AssetLink/3/1 Attribute Explanation Type Card. name Name of the Asset identifier, i.e., "globalAssetId", a serial number, manufacturer part ID, or customer part IDs LabelType 1 value Value of the Asset Identifier Identifier 1 ServiceDescription Class Name ServiceDescription Explanation The self-describing information of an API Implementation. It enables servers to present their capabilities to the clients, in particular which profiles they implement. At least one defined profile is required. Additional, proprietary attributes might be included. Nevertheless, the server must not expect that a regular client understands them. This class is not part of the metamodel. Inherits from — semanticId https://admin-shell.io/aas/API/DataTypes/ServiceDescription/3/1 Attribute Explanation Type Card. profiles List of implemented server specification profiles. ServiceSpecificationProfileEnum 1..* Enumeration ServiceSpecificationProfileEnum Explanation The identifiers of the standardized service specification profiles. See also Clause service-specifications-and-profiles for further details. semanticId https://admin-shell.io/aas/API/DataTypes/ServiceSpecificationProfileEnum/3/1 Literal Explanation https://admin-shell.io/aas/API/3/0/AssetAdministrationShellServiceSpecification/SSP-001 Indicates that the server implemented all features of the Asset Administration Shell Service Specification Full Profile in version 3.0. https://admin-shell.io/aas/API/3/0/AssetAdministrationShellServiceSpecification/SSP-002 Indicates that the server implemented all features of the Asset Administration Shell Service Specification Read Profile in version 3.0. https://admin-shell.io/aas/API/3/0/SubmodelServiceSpecification/SSP-001 Indicates that the server implemented all features of the Submodel Service Specification Full Profile in version 3.0. https://admin-shell.io/aas/API/3/0/SubmodelServiceSpecification/SSP-002 Indicates that the server implemented all features of the Submodel Service Specification Value Profile in version 3.0. https://admin-shell.io/aas/API/3/0/SubmodelServiceSpecification/SSP-003 Indicates that the server implemented all features of the Submodel Service Specification Read Profile in version 3.0. https://admin-shell.io/aas/API/3/0/AasxFileServerServiceSpecification/SSP-001 Indicates that the server implemented all details of the AASX File Server Service Specification Full Profile in version 3.0. https://admin-shell.io/aas/API/3/0/AssetAdministrationShellRegistryServiceSpecification/SSP-001 Indicates that the server implemented all details of the Asset Administration Shell Registry Service Specification Full Profile in version 3.0. https://admin-shell.io/aas/API/3/0/AssetAdministrationShellRegistryServiceSpecification/SSP-002 Indicates that the server implemented all details of the Asset Administration Shell Registry Service Specification Read Profile in version 3.0. https://admin-shell.io/aas/API/3/1/AssetAdministrationShellRegistryServiceSpecification/SSP-003 Indicates that the server implemented all details of the Asset Administration Shell Registry Service Specification Bulk Profile in version 3.1. https://admin-shell.io/aas/API/3/0/SubmodelRegistryServiceSpecification/SSP-001 Indicates that the server implemented all details of the Submodel Registry Service Specification Full Profile in version 3.0. https://admin-shell.io/aas/API/3/0/SubmodelRegistryServiceSpecification/SSP-002 Indicates that the server implemented all details of the Submodel Registry Service Specification Read Profile in version 3.0. https://admin-shell.io/aas/API/3/1/SubmodelRegistryServiceSpecification/SSP-003 Indicates that the server implemented all details of the Submodel Registry Service Specification Bulk Profile in version 3.1. https://admin-shell.io/aas/API/3/0/DiscoveryServiceSpecification/SSP-001 Indicates that the server implemented all details of the Discovery Service Specification Full Profile in version 3.0. https://admin-shell.io/aas/API/3/0/AssetAdministrationShellRepositoryServiceSpecification/SSP-001 Indicates that the server implemented all details of the Asset Administration Shell Repository Service Specification Full Profile in version 3.0. https://admin-shell.io/aas/API/3/0/AssetAdministrationShellRepositoryServiceSpecification/SSP-002 Indicates that the server implemented all details of the Asset Administration Shell Repository Service Specification Read Profile in version 3.0. https://admin-shell.io/aas/API/3/0/SubmodelRepositoryServiceSpecification/SSP-001 Indicates that the server implemented all details of the Submodel Service Repository Specification Full Profile in version 3.0. https://admin-shell.io/aas/API/3/0/SubmodelRepositoryServiceSpecification/SSP-002 Indicates that the server implemented all details of the Submodel Service Repository Specification Read Profile in version 3.0. https://admin-shell.io/aas/API/3/0/SubmodelRepositoryServiceSpecification/SSP-003 Indicates that the server implemented all details of the Submodel Service Repository Specification Read Profile in version 3.0. https://admin-shell.io/aas/API/3/0/SubmodelRepositoryServiceSpecification/SSP-004 Indicates that the server implemented all details of the Submodel Service Repository Specification Template Profile in version 3.0. https://admin-shell.io/aas/API/3/0/ConceptDescriptionServiceSpecification/SSP-001 Indicates that the server implemented all details of the Concept Description Service Specification Read Template Profile in version 3.0. An example ServiceDescription object might look like the following, indicating that the server supports two profiles at the same time (see Clause http-rest-api/service-specifications-and-profiles.adoc#submodel-service-specification for further details on service specifications and profiles): { "profiles": [ "https://admin-shell.io/aas/API/3/0/DiscoveryServiceSpecification/SSP-001", "https://admin-shell.io/aas/API/3/0/RegistryServiceSpecification/SSP-002" ] } Query Results Result elements of AAS queries depend on the declared output selector and the target of the query. Possible targets are Asset Administration Shells, Submodels, Concept Descriptions, Asset Administration Shell Descriptors, and Submodel Descriptors. In accordance, also these objects are returned in the Query Result. In addition, their representation can be controlled via the select statements of the input query, e.g., by only selecting the identifiers of the respective objects rather than the whole content. Table 1. Simple Data Types used for API-specific Classes Query Result Definition Value Examples QueryResult<AssetAdministrationShell> List of Asset Administration Shells or a list of Asset Administration Shell identifiers [ { "modelType": "AssetAdministrationShell", "id": "https://example.com/aas-1", ... }, { "modelType": "AssetAdministrationShell", "id": "https://example.com/aas-2", ... }, ... ] [ "https://example.com/aas-1", "https://example.com/aas-2", ... ] QueryResult<Submodel> List of Submodels or a list of Submodel identifiers [ { "modelType": "Submodel", "id": "https://example.com/sm-1", ... }, { "modelType": "Submodel", "id": "https://example.com/sm-2", ... }, ... ] [ "https://example.com/sm-1", "https://example.com/sm-2", ... ] QueryResult<ConceptDescription> List of Concept Descriptions or a list of Concept Description identifiers [ { "modelType": "ConceptDescription", "id": "https://example.com/cd-1", ... }, { "modelType": "ConceptDescription", "id": "https://example.com/cd-2", ... }, ... ] [ "https://example.com/cd-1", "https://example.com/cd-2", ... ] QueryResult<AssetAdministrationShellDescriptor> List of Asset Administration Shell Descriptors or a list of Asset Administration Shell identifiers [ { "modelType": "AssetAdministrationShellDescriptor", "id": "https://example.com/aas-1", ... }, { "modelType": "AssetAdministrationShellDescriptor", "id": "https://example.com/aas-2", ... }, ... ] [ "https://example.com/aas-1", "https://example.com/aas-2", ... ] QueryResult<SubmodelDescriptor> List of Submodel Descriptors or a list of Submodel identifiers [ { "modelType": "SubmodelDescriptor", "id": "https://example.com/sm-1", ... }, { "modelType": "SubmodelDescriptor", "id": "https://example.com/sm-2", }, ... ] [ "https://example.com/sm-1", "https://example.com/sm-2", ... ] Simple Data Types All simple data types from Part 1 [1] apply also to the specifications described in this document. Additional data types are defined in Table 2. Table 2. Simple Data Types used for API-specific Classes Primitive Definition Value Examples NonNegativeInteger The nonNegativeInteger datatype as defined by XML Schema Part 2 in version 1.0 [1] 0 42 Primitive Data Types All primitive data types from Part 1 apply also to the specifications described in this document. All constraints and spelling patterns apply as well. In addition, the following data types are defined. Table 3. Primitive Data Types used for the API-specific Classes Primitive Definition Value Examples CodeType string with max 32 and min 1 characters “409” “Bad_UserAccessDenied” ShortIdType same as NameType (string with max 128 and min 1 characters) Note: ShortIdType is not the data type of idShort attributes but for IDs which shall be shorter than the identifier type. “02063059-b81c-482b-97d1-d29cbe382ef6” “my-random-id” LocatorType string with max 2048 and min 1 characters “https://example.org/” “https://provider-edc.data.plane/v3.0/shells/aas-1/submodels/submodel-1/submodel” TextType string with max 2048 and min 1 characters “asset:prop:id=123;idsEndpoint=http://edc.control.plane/” SchemeType same as NameType (string with max 128 and min 1 characters) “HTTP” Status Code, Error Handling & Result Messages This clause deals with the error and result handling of an operation’s execution in a technology-independent manner. The first clause covers generic status codes that are returned on each request, independent of the operation’s success or failure. The subsequent clause describes the result object that is returned in case of failure. Generic Status Codes Successful operations return one of the success status codes and their respective payload. Unsuccessful operations return one of the failure status codes and a result object as defined in General Result Object. Table 4 shows generic status codes returned to the requester. Additionally, the table indicates whether a specific status code comes with a result object in the returned payload. Table 4. Status Codes Generic Status Code Meaning Has Result Object Success Success No SuccessCreated Successful creation of a new resource No SuccessAccepted The reception of the request was successful No SuccessNoContent Success with explicitly no content in the payload No ClientErrorBadRequest Bad or malformed request Yes ClientNotAuthorized Wrong or missing authorization credentials Yes ClientForbidden Authorization has been refused Yes ClientMethodNotAllowed Operation request is not allowed Yes ClientErrorResourceNotFound Resource not found Yes ClientResourceConflict Conflict-creating resource (resource already exists) Yes ServerInternalError Unexpected error Yes ServerErrorBadGateway Bad gateway Yes General Result Object In case of a failed operation execution, a result object shall be returned containing more information about the reasons why the operation failed to execute. Class Name Result Explanation The result object Inherits from — semanticId https://admin-shell.io/aas/API/DataTypes/Result/3/0 Attribute Explanation Type Card. message Additional message containing information for the requester Message 0..* Class Name Message Explanation A message containing more information for the requester about a certain happening in the backend Inherits from — semanticId https://admin-shell.io/aas/API/DataTypes/Message/3/0 Attribute Explanation Type Card. messageType The message type MessageTypeEnum 1 text The message text string 1 code Technology-dependent status or error code CodeType 0..1 correlationId Identifier to relate several result messages throughout several systems ShortIdType 0..1 timestamp Timestamp of the message dateTime 0..1 Enumeration MessageTypeEnum Explanation The message type semanticId https://admin-shell.io/aas/API/DataTypes/MessageTypeEnum/3/0 Literal Explanation Info Used to inform the user about a certain fact Warning Used for warnings; warnings may lead to errors in the subsequent execution Error Used for handling errors Exception Used in case of an internal and/or unhandled exception Operation Objects The following type definitions are used to call and handle the requests and responses while performing synchronous or asynchronous operation invocation. OperationRequest Class Name OperationRequest Explanation The operation request object Inherits from — semanticId* https://admin-shell.io/aas/API/DataTypes/OperationRequest/3/0 Attribute Explanation Type Card. inputArguments Input argument OperationVariable 0..* inoutputArguments InOutput argument OperationVariable 0..* clientTimeoutDuration Duration indicating when the client suggests the server to have finished execution of the invoked operation. The server may take this value into account to decide on its effective timeout, however, the server may or may not use by its own discretion. duration 0..1 BaseOperationResult Class Name BaseOperationResult Explanation The object containing the intermediate state of an operation Inherits from Result semanticId https://admin-shell.io/aas/API/DataTypes/BaseOperationResult/3/1 Attribute Explanation Type Card. executionState Execution state ExecutionState 1 success Flag indicating whether the business operation behind the operation was successful (true) or not (false) boolean 0..1 OperationResult Class Name OperationResult Explanation The operation’s invocation result object Inherits from BaseOperationResult semanticId https://admin-shell.io/aas/API/DataTypes/OperationResult/3/0 Attribute Explanation Type Card. outputArguments Output argument OperationVariable 0..* inoutputArguments InOutput argument OperationVariable 0..* Enumeration ExecutionState Enumeration ExecutionState Explanation The operation’s invocation result state semanticId https://admin-shell.io/aas/API/DataTypes/ExecutionState/3/0 Literal Explanation Initiated The operation is ready to be executed (initial state) Running The operation is running Completed The operation is completed Canceled The operation was cancelled externally Failed The operation failed Timeout The operation has timed out due to given client or server timeout OperationHandle Class Name OperationHandle Explanation The returned handle of an operation’s asynchronous invocation used to request the current state of the operation’s execution Inherits from — semanticId https://admin-shell.io/aas/API/DataTypes/OperationHandle/3/0 Attribute Explanation Type Card. handleId Handle ID ShortIdType 1 File Content The “File Content” type of the operations mentioned above is seen as “arbitrary binary data” according to RFC 2046 and is as such defined as byte-array in UTF8-encoding. If a content type is required, “application/octet-stream” must be used as defined in RFC 2046. 1. https://www.w3.org/TR/xmlschema-2/