It is necessary to inject the environment variables, credentials and URLs that can be found on application.properties file. For more details, please refer configuration section from README.md
We have helm chart available for ArgoCD deployment. In deployment, if don't specified specific version, the app version/chart version is automatically picked up by ArgoCD and deployed to the environment using Helm charts.
In values.yaml you can find default
as value for all required configuration. You need to change all those values as per your need. For reference, please refer configuration example section.
As part of argo CD deployment using helm chart the postgres database dependency will get provide automatic but for EDC, DigitalTwin and Portal you need to provide valid details as per configuration requirement other wise SDE service will get started with default configuration but will not work as expected.
- k8s cluster/ minikube
- helm
- Docker
In values.yaml you can find default
as value for all required configuration. You need to change all those values as per your need. For reference, please refer configuration example section.
helm repo add sdebackend https://eclipse-tractusx.github.io/charts/dev
helm search repo sdebackend/sde
helm install -f your-values.yaml release-name sdebackend/sde-app
- JDK17
- Postgres 12.12.10
- Clone the GitHub Repository - https://github.com/eclipse-tractusx/managed-simple-data-exchanger-backend.
- Get your instance of postgres running (Create sdedb new database).
- Setup your project environment to JDK 17.
- Provide require application configuration in application.properties as specified in step configuration.properties.
- Start the SDE spring boot application from your IDE using main class or use spring CLI.
SDE-backend use Maven for building process. To build a service from sources one need to go to corresponding directory and trigger building process:
cd managed-simple-data-exchanger-backend
./mvnw clean install
Then fat jar file can be found in modules/sde-core/target folder as well as in local Maven repository. it can be run with this command:
java -jar target/sde-core-0.0.1.jar
When a file .csv is uploaded, the program checks whether the file is a SerialPartTypization or an AssemblyPartRelationship and there is a pipeline for each one. Apart from both upload Batch upload is additional feature were added into DFT.
For Serial Part:
- Maps the content of the line with an Serial Part Typization Aspect.
- Generates the UUID if it does not contain a UUID.
- Registers in DigitalTwins.
- Create Asset in EDC Connector.
- Stores the line in the database.
For Single Level BoM As Built:
- Maps the content of the line with an Assembly Part Relationship Aspect Relationship.
- checks if an Serial Part Typization Aspect exists so it can be related to that Aspect.
- Registers in DigitalTwins.
- Create Asset in EDC Connector.
- Stores the line in the database.
For Single Level Usage As Built:
- Maps the content of the line with an Single Level Usage As Built Aspect Relationship.
- checks if an Serial Part Typization Aspect exists so it can be related to that Aspect.
- Registers in DigitalTwins.
- Create Asset in EDC Connector.
- Stores the line in the database.
For Batch Upload:
- Maps the content of the line with an Batch.
- Generates the UUID if it does not contain a UUID.
- Registers in DigitalTwins.
- Create Asset in EDC Connector.
- Stores the line in the database.
For PartAsPlanned Upload:
- Maps the content of the line with an PartAsPlanned.
- Generates the UUID if it does not contain a UUID.
- Registers in DigitalTwins.
- Create Asset in EDC Connector.
- Stores the line in the database.
For PartTypeInformation Upload:
- Maps the content of the line with an PartTypeInformation.
- Generates the UUID if it does not contain a UUID.
- Registers in DigitalTwins.
- Create Asset in EDC Connector.
- Stores the line in the database.
For SingleLevelBoMAsPlanned Upload:
- Maps the content of the line with an SingleLevelBoMAsPlanned.
- checks if an PartAsPlanned Aspect exists so it can be related to that Aspect.
- Registers in DigitalTwins.
- Create Asset in EDC Connector.
- Stores the line in the database.
For PartSiteInformationAsPlanned Upload:
- Maps the content of the line with an PartSiteInformationAsPlanned.
- checks if an PartAsPlanned Aspect exists so it can be related to that Aspect.
- Registers in DigitalTwins.
- Create Asset in EDC Connector.
- Stores the line in the database.
For Pcf Upload:
- Maps the content of the line with an Pcf.
- checks if an PartAsPlanned Aspect exists so it can be related to that Aspect.
- Registers in DigitalTwins.
- Create Asset in EDC Connector.
- Stores the line in the database.
The file .csv is loaded in memory, the content is saved and then, the file is removed from memory.
If the file is not .csv, it is read, processed and is considered as FAILED.