Skip to content

Latest commit

 

History

History
181 lines (162 loc) · 16 KB

File metadata and controls

181 lines (162 loc) · 16 KB

tractusx-connector-memory

Version: 0.7.2 Type: application AppVersion: 0.7.2

A Helm chart for Tractus-X Eclipse Data Space Connector based on memory. Please only use this for development or testing purposes, never in production workloads!

Homepage: https://github.com/eclipse-tractusx/tractusx-edc/tree/main/charts/tractusx-connector-memory

Setting up IATP

Preconditions

  • You'll need an account with DIM, the wallet for VerifiableCredentials
  • the necessary set of VerifiableCredentials for this participant must already be issued to your DIM tenant. This is typically done by the Portal during participant onboarding
  • the client ID and client secret corresponding to that account must be known

Preparatory work

  • store client secret in the HashiCorp vault using an alias. The exact procedure will depend on your deployment of HashiCorp Vault and is out of scope of this document. But by default, Tractus-X EDC expects to find the secret under secret/client-secret. The alias must be configured using the iatp.sts.oauth.client.secret_alias Helm value.

Configure the chart

Be sure to provide the following configuration entries to your Tractus-X EDC Helm chart:

  • iatp.sts.oauth.token_url: the token endpoint of DIM
  • iatp.sts.oauth.client.id: the client ID of your tenant in DIM
  • iatp.sts.oauth.client.secret_alias: alias under which you saved your DIM client secret in the vault
  • iatp.sts.dim.url: the base URL for DIM

In addition, in order to map BPNs to DIDs, a new service is required, called the BPN-DID Resolution Service, which must be configured:

  • controlplane.bdrs.server.url: base URL of the BPN-DID Resolution Service ("BDRS")

Launching the application

As an easy starting point, please consider using this example configuration to launch the application. The configuration values mentioned above (controlplane.ssi.*) will have to be adapted manually. Combined, run this shell command to start the in-memory Tractus-X EDC runtime:

helm repo add tractusx-edc https://eclipse-tractusx.github.io/charts/dev
helm install my-release tractusx-edc/tractusx-connector-memory --version 0.7.2 \
     -f <path-to>/tractusx-connector-memory-test.yaml \
     --set vault.secrets="client-secret:$YOUR_CLIENT_SECRET"

Source Code

Values

