2017-12-14 21:56:19 +00:00
|
|
|
package k8s
|
|
|
|
|
|
|
|
import (
|
2020-03-26 21:32:45 +00:00
|
|
|
"context"
|
|
|
|
|
|
|
|
v1 "k8s.io/api/core/v1"
|
2017-12-14 21:56:19 +00:00
|
|
|
apierrors "k8s.io/apimachinery/pkg/api/errors"
|
|
|
|
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
|
|
|
"k8s.io/client-go/kubernetes"
|
|
|
|
)
|
|
|
|
|
|
|
|
func UpdateServiceAccountFromYaml(k8sClient *kubernetes.Clientset, serviceAccountYaml string) error {
|
|
|
|
serviceAccount := v1.ServiceAccount{}
|
|
|
|
|
2019-10-03 01:56:39 +00:00
|
|
|
if err := DecodeYamlResource(&serviceAccount, serviceAccountYaml); err != nil {
|
2017-12-14 21:56:19 +00:00
|
|
|
return err
|
|
|
|
}
|
2017-12-20 23:11:50 +00:00
|
|
|
return retryTo(updateServiceAccount, k8sClient, serviceAccount, DefaultRetries, DefaultSleepSeconds)
|
|
|
|
}
|
|
|
|
|
|
|
|
func updateServiceAccount(k8sClient *kubernetes.Clientset, s interface{}) error {
|
|
|
|
serviceAccount := s.(v1.ServiceAccount)
|
2020-03-26 21:32:45 +00:00
|
|
|
if _, err := k8sClient.CoreV1().ServiceAccounts(metav1.NamespaceSystem).Create(context.TODO(), &serviceAccount, metav1.CreateOptions{}); err != nil {
|
2017-12-20 23:11:50 +00:00
|
|
|
if !apierrors.IsAlreadyExists(err) {
|
|
|
|
return err
|
|
|
|
}
|
2020-03-26 21:32:45 +00:00
|
|
|
if _, err := k8sClient.CoreV1().ServiceAccounts(metav1.NamespaceSystem).Update(context.TODO(), &serviceAccount, metav1.UpdateOptions{}); err != nil {
|
2017-12-20 23:11:50 +00:00
|
|
|
return err
|
2017-12-14 21:56:19 +00:00
|
|
|
}
|
|
|
|
}
|
2017-12-20 23:11:50 +00:00
|
|
|
return nil
|
2017-12-14 21:56:19 +00:00
|
|
|
}
|