Documentation
¶
Overview ¶
Package kubeclient provides a client to interact with Kubernetes. This package is Tailscale-internal and not meant for external consumption. Further, the API should not be considered stable. Client is split into a separate package for consumption of non-Kubernetes shared libraries and binaries. Be mindful of not increasing dependency size for those consumers when adding anything new here.
Index ¶
- Constants
- func IsNotFoundErr(err error) bool
- func SetRootPathForTesting(p string)
- type Client
- type FakeClient
- func (fc *FakeClient) CheckSecretPermissions(ctx context.Context, name string) (bool, bool, error)
- func (fc *FakeClient) CreateSecret(ctx context.Context, secret *kubeapi.Secret) error
- func (fc *FakeClient) Event(context.Context, string, string, string) error
- func (fc *FakeClient) GetSecret(ctx context.Context, name string) (*kubeapi.Secret, error)
- func (fc *FakeClient) JSONPatchResource(ctx context.Context, resource, name string, patches []JSONPatch) error
- func (fc *FakeClient) ListSecrets(ctx context.Context, selector map[string]string) (*kubeapi.SecretList, error)
- func (fc *FakeClient) SetDialer(dialer func(ctx context.Context, network, addr string) (net.Conn, error))
- func (fc *FakeClient) SetURL(_ string)
- func (fc *FakeClient) StrategicMergePatchSecret(ctx context.Context, name string, s *kubeapi.Secret, fieldManager string) error
- func (fc *FakeClient) UpdateSecret(ctx context.Context, secret *kubeapi.Secret) error
- type JSONPatch
Constants ¶
View Source
const (
TypeSecrets = "secrets"
)
Variables ¶
This section is empty.
Functions ¶
func IsNotFoundErr ¶
func SetRootPathForTesting ¶
func SetRootPathForTesting(p string)
SetRootPathForTesting sets the path to the service account directory.
Types ¶
type Client ¶
type Client interface {
GetSecret(context.Context, string) (*kubeapi.Secret, error)
ListSecrets(context.Context, map[string]string) (*kubeapi.SecretList, error)
UpdateSecret(context.Context, *kubeapi.Secret) error
CreateSecret(context.Context, *kubeapi.Secret) error
// Event attempts to ensure an event with the specified options associated with the Pod in which we are
// currently running. This is best effort - if the client is not able to create events, this operation will be a
// no-op. If there is already an Event with the given reason for the current Pod, it will get updated (only
// count and timestamp are expected to change), else a new event will be created.
Event(_ context.Context, typ, reason, msg string) error
StrategicMergePatchSecret(context.Context, string, *kubeapi.Secret, string) error
JSONPatchResource(_ context.Context, resourceName string, resourceType string, patches []JSONPatch) error
CheckSecretPermissions(context.Context, string) (bool, bool, error)
SetDialer(dialer func(context.Context, string, string) (net.Conn, error))
SetURL(string)
}
Client handles connections to Kubernetes. It expects to be run inside a cluster.
type FakeClient ¶
type FakeClient struct {
GetSecretImpl func(context.Context, string) (*kubeapi.Secret, error)
CheckSecretPermissionsImpl func(ctx context.Context, name string) (bool, bool, error)
CreateSecretImpl func(context.Context, *kubeapi.Secret) error
UpdateSecretImpl func(context.Context, *kubeapi.Secret) error
JSONPatchResourceImpl func(context.Context, string, string, []JSONPatch) error
ListSecretsImpl func(context.Context, map[string]string) (*kubeapi.SecretList, error)
StrategicMergePatchSecretImpl func(context.Context, string, *kubeapi.Secret, string) error
}
func (*FakeClient) CheckSecretPermissions ¶
func (*FakeClient) CreateSecret ¶
func (*FakeClient) JSONPatchResource ¶ added in v1.78.0
func (*FakeClient) ListSecrets ¶ added in v1.82.0
func (fc *FakeClient) ListSecrets(ctx context.Context, selector map[string]string) (*kubeapi.SecretList, error)
func (*FakeClient) SetURL ¶
func (fc *FakeClient) SetURL(_ string)
func (*FakeClient) StrategicMergePatchSecret ¶
func (*FakeClient) UpdateSecret ¶
Click to show internal directories.
Click to hide internal directories.