This Command Line Interface (CLI) is a local client that's used for two purposes:
a) Operator Management Tasks
- operate on the control plane
- upload/download artifacts to the artifact proxy.
b) Attestation Crafting Process
- Perform the attestation process inside a CI/CD system.
The project is a Go CLI that leverages Cobra for CLI scaffolding, Viper for configuration handling, gRPC to communicate with both the control plane and the Artifact CAS APIs, and the cosign, in-toto, DSEE and SLSA projects for the attestation process.
We use make
for most development tasks. Run make -C app/cli
to see a list of the available tasks.
Refer to development guide for more information but in a nutshell.
go run app/cli/main.go --insecure
NOTE: In development a --insecure flag must be provided to talk to the local APIs
If you want to use this CLI pointing to a local or custom instance of Chainloop, you need to perform a config override this way.
go run app/cli/main.go config save --insecure --control-plane localhost:9000 --artifact-cas localhost:9001
make test
make build
We leverage buf.io to lint and generate proto files. Make sure you install buf first. Once done, generating the API code is as easy as executing
make api
By default CLI uses the following values for the Control Plane and Artifacts CAS API endpoints:
- Artifacts CAS: api.cas.chainloop.dev:443
- Control Plane API: api.cp.chainloop.dev:443
If you want to change them to your custom endpoints, you can do that at build time. We will use ldflags
and the following variables: defaultCASAPI
and defaultCPAPI
. We assume in this example that we have our instance of Chainloop running at the following locations: api.cas.acme.com:443
and api.cp.acme.com:443
.
go build -ldflags "-X 'github.com/chainloop-dev/chainloop/app/cli/cmd.defaultCASAPI=api.cas.acme.com:443' -X 'github.com/chainloop-dev/chainloop/app/cli/cmd.defaultCPAPI=api.cp.acme.com:443'" app/cli/main.go
Please make sure to review the Contribution guidelines and feel free to reach out if you have any questions!
Welcome!