mirror of
https://github.com/drone/drone-kaniko.git
synced 2026-06-16 14:49:02 +08:00
Compare commits
2 Commits
main-patch
...
CI-14242-2
| Author | SHA1 | Date | |
|---|---|---|---|
| 153882eafc | |||
| 048567b3d4 |
+63
-2
@@ -7,6 +7,7 @@ import (
|
|||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"os"
|
"os"
|
||||||
"strings"
|
"strings"
|
||||||
|
"time"
|
||||||
|
|
||||||
"github.com/aws/aws-sdk-go-v2/aws"
|
"github.com/aws/aws-sdk-go-v2/aws"
|
||||||
"github.com/aws/aws-sdk-go-v2/config"
|
"github.com/aws/aws-sdk-go-v2/config"
|
||||||
@@ -17,6 +18,7 @@ import (
|
|||||||
"github.com/aws/aws-sdk-go/aws/session"
|
"github.com/aws/aws-sdk-go/aws/session"
|
||||||
ecrv1 "github.com/aws/aws-sdk-go/service/ecr"
|
ecrv1 "github.com/aws/aws-sdk-go/service/ecr"
|
||||||
ecrpublicv1 "github.com/aws/aws-sdk-go/service/ecrpublic"
|
ecrpublicv1 "github.com/aws/aws-sdk-go/service/ecrpublic"
|
||||||
|
"github.com/aws/aws-sdk-go/service/sts"
|
||||||
"github.com/aws/smithy-go"
|
"github.com/aws/smithy-go"
|
||||||
"github.com/hashicorp/go-version"
|
"github.com/hashicorp/go-version"
|
||||||
"github.com/joho/godotenv"
|
"github.com/joho/godotenv"
|
||||||
@@ -35,6 +37,7 @@ const (
|
|||||||
secretKeyEnv string = "AWS_SECRET_ACCESS_KEY"
|
secretKeyEnv string = "AWS_SECRET_ACCESS_KEY"
|
||||||
ecrPublicDomain string = "public.ecr.aws"
|
ecrPublicDomain string = "public.ecr.aws"
|
||||||
kanikoVersionEnv string = "KANIKO_VERSION"
|
kanikoVersionEnv string = "KANIKO_VERSION"
|
||||||
|
sessionKeyEnv string = "AWS_SESSION_TOKEN"
|
||||||
|
|
||||||
oneDotEightVersion string = "1.8.0"
|
oneDotEightVersion string = "1.8.0"
|
||||||
defaultDigestFile string = "/kaniko/digest-file"
|
defaultDigestFile string = "/kaniko/digest-file"
|
||||||
@@ -384,6 +387,11 @@ func main() {
|
|||||||
Usage: "Number of retries for downloading base images.",
|
Usage: "Number of retries for downloading base images.",
|
||||||
EnvVar: "PLUGIN_IMAGE_DOWNLOAD_RETRY",
|
EnvVar: "PLUGIN_IMAGE_DOWNLOAD_RETRY",
|
||||||
},
|
},
|
||||||
|
cli.StringFlag{
|
||||||
|
Name: "oidc-token-id",
|
||||||
|
Usage: "OIDC token for assuming role via web identity",
|
||||||
|
EnvVar: "PLUGIN_OIDC_TOKEN_ID",
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
if err := app.Run(os.Args); err != nil {
|
if err := app.Run(os.Args); err != nil {
|
||||||
@@ -398,6 +406,7 @@ func run(c *cli.Context) error {
|
|||||||
noPush := c.Bool("no-push")
|
noPush := c.Bool("no-push")
|
||||||
assumeRole := c.String("assume-role")
|
assumeRole := c.String("assume-role")
|
||||||
externalId := c.String("external-id")
|
externalId := c.String("external-id")
|
||||||
|
oidcToken := c.String("oidc-token-id")
|
||||||
|
|
||||||
// setup docker config for azure registry and base image docker registry
|
// setup docker config for azure registry and base image docker registry
|
||||||
err := setDockerAuth(
|
err := setDockerAuth(
|
||||||
@@ -411,6 +420,7 @@ func run(c *cli.Context) error {
|
|||||||
externalId,
|
externalId,
|
||||||
region,
|
region,
|
||||||
noPush,
|
noPush,
|
||||||
|
oidcToken,
|
||||||
)
|
)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return errors.Wrap(err, "failed to create docker config")
|
return errors.Wrap(err, "failed to create docker config")
|
||||||
@@ -518,7 +528,7 @@ func run(c *cli.Context) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func setDockerAuth(dockerRegistry, dockerUsername, dockerPassword, accessKey, secretKey,
|
func setDockerAuth(dockerRegistry, dockerUsername, dockerPassword, accessKey, secretKey,
|
||||||
registry, assumeRole, externalId, region string, noPush bool) error {
|
registry, assumeRole, externalId, region string, noPush bool, oidcToken string) error {
|
||||||
dockerConfig := docker.NewConfig()
|
dockerConfig := docker.NewConfig()
|
||||||
credentials := []docker.RegistryCredentials{}
|
credentials := []docker.RegistryCredentials{}
|
||||||
// set docker credentials for base image registry
|
// set docker credentials for base image registry
|
||||||
@@ -531,7 +541,24 @@ func setDockerAuth(dockerRegistry, dockerUsername, dockerPassword, accessKey, se
|
|||||||
credentials = append(credentials, pullFromRegistryCreds)
|
credentials = append(credentials, pullFromRegistryCreds)
|
||||||
}
|
}
|
||||||
|
|
||||||
if assumeRole != "" {
|
if assumeRole != "" && oidcToken != "" {
|
||||||
|
oidcAccessKey, oidcSecretKey, oidcSessionKey, err := getOidcCreds(oidcToken, assumeRole)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
_ = os.Setenv(accessKeyEnv, oidcAccessKey)
|
||||||
|
_ = os.Setenv(secretKeyEnv, oidcSecretKey)
|
||||||
|
_ = os.Setenv(sessionKeyEnv, oidcSessionKey)
|
||||||
|
|
||||||
|
// kaniko-executor >=1.8.0 does not require additional cred helper logic for ECR,
|
||||||
|
// as it discovers ECR repositories automatically and acts accordingly.
|
||||||
|
if isKanikoVersionBelowOneDotEight(os.Getenv(kanikoVersionEnv)) {
|
||||||
|
dockerConfig.SetCredHelper(ecrPublicDomain, "ecr-login")
|
||||||
|
dockerConfig.SetCredHelper(registry, "ecr-login")
|
||||||
|
}
|
||||||
|
|
||||||
|
} else if assumeRole != "" {
|
||||||
var err error
|
var err error
|
||||||
username, password, registry, err := getAssumeRoleCreds(region, assumeRole, externalId, "")
|
username, password, registry, err := getAssumeRoleCreds(region, assumeRole, externalId, "")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@@ -771,3 +798,37 @@ func isKanikoVersionBelowOneDotEight(v string) bool {
|
|||||||
|
|
||||||
return currVer.LessThan(oneEightVer)
|
return currVer.LessThan(oneEightVer)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func getOidcCreds(oidcToken, assumeRole string) (string, string, string, error) {
|
||||||
|
// Create a new session
|
||||||
|
sess, err := session.NewSession()
|
||||||
|
if err != nil {
|
||||||
|
return "", "", "", fmt.Errorf("failed to create AWS session: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Create a new STS client
|
||||||
|
svc := sts.New(sess)
|
||||||
|
|
||||||
|
// Prepare the input parameters for the STS call
|
||||||
|
duration := int64(time.Hour / time.Second)
|
||||||
|
input := &sts.AssumeRoleWithWebIdentityInput{
|
||||||
|
RoleArn: aws.String(assumeRole),
|
||||||
|
RoleSessionName: aws.String("kaniko-ecr-oidc"),
|
||||||
|
WebIdentityToken: aws.String(oidcToken),
|
||||||
|
DurationSeconds: aws.Int64(duration),
|
||||||
|
}
|
||||||
|
|
||||||
|
// Call the AssumeRoleWithWebIdentity function
|
||||||
|
result, err := svc.AssumeRoleWithWebIdentity(input)
|
||||||
|
if err != nil {
|
||||||
|
return "", "", "", fmt.Errorf("failed to assume role with web identity: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check if credentials exist in the result
|
||||||
|
if result.Credentials == nil {
|
||||||
|
return "", "", "", errors.New("no credentials returned by AssumeRoleWithWebIdentity")
|
||||||
|
}
|
||||||
|
|
||||||
|
// Return the credentials
|
||||||
|
return *result.Credentials.AccessKeyId, *result.Credentials.SecretAccessKey, *result.Credentials.SessionToken, nil
|
||||||
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user