(formerly known as PyI40AAS – Python Industry 4.0 Asset Administration Shell)
The Eclipse BaSyx Python project focuses on providing a Python implementation of the Asset Administration Shell (AAS) for Industry 4.0 Systems. These are the currently implemented specifications:
Specification | Version |
---|---|
Part 1: Metamodel | v3.0.1 (01001-3-0-1) |
Schemata (JSONSchema, XSD) | v3.0.8 (IDTA-01001-3-0-1_schemasV3.0.8) |
Part 2: API | v3.0 (01002-3-0) |
Part 3a: Data Specification IEC 61360 | v3.0 (01003-a-3-0) |
Part 5: Package File Format (AASX) | v3.0 (01005-3-0) |
This repository is structured into separate packages.
The sdk
directory provides the AAS metamodel as Python objects and fundamental functionalities to handle AAS.
The server
implements a specification-compliant Docker HTTP server for AASs.
The compliance_tool
is to be determined.
- SDK:
- Modelling of AASs as Python objects
- Reading and writing of AASX package files
- (De-)serialization of AAS objects into/from JSON and XML
- Experimental serialization to RDF (see branch Experimental/Adapter/RDF). Please refer to discussion of PR #308 for the reasoning behind keeping this feature experimental.
- Storing of AAS objects in CouchDB, Backend infrastructure for easy expansion
- Compliance checking of AAS XML and JSON files
- Server: Docker Image of a specification compliant HTTP Server implementing the interfaces:
- Asset Administration Shell Repository
- Submodel Repository
- Compliance Tool: A command-line tool for checking compliance of JSON and XML files to the specification of the AAS
The BaSyx Python SDK project is licensed under the terms of the MIT License.
SPDX-License-Identifier: MIT
For more information, especially considering the licenses of included third-party works, please consult the NOTICE
file.
The Eclipse BaSyx-Python SDK Team evaluates bi-monthly the newly added commits to the main branch towards the need of releasing a new version. If decided the changes warrant a release, it is initiated, using semantic versioning for the new release number. If the changes do not warrant a release, the decision is postponed to the next meeting.
Additionally, security fixes may be released at any point.
For contributing with issues and code, please see our Contribution Guideline.
To contribute code to this project you need to sign the Eclipse Contributor Agreement (ECA). This is done by creating an Eclipse account for your git e-mail address and then submitting the following form: https://accounts.eclipse.org/user/eca