Skip to main content

Installation

There are four supported ways to get CI/lock running.

1. Prebuilt binary

Binaries are distributed from cilock.dev — every download is served (and counted) from our own infrastructure, and each artifact is uploaded only after the release pipeline verifies it against the signed release policy (verify-then-upload). Static binaries are published for:

OSArchitectures
Linuxamd64, arm64
macOS (Darwin)amd64, arm64

Windows is not currently shipped — the omnitrail attestor has linux/darwin-only build constraints.

Default binary signer set

The prebuilt cilock binary includes file and fulcio (keyless). That's it for the default release — two signers covering the two real production use cases: a private key file you own, or a keyless ephemeral identity certificate issued by the TestifySec platform's Fulcio from your CI's OIDC token. The cloud-broker signers (kms/aws, kms/gcp, kms/azure, spiffe, vault, vault-transit) and the test-only debug-signer are not in the default — they're opt-in via rookery-builder.

This is deliberate. The release binary is the one users verify; shipping debug helpers or cloud-broker clients in it would mean more code to trust and more code to verify, for use cases the default user doesn't need. Same CI/lock, smaller attack surface. The default binary still ships every attestor.

Quick install

curl -fsSL https://cilock.dev/install.sh | bash

The script auto-detects your OS/arch, resolves the latest stable version from cilock.dev/dl/manifest.json, downloads the matching archive, and verifies its SHA-256 against the published checksums-sha256.txt before installing. Knobs:

VariableDefaultPurpose
CILOCK_VERSIONlatest stablePin a version, e.g. v2.0.0. Required for pre-releases — they don't move latest.
CILOCK_BIN_DIR/usr/local/bin if writable, else $HOME/.local/binInstall directory.
CILOCK_DIST_BASEhttps://cilock.devOverride the distribution origin.

Manual download

Each release publishes, under https://cilock.dev/dl/<version>/:

FamilyFilesWhat it's for
Binarycilock-<version>-<os>-<arch>.tar.gz + .dsse.jsonThe compressed binary + a cilock-signed DSSE envelope over the archive bytes (platform Fulcio + TSA).
Checksumschecksums-sha256.txt + .dsse.jsonSHA-256 of every archive, DSSE-signed.
Per-platform attestation<os>-<arch>.attestation.jsonThe build's signed evidence collection (environment, git, github, command-run, product) — the input to cilock verify.
VSAcilock-<version>-<os>-<arch>.vsa.jsonVerification Summary Attestation — the verify result the release pipeline itself computed.
SBOMcilock-<version>-sbom.spdx.jsonSPDX SBOM.
Signed policyrelease-v1.policy.json (at https://cilock.dev/policy/)The DSSE-signed release policy, anchored to the TestifySec Platform Root CA and the release workflow identity.
# OS: linux|darwin ARCH: amd64|arm64
VERSION=v2.0.0
OS=linux
ARCH=amd64
ARCHIVE="cilock-${VERSION#v}-${OS}-${ARCH}.tar.gz"
BASE="https://cilock.dev/dl/${VERSION}"

curl -fsSLO "${BASE}/${ARCHIVE}"
curl -fsSLO "${BASE}/checksums-sha256.txt"

# Integrity: the bytes match what the publisher signed.
grep " ${ARCHIVE}\$" checksums-sha256.txt | shasum -a 256 -c - # or: sha256sum -c -

tar xzf "${ARCHIVE}" cilock && chmod +x cilock && ./cilock version
macOS / Apple Silicon

Use OS=darwin and ARCH=arm64 on Apple Silicon (M1 and later), or ARCH=amd64 on Intel Macs. Running a Linux binary on macOS fails with zsh: exec format error.

The SHA-256 check proves the bytes match the published checksums. To cryptographically verify the binary against the TestifySec platform signing identity — flagless cilock verify against the signed release policy + the per-platform attestation — see Verify the cilock binary.

2. GitHub Action

For GitHub Actions workflows, use the aflock-ai/cilock-action Action. It downloads its own variant binary at runtime (containing every attestor — including secretscan, govulncheck, slsa, inclusion-proof, the trace-enabled product attestor) and wraps your commands.

permissions:
id-token: write # required for keyless OIDC signing (Sigstore default)
contents: read

steps:
- uses: aflock-ai/cilock-[email protected] # pin to an exact tag or commit SHA
with:
step: build
command: "go build -o myapp ./cmd/myapp"
attestations: environment git github product sbom secretscan govulncheck slsa
enable-sigstore: "true"
hashes: "sha256"
trace: "true" # ptrace network egress + file ops; required by hermetic Rego gates

attestations defaults to environment git github when omitted. Pinning the action to an exact tag (or, better, a 40-character commit SHA) is consistent with the SHA-pinning advice in Layer 1 of the intro, the float-tag pattern is what the March 2026 Trivy attack exploited.

Dogfood pattern: CI/lock's own release pipeline uses this Action twice per platform — once to attest go mod vendor (step name vendor-cilock-deps), once to attest go build -mod=vendor (step name release-build). The policy declares release-build.artifactsFrom = ["vendor-cilock-deps"], so the build's materials are checked digest-for-digest against the vendor's products. You can apply the same source→vendor→build chain pattern to your own releases — see .github/workflows/release.yml for the canonical example.

For a real five-step pipeline (lint, SAST, test, build+SBOM, docker build), see testifysec/dropbox-clone/.github/workflows/cilock-action-oidc.yaml. See the GitHub Action reference for the full input list.

3. GitLab CI template

For GitLab CI, include the reusable template:

include:
- remote: 'https://raw.githubusercontent.com/aflock-ai/cilock-action/v1/gitlab/cilock.gitlab-ci.yml'

build:
extends: .cilock
variables:
CILOCK_STEP: build
CILOCK_COMMAND: "go build -o myapp ./cmd/myapp"

See the GitLab component reference for the full variable list.

4. Build from source

The cilock binary lives in the rookery monorepo at cilock/cmd/cilock/main.go. You'll need Go 1.26+.

git clone https://github.com/aflock-ai/rookery
cd rookery/cilock
GOWORK=off CGO_ENABLED=0 go build -trimpath -o cilock ./cmd/cilock/
./cilock version

GOWORK=off is required because the default Go workspace is set up for monorepo development; CGO_ENABLED=0 produces a static binary matching the released artifacts.

This rebuilds the default binary (file + fulcio signers, every attestor). To compose a binary with a different plugin set, use the rookery-builder — it generates a real CI/lock with whatever attestors and signers you specify. The release pipeline (.github/workflows/release.yml) is the canonical template for a full multi-arch signed release build.

Verifying your install

Whichever path you pick, sanity-check with:

cilock version
cilock attestors list

The attestors list output shows every attestor compiled into the binary, plus markers for which are always-run (material, product, command-run) and which are enabled by default. See Getting Started to actually run it.