2023-06-01 07:55:46 -04:00
/ *
Copyright ( c ) Edgeless Systems GmbH
SPDX - License - Identifier : AGPL - 3.0 - only
* /
2023-08-23 10:39:49 -04:00
/ *
2023-08-31 04:46:50 -04:00
This package provides a CLI to interact with the Attestationconfig API , a sub API of the Resource API .
2023-08-23 10:39:49 -04:00
2023-09-11 04:57:32 -04:00
You can execute an e2e test by running : ` bazel run //internal/api/attestationconfigapi:configapi_e2e_test ` .
2023-09-25 05:53:02 -04:00
The CLI is used in the CI pipeline . Manual actions that change the bucket ' s data shouldn ' t be necessary .
The reporter CLI caches the observed version values in a dedicated caching directory and derives the latest API version from it .
Any version update is then pushed to the API .
2023-08-23 10:39:49 -04:00
* /
2023-08-10 03:45:46 -04:00
package main
2023-06-01 07:55:46 -04:00
import (
"os"
2023-08-23 10:39:49 -04:00
"github.com/edgelesssys/constellation/v2/internal/constants"
2023-06-01 07:55:46 -04:00
"github.com/spf13/cobra"
)
const (
2023-06-02 06:10:22 -04:00
awsRegion = "eu-central-1"
awsBucket = "cdn-constellation-backend"
2023-08-23 10:39:49 -04:00
distributionID = constants . CDNDefaultDistributionID
2023-06-02 06:10:22 -04:00
envCosignPwd = "COSIGN_PASSWORD"
envCosignPrivateKey = "COSIGN_PRIVATE_KEY"
2024-07-10 06:59:02 -04:00
// versionWindowSize defines the number of versions to be considered for the latest version.
// Through our weekly e2e tests, each week 2 versions are uploaded:
// One from a stable release, and one from a debug image.
// A window size of 6 ensures we update only after a version has been "stable" for 3 weeks.
versionWindowSize = 6
2023-06-01 07:55:46 -04:00
)
var (
// Cosign credentials.
2023-06-02 06:10:22 -04:00
cosignPwd string
privateKey string
2023-06-01 07:55:46 -04:00
)
2023-08-10 03:45:46 -04:00
func main ( ) {
if err := newRootCmd ( ) . Execute ( ) ; err != nil {
os . Exit ( 1 )
}
os . Exit ( 0 )
2023-06-01 07:55:46 -04:00
}
// newRootCmd creates the root command.
func newRootCmd ( ) * cobra . Command {
2023-11-14 07:24:25 -05:00
rootCmd := & cobra . Command {
Short : "CLI to interact with the attestationconfig API" ,
Long : "CLI to interact with the attestationconfig API. Allows uploading new TCB versions, deleting specific versions and deleting all versions. Uploaded objects are signed with cosign." ,
}
2023-11-09 03:59:19 -05:00
rootCmd . PersistentFlags ( ) . StringP ( "region" , "r" , awsRegion , "region of the targeted bucket." )
rootCmd . PersistentFlags ( ) . StringP ( "bucket" , "b" , awsBucket , "bucket targeted by all operations." )
rootCmd . PersistentFlags ( ) . Bool ( "testing" , false , "upload to S3 test bucket." )
rootCmd . AddCommand ( newUploadCmd ( ) )
rootCmd . AddCommand ( newDeleteCmd ( ) )
2024-07-10 06:59:02 -04:00
rootCmd . AddCommand ( newCompareCmd ( ) )
2023-11-09 03:59:19 -05:00
return rootCmd
}
2023-10-17 11:36:50 -04:00
type apiConfig struct {
url string
distribution string
cosignPublicKey string
2023-08-09 12:58:46 -04:00
}
2023-10-17 11:36:50 -04:00
func getAPIEnvironment ( testing bool ) apiConfig {
if testing {
return apiConfig { url : "https://d33dzgxuwsgbpw.cloudfront.net" , distribution : "ETZGUP1CWRC2P" , cosignPublicKey : constants . CosignPublicKeyDev }
2023-06-09 06:48:12 -04:00
}
2023-10-17 11:36:50 -04:00
return apiConfig { url : constants . CDNRepositoryURL , distribution : constants . CDNDefaultDistributionID , cosignPublicKey : constants . CosignPublicKeyReleases }
2023-06-09 06:48:12 -04:00
}