Skip to content

Commit

Permalink
UPSTREAM: <carry>: kube-controller-manager: add service serving cert …
Browse files Browse the repository at this point in the history
…signer to token controller

:100644 100644 b32534e... 3e694fc... M	pkg/controller/serviceaccount/tokens_controller.go
  • Loading branch information
deads2k authored and soltysh committed Sep 7, 2021
1 parent 99c4023 commit 1c7dca0
Showing 1 changed file with 23 additions and 9 deletions.
32 changes: 23 additions & 9 deletions pkg/controller/serviceaccount/tokens_controller.go
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,8 @@ import (
"k8s.io/kubernetes/pkg/serviceaccount"
)

const ServiceServingCASecretKey = "service-ca.crt"

// RemoveTokenBackoff is the recommended (empirical) retry interval for removing
// a secret reference from a service account when the secret is deleted. It is
// exported for use by custom secret controllers.
Expand All @@ -68,6 +70,9 @@ type TokensControllerOptions struct {
// MaxRetries controls the maximum number of times a particular key is retried before giving up
// If zero, a default max is used
MaxRetries int

// This CA will be added in the secrets of service accounts
ServiceServingCA []byte
}

// NewTokensController returns a new *TokensController.
Expand All @@ -78,9 +83,10 @@ func NewTokensController(serviceAccounts informers.ServiceAccountInformer, secre
}

e := &TokensController{
client: cl,
token: options.TokenGenerator,
rootCA: options.RootCA,
client: cl,
token: options.TokenGenerator,
rootCA: options.RootCA,
serviceServingCA: options.ServiceServingCA,

syncServiceAccountQueue: workqueue.NewNamedRateLimitingQueue(workqueue.DefaultControllerRateLimiter(), "serviceaccount_tokens_service"),
syncSecretQueue: workqueue.NewNamedRateLimitingQueue(workqueue.DefaultControllerRateLimiter(), "serviceaccount_tokens_secret"),
Expand Down Expand Up @@ -135,7 +141,8 @@ type TokensController struct {
client clientset.Interface
token serviceaccount.TokenGenerator

rootCA []byte
rootCA []byte
serviceServingCA []byte

serviceAccounts listersv1.ServiceAccountLister
// updatedSecrets is a wrapper around the shared cache which allows us to record
Expand Down Expand Up @@ -406,6 +413,9 @@ func (e *TokensController) ensureReferencedToken(serviceAccount *v1.ServiceAccou
if e.rootCA != nil && len(e.rootCA) > 0 {
secret.Data[v1.ServiceAccountRootCAKey] = e.rootCA
}
if e.serviceServingCA != nil && len(e.serviceServingCA) > 0 {
secret.Data[ServiceServingCASecretKey] = e.serviceServingCA
}

// Save the secret
createdToken, err := e.client.CoreV1().Secrets(serviceAccount.Namespace).Create(context.TODO(), secret, metav1.CreateOptions{})
Expand Down Expand Up @@ -499,22 +509,23 @@ func (e *TokensController) hasReferencedToken(serviceAccount *v1.ServiceAccount)
return false, nil
}

func (e *TokensController) secretUpdateNeeded(secret *v1.Secret) (bool, bool, bool) {
func (e *TokensController) secretUpdateNeeded(secret *v1.Secret) (bool, bool, bool, bool) {
caData := secret.Data[v1.ServiceAccountRootCAKey]
needsCA := len(e.rootCA) > 0 && !bytes.Equal(caData, e.rootCA)
needsServiceServingCA := len(e.serviceServingCA) > 0 && bytes.Compare(secret.Data[ServiceServingCASecretKey], e.serviceServingCA) != 0

needsNamespace := len(secret.Data[v1.ServiceAccountNamespaceKey]) == 0

tokenData := secret.Data[v1.ServiceAccountTokenKey]
needsToken := len(tokenData) == 0

return needsCA, needsNamespace, needsToken
return needsCA, needsServiceServingCA, needsNamespace, needsToken
}

// generateTokenIfNeeded populates the token data for the given Secret if not already set
func (e *TokensController) generateTokenIfNeeded(serviceAccount *v1.ServiceAccount, cachedSecret *v1.Secret) ( /* retry */ bool, error) {
// Check the cached secret to see if changes are needed
if needsCA, needsNamespace, needsToken := e.secretUpdateNeeded(cachedSecret); !needsCA && !needsToken && !needsNamespace {
if needsCA, needsServiceServingCA, needsNamespace, needsToken := e.secretUpdateNeeded(cachedSecret); !needsCA && !needsServiceServingCA && !needsToken && !needsNamespace {
return false, nil
}

Expand All @@ -533,8 +544,8 @@ func (e *TokensController) generateTokenIfNeeded(serviceAccount *v1.ServiceAccou
return false, nil
}

needsCA, needsNamespace, needsToken := e.secretUpdateNeeded(liveSecret)
if !needsCA && !needsToken && !needsNamespace {
needsCA, needsServiceServingCA, needsNamespace, needsToken := e.secretUpdateNeeded(liveSecret)
if !needsCA && !needsServiceServingCA && !needsToken && !needsNamespace {
return false, nil
}

Expand All @@ -549,6 +560,9 @@ func (e *TokensController) generateTokenIfNeeded(serviceAccount *v1.ServiceAccou
if needsCA {
liveSecret.Data[v1.ServiceAccountRootCAKey] = e.rootCA
}
if needsServiceServingCA {
liveSecret.Data[ServiceServingCASecretKey] = e.serviceServingCA
}
// Set the namespace
if needsNamespace {
liveSecret.Data[v1.ServiceAccountNamespaceKey] = []byte(liveSecret.Namespace)
Expand Down

0 comments on commit 1c7dca0

Please sign in to comment.