github.com/operator-framework/operator-lifecycle-manager@v0.30.0/pkg/lib/operatorclient/secret.go (about) 1 package operatorclient 2 3 import ( 4 "context" 5 "fmt" 6 7 v1 "k8s.io/api/core/v1" 8 apierrors "k8s.io/apimachinery/pkg/api/errors" 9 metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" 10 "k8s.io/apimachinery/pkg/types" 11 "k8s.io/klog" 12 ) 13 14 // CreateSecret creates the Secret or Updates if it already exists. 15 func (c *Client) CreateSecret(ig *v1.Secret) (*v1.Secret, error) { 16 createdSecret, err := c.CoreV1().Secrets(ig.GetNamespace()).Create(context.TODO(), ig, metav1.CreateOptions{}) 17 if apierrors.IsAlreadyExists(err) { 18 return c.UpdateSecret(ig) 19 } 20 return createdSecret, err 21 } 22 23 // GetSecret returns the existing Secret. 24 func (c *Client) GetSecret(namespace, name string) (*v1.Secret, error) { 25 return c.CoreV1().Secrets(namespace).Get(context.TODO(), name, metav1.GetOptions{}) 26 } 27 28 // DeleteSecret deletes the Secret. 29 func (c *Client) DeleteSecret(namespace, name string, options *metav1.DeleteOptions) error { 30 return c.CoreV1().Secrets(namespace).Delete(context.TODO(), name, *options) 31 } 32 33 // UpdateSecret will update the given Secret resource. 34 func (c *Client) UpdateSecret(secret *v1.Secret) (*v1.Secret, error) { 35 klog.V(4).Infof("[UPDATE Secret]: %s", secret.GetName()) 36 oldSa, err := c.GetSecret(secret.GetNamespace(), secret.GetName()) 37 if err != nil { 38 return nil, err 39 } 40 patchBytes, err := createPatch(oldSa, secret) 41 if err != nil { 42 return nil, fmt.Errorf("error creating patch for Secret: %v", err) 43 } 44 return c.CoreV1().Secrets(secret.GetNamespace()).Patch(context.TODO(), secret.GetName(), types.StrategicMergePatchType, patchBytes, metav1.PatchOptions{}) 45 }