This repo was created to support building out the official EC SDK.
Execute the buildpack will result in the following plugins/artifacts and will be checked-in in the SDK -
- TLS plugin: bin | source code
- VLAN plugin: bin | source code
- PTC Kepware/px-eventhub: bin | source code
- EC Agent: bin | source code
The agent buildpack image conviniently includes all dependencies and components to build the EC-Agent-relate products. Please refer to these steps to build a custom agent binary
This buildpack depends on the following environment variables-
- REPO: Internal EC-SDK Repo URL.
- BRANCH: The SDK branch.
- PROXY_URL: Proxy settings.
- GITTOKEN: github.build.ge.com user token for the internal SDK push.
- GITPUBTKN: github.com user token for the SDK push. This includes the homebrew ruby formula.
- DTRUSR: A dtr.predix.io cred for images push.
- DTRPWD
OR
If you are granted access to the digi-digiconnect org @dtr.predix.io, you may use the Digital-Foundry Jenkins to access all builds-
#enable docker gRPC API for DIND
dockerd -H 0.0.0.0:2375 -H unix:///var/run/docker.sock
#login into the DTR repo in Predix. This enables pull the image.
docker login dtr.predix.io -u <username> -p <password>
#launch the digital-foundry jenkins instance
docker run \
--rm \
--name digital_foundry \
--network=host
-e DOCKER_HOST=<this should resolve by your vm. E.g. 10.0.2.15. 127.0.0.1 when no vm> \
-e HTTPS_PROXY=${https_proxy} \
-e NO_PROXY=${no_proxy} \
-p 8080:8080 \
-v /var/run/docker.sock:/var/run/docker.sock \
dtr.predix.io/dig-digiconnect/digital-foundry:v1beta
#To persist the builds/logs, first let's make a backup
docker exec -u jenkins digital_foundry \
bash -c 'rm -Rf /var/backups/jenkins_home; cp -R /var/jenkins_home /var/backups/'
#secondly, commit the backup
docker commit digital_foundry dtr.predix.io/dig-digiconnect/digital-foundry:v1beta
#finally, push the commit. This step is needed in order to share the latest build information amongst other builders
docker push dtr.predix.io/dig-digiconnect/digital-foundry:v1beta
The Digital-Foundry self-provisioning Jenkins instance adopts the concept of DIND (Docker-in -Docker) which allows the EC/TC (tc-subscription series) software bundles be built anywhere with the docker-daemon installed. Since the DIND Jenkins instance requires the docker native API access via gRPC, developers would need to enable the local dockrd with the TCP access as it's specified above. You may consider enable the API via systemctl refers to the official docker for further usage.
If everything worked as expected, you may now browse the Jenkins instance locally at http://localhost:8080/job/EC/job/Core/job/EC-SDK-Build-Beta/ and VIEW the build detail. FYI annonymous users will need the DC Admin account to execute/modify jobs. Please contact the team for the credential.
The instance contains the following builds-
- SDK
- Agent
- Single-Tenance Service
- CF Broker
- Test Automation