Skip to content

Commit

Permalink
add support for additional irsa domains
Browse files Browse the repository at this point in the history
  • Loading branch information
Berk Dehrioglu committed Dec 18, 2023
1 parent fb4937f commit bc5dcf7
Show file tree
Hide file tree
Showing 5 changed files with 37 additions and 7 deletions.
2 changes: 1 addition & 1 deletion controllers/awsmachinetemplate_controller.go
Original file line number Diff line number Diff line change
Expand Up @@ -278,7 +278,7 @@ func (r *AWSMachineTemplateReconciler) reconcileNormal(ctx context.Context, iamS

cloudFrontDomain := key.CloudFrontAlias(baseDomain)

err = iamService.ReconcileRolesForIRSA(accountID, cloudFrontDomain)
err = iamService.ReconcileRolesForIRSA(accountID, cloudFrontDomain, "")
if err != nil {
return ctrl.Result{}, errors.WithStack(err)
}
Expand Down
2 changes: 1 addition & 1 deletion controllers/awsmanagedcontrolplane_controller.go
Original file line number Diff line number Diff line change
Expand Up @@ -157,7 +157,7 @@ func (r *AWSManagedControlPlaneReconciler) Reconcile(ctx context.Context, req ct
}

iamService.SetPrincipalRoleARN(eksRoleARN)
err = iamService.ReconcileRolesForIRSA(accountID, eksOpenIdDomain)
err = iamService.ReconcileRolesForIRSA(accountID, eksOpenIdDomain, "")
if err != nil {
return ctrl.Result{}, microerror.Mask(err)
}
Expand Down
11 changes: 8 additions & 3 deletions pkg/iam/iam.go
Original file line number Diff line number Diff line change
Expand Up @@ -64,6 +64,7 @@ type Route53RoleParams struct {
Namespace string
ServiceAccount string
PrincipalRoleARN string
IsMigrate bool
}

func New(config IAMServiceConfig) (*IAMService, error) {
Expand Down Expand Up @@ -156,12 +157,12 @@ func (s *IAMService) ReconcileKiamRole() error {
return nil
}

func (s *IAMService) ReconcileRolesForIRSA(awsAccountID string, cloudFrontDomain string) error {
func (s *IAMService) ReconcileRolesForIRSA(awsAccountID string, cloudFrontDomain string, oldCloudFrontDomain string) error {
s.log.Info("reconciling IAM roles for IRSA")

for _, roleTypeToReconcile := range getIRSARoles() {
var params Route53RoleParams
params, err := s.generateRoute53RoleParams(roleTypeToReconcile, awsAccountID, cloudFrontDomain)
params, err := s.generateRoute53RoleParams(roleTypeToReconcile, awsAccountID, cloudFrontDomain, oldCloudFrontDomain)
if err != nil {
s.log.Error(err, "failed to generate Route53 role parameters")
return err
Expand All @@ -177,7 +178,7 @@ func (s *IAMService) ReconcileRolesForIRSA(awsAccountID string, cloudFrontDomain
return nil
}

func (s *IAMService) generateRoute53RoleParams(roleTypeToReconcile string, awsAccountID string, cloudFrontDomain string) (Route53RoleParams, error) {
func (s *IAMService) generateRoute53RoleParams(roleTypeToReconcile string, awsAccountID string, cloudFrontDomain string, oldCloudFrontDomain string) (Route53RoleParams, error) {
namespace := "kube-system"
serviceAccount, err := getServiceAccount(roleTypeToReconcile)
if err != nil {
Expand All @@ -193,6 +194,10 @@ func (s *IAMService) generateRoute53RoleParams(roleTypeToReconcile string, awsAc
ServiceAccount: serviceAccount,
}

if oldCloudFrontDomain != "" {
params.CloudFrontDomain = oldCloudFrontDomain
}

return params, nil
}

Expand Down
16 changes: 14 additions & 2 deletions pkg/iam/route53_template.go
Original file line number Diff line number Diff line change
Expand Up @@ -14,10 +14,22 @@ const trustIdentityPolicyIRSA = `{
"{{.CloudFrontDomain}}:sub": "system:serviceaccount:{{.Namespace}}:{{.ServiceAccount}}"
}
}
}{{if .IsMigrate}},
{
"Effect": "Allow",
"Principal": {
"Federated": "arn:aws:iam::{{.AccountID}}:oidc-provider/{{.OldCloudFrontDomain}}"
},
"Action": "sts:AssumeRoleWithWebIdentity",
"Condition": {
"StringEquals": {
"{{.OldCloudFrontDomain}}:sub": "system:serviceaccount:{{.Namespace}}:{{.ServiceAccount}}"
}
}
}
{{end}}
]
}
`
}`

const route53RolePolicyTemplate = `{
"Version": "2012-10-17",
Expand Down
13 changes: 13 additions & 0 deletions pkg/key/key.go
Original file line number Diff line number Diff line change
Expand Up @@ -158,3 +158,16 @@ func GetAWSAccountID(awsClusterRoleIdentity *capa.AWSClusterRoleIdentity) (strin

return a.AccountID, nil
}

func GetAdditionalIrsaDomain(o v1.Object) string {
return GetAnnotation(o, "aws.giantswarm.io/irsa-additional-domain")
}

// GetAnnotation returns the value of the specified annotation.
func GetAnnotation(o v1.Object, annotation string) string {
annotations := o.GetAnnotations()
if annotations == nil {
return ""
}
return annotations[annotation]
}

0 comments on commit bc5dcf7

Please sign in to comment.