This repository contains code for the plugins needed to generate and upload notes, occurrences, and attestations related to building an application, and authorization for deployment based on those attestations.
It contains the following:
- Maven plugins for build, test, and security-scan goals
- Gradle plugins for build, test, and security-scan goals
- Scripts to support signing metadata objects and verifying signatures
- Scripts to support making deployment decisions based on attestations
The gpg-script.sh script provides for signing and verification of data provided as an argument to the script:
gpg-script.sh --sign "<authority-name>" "<data-to-be-signed>"
gpg-script.sh --verify "<signature-string>"
gpg-script.sh --get-signature-keyid "<signature-string>"
gpg-script.sh --get-signature-data "<signature-string>"
The first form signs the provided data using the key identified by authority-name, outputs the resulting signature as a base64-encoded string. The authority-name identifies an attestation authority using it's full name.
The last three forms verify a base64-encoded signature-string, provided as a parameter. The verify operation simply returns 0 or 1 to indicate success or failure. The getkey opereration returns 0 or 1 to indicate whether the signature is valid, and outputs the short-form keyid of the public key that verified the signature. The getdata operation returns 0 or 1 to indicate whether the signature is valid, and outputs the data that was signed.
The signatures produced/verified are attached, ascii-armored PGP signatures.
The script also provides functions to initialize the local keyring, to get the names of known attestation authorities, and to get the key id for an attestation authority:
gpg-script.sh --init-keyring
gpg-script.sh --get-authority-names
gpg-script.sh --get-authority-keyid <authority-name>
There are 3 scripts:
- policy-provision.sh
- authorities-generator.sh
- sbas-check.sh
These 3 scripts depend on below environment variables, which are from Wercker envrionment variables.
- GRAFEAS_SERVER_ADDRESS: the host of the Grafeas server.
- GRAFEAS_SERVER_PORT: the port of the Grafeas server.
- GPG_SCRIPT: the script that execute pgp sign and verify.
- ATTESTATION_AUTHORITY_FILE: the location to store attestation authority data.
Below environment varaibles are optional:
- SPHINX_PMS_ENDPOINT
- SPHINX_TMS_ENDPOINT
- SPHINX_ARS_ENDPOINT
- SPHINX_CLIENT_ID
- SPHINX_CLIENT_SECRET
- SPHINX_PMS_TOKEN
- SPHINX_SERVICE_NAME
If not set them, the default values (except SHPINX_PMS_TOKEN
and SPHINX_SERVICE_NAME
) are based on the JSON data:
{
"name":"sscm-demo",
"id":"bak8dhbp5c8g00dbaup0",
"pmsEndpoint":"https://a.authz.fun:6733/bak8dhbp5c8g00dbaup0/policy-mgmt/v1/",
"arsEndpoint":"https://a.authz.fun:6734/bak8dhbp5c8g00dbaup0/authz-check/v1/",
"tmsEndpoint":"https://a.authz.fun:6735/bak8dhbp5c8g00dbaup0/tenant-mgmt/v1/",
"clientID":"client-BDIuVS",
"clientSecret":"eYHNuaFZBH"
}
For more details, please check SBAS Implementation for POC.
If not provision policy in Sphinx side, execute the script policy-provision.sh
policy-provision.sh
This script will firstly clear the old service then create policy. The attestation name is get by "GPG_SCRIPT".
If want to execute "Attestation Authority" check, we must execute the script authorities-generator.sh
before sbas-check.sh
.
To generate the attestation authority file, run:
authorities-generator.sh
This script will call "GPG_SCRIPT" to get attestation name and key id. The result is wrote to the file "ATTESTATION_AUTHORITY_FILE".
To check if a resource can be deployed, run script:
sbas-check.sh <project name> <resource url> <cluster name>
sbas-check.sh build https://host/demo/build@sha256:aba48d60ba4410ec921f9d2e8169236c57660d121f9430dc9758d754eec8f887 experimental
This scipt will load meta data from Grafeas, execute signature verification and send request to Sphinx to get the final decision.