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  }