Key Type Default Description
backendService.httpProxyTokenReceiverUrl string "https://example.com" Specifies a backend service which will receive the EDR
customCaCerts object {} Add custom ca certificates to the truststore
customLabels object {} To add some custom labels
fullnameOverride string ""
iatp.id string "did:web:changeme"
iatp.sts.dim.url string nil
iatp.sts.oauth.client.id string nil
iatp.sts.oauth.client.secret_alias string nil
iatp.sts.oauth.token_url string nil
iatp.trustedIssuers list [] Configures the trusted issuers for this runtime
imagePullSecrets list [] Existing image pull secret to use to obtain the container image from private registries
nameOverride string ""
participant.id string "BPNLCHANGEME" BPN Number
runtime.affinity object {}
runtime.autoscaling.enabled bool false Enables horizontal pod autoscaling
runtime.autoscaling.maxReplicas int 100 Maximum replicas if resource consumption exceeds resource threshholds
runtime.autoscaling.minReplicas int 1 Minimal replicas if resource consumption falls below resource threshholds
runtime.autoscaling.targetCPUUtilizationPercentage int 80 targetAverageUtilization of cpu provided to a pod
runtime.autoscaling.targetMemoryUtilizationPercentage int 80 targetAverageUtilization of memory provided to a pod
runtime.bdrs.cache_validity_seconds int 600
runtime.bdrs.server.url string nil
runtime.businessPartnerValidation.log.agreementValidation bool true
runtime.debug.enabled bool false
runtime.debug.port int 1044
runtime.debug.suspendOnStart bool false
runtime.endpoints object {"control":{"path":"/control","port":8083},"default":{"path":"/api","port":8080},"management":{"authKey":"password","path":"/management","port":8081},"protocol":{"path":"/api/v1/dsp","port":8084},"proxy":{"authKey":"password","path":"/proxy","port":8186},"public":{"path":"/api/public","port":8086}} endpoints of the control plane
runtime.endpoints.control object {"path":"/control","port":8083} control api, used for internal control calls. can be added to the internal ingress, but should probably not
runtime.endpoints.control.path string "/control" path for incoming api calls
runtime.endpoints.control.port int 8083 port for incoming api calls
runtime.endpoints.default object {"path":"/api","port":8080} default api for health checks, should not be added to any ingress
runtime.endpoints.default.path string "/api" path for incoming api calls
runtime.endpoints.default.port int 8080 port for incoming api calls
runtime.endpoints.management object {"authKey":"password","path":"/management","port":8081} data management api, used by internal users, can be added to an ingress and must not be internet facing
runtime.endpoints.management.authKey string "password" authentication key, must be attached to each 'X-Api-Key' request header
runtime.endpoints.management.path string "/management" path for incoming api calls
runtime.endpoints.management.port int 8081 port for incoming api calls
runtime.endpoints.protocol object {"path":"/api/v1/dsp","port":8084} dsp api, used for inter connector communication and must be internet facing
runtime.endpoints.protocol.path string "/api/v1/dsp" path for incoming api calls
runtime.endpoints.protocol.port int 8084 port for incoming api calls
runtime.env object {}
runtime.envConfigMapNames list []
runtime.envSecretNames list []
runtime.envValueFrom object {}
runtime.image.pullPolicy string "IfNotPresent" Kubernetes image pull policy to use
runtime.image.repository string ""
runtime.image.tag string "" Overrides the image tag whose default is the chart appVersion
runtime.ingresses[0].annotations object {} Additional ingress annotations to add
runtime.ingresses[0].certManager.clusterIssuer string "" If preset enables certificate generation via cert-manager cluster-wide issuer
runtime.ingresses[0].certManager.issuer string "" If preset enables certificate generation via cert-manager namespace scoped issuer
runtime.ingresses[0].className string "" Defines the ingress class to use
runtime.ingresses[0].enabled bool false
runtime.ingresses[0].endpoints list ["protocol","public"] EDC endpoints exposed by this ingress resource
runtime.ingresses[0].hostname string "edc-control.local" The hostname to be used to precisely map incoming traffic onto the underlying network service
runtime.ingresses[0].tls object {"enabled":false,"secretName":""} TLS tls class applied to the ingress resource
runtime.ingresses[0].tls.enabled bool false Enables TLS on the ingress resource
runtime.ingresses[0].tls.secretName string "" If present overwrites the default secret name
runtime.ingresses[1].annotations object {} Additional ingress annotations to add
runtime.ingresses[1].certManager.clusterIssuer string "" If preset enables certificate generation via cert-manager cluster-wide issuer
runtime.ingresses[1].certManager.issuer string "" If preset enables certificate generation via cert-manager namespace scoped issuer
runtime.ingresses[1].className string "" Defines the ingress class to use
runtime.ingresses[1].enabled bool false
runtime.ingresses[1].endpoints list ["management","control"] EDC endpoints exposed by this ingress resource
runtime.ingresses[1].hostname string "edc-control.intranet" The hostname to be used to precisely map incoming traffic onto the underlying network service
runtime.ingresses[1].tls object {"enabled":false,"secretName":""} TLS tls class applied to the ingress resource
runtime.ingresses[1].tls.enabled bool false Enables TLS on the ingress resource
runtime.ingresses[1].tls.secretName string "" If present overwrites the default secret name
runtime.initContainers list []
runtime.limits.cpu float 1.5
runtime.limits.memory string "512Mi"
runtime.livenessProbe.enabled bool true Whether to enable kubernetes liveness-probe
runtime.livenessProbe.failureThreshold int 6 when a probe fails kubernetes will try 6 times before giving up
runtime.livenessProbe.initialDelaySeconds int 30 seconds to wait before performing the first liveness check
runtime.livenessProbe.periodSeconds int 10 this fields specifies that kubernetes should perform a liveness check every 10 seconds
runtime.livenessProbe.successThreshold int 1 number of consecutive successes for the probe to be considered successful after having failed
runtime.livenessProbe.timeoutSeconds int 5 number of seconds after which the probe times out
runtime.logging string ".level=INFO\norg.eclipse.edc.level=ALL\nhandlers=java.util.logging.ConsoleHandler\njava.util.logging.ConsoleHandler.formatter=java.util.logging.SimpleFormatter\njava.util.logging.ConsoleHandler.level=ALL\njava.util.logging.SimpleFormatter.format=[%1$tY-%1$tm-%1$td %1$tH:%1$tM:%1$tS] [%4$-7s] %5$s%6$s%n" configuration of the Java Util Logging Facade
runtime.nodeSelector object {}
runtime.podAnnotations object {} additional annotations for the pod
runtime.podLabels object {} additional labels for the pod
runtime.podSecurityContext object {"fsGroup":10001,"runAsGroup":10001,"runAsUser":10001,"seccompProfile":{"type":"RuntimeDefault"}} The pod security context defines privilege and access control settings for a Pod within the deployment
runtime.podSecurityContext.fsGroup int 10001 The owner for volumes and any files created within volumes will belong to this guid
runtime.podSecurityContext.runAsGroup int 10001 Processes within a pod will belong to this guid
runtime.podSecurityContext.runAsUser int 10001 Runs all processes within a pod with a special uid
runtime.podSecurityContext.seccompProfile.type string "RuntimeDefault" Restrict a Container's Syscalls with seccomp
runtime.readinessProbe.enabled bool true Whether to enable kubernetes readiness-probes
runtime.readinessProbe.failureThreshold int 6 when a probe fails kubernetes will try 6 times before giving up
runtime.readinessProbe.initialDelaySeconds int 30 seconds to wait before performing the first readiness check
runtime.readinessProbe.periodSeconds int 10 this fields specifies that kubernetes should perform a readiness check every 10 seconds
runtime.readinessProbe.successThreshold int 1 number of consecutive successes for the probe to be considered successful after having failed
runtime.readinessProbe.timeoutSeconds int 5 number of seconds after which the probe times out
runtime.replicaCount int 1
runtime.requests.cpu string "500m"
runtime.requests.memory string "128Mi"
runtime.resources object {} resource management for the container
runtime.securityContext.allowPrivilegeEscalation bool false Controls Privilege Escalation enabling setuid binaries changing the effective user ID
runtime.securityContext.capabilities.add list [] Specifies which capabilities to add to issue specialized syscalls
runtime.securityContext.capabilities.drop list ["ALL"] Specifies which capabilities to drop to reduce syscall attack surface
runtime.securityContext.readOnlyRootFilesystem bool true Whether the root filesystem is mounted in read-only mode
runtime.securityContext.runAsNonRoot bool true Requires the container to run without root privileges
runtime.securityContext.runAsUser int 10001 The container's process will run with the specified uid
runtime.service.annotations object {}
runtime.service.type string "ClusterIP" Service type to expose the running application on a set of Pods as a network service.
runtime.token.refresh.expiry_seconds int 300
runtime.token.refresh.expiry_tolerance_seconds int 10
runtime.token.refresh.refresh_endpoint string nil
runtime.token.signer.privatekey_alias string nil
runtime.token.verifier.publickey_alias string nil
runtime.tolerations list []
runtime.url.protocol string "" Explicitly declared url for reaching the dsp api (e.g. if ingresses not used)
runtime.url.public string ""
runtime.url.readiness string ""
runtime.volumeMounts list [] declare where to mount volumes into the container
runtime.volumes list [] volume directories
serviceAccount.annotations object {}
serviceAccount.create bool true
serviceAccount.imagePullSecrets list [] Existing image pull secret bound to the service account to use to obtain the container image from private registries
serviceAccount.name string ""
tests object {"hookDeletePolicy":"before-hook-creation,hook-succeeded"} Configurations for Helm tests
tests.hookDeletePolicy string "before-hook-creation,hook-succeeded" Configure the hook-delete-policy for Helm tests
vault.secretNames string nil
vault.secrets string ""
vault.server.postStart string ""

Autogenerated from chart metadata using helm-docs v1.10.0