Client Authentication (v1)
ExecCredential is used by exec-based plugins to communicate credentials to HTTP transports.
Spec holds information passed to the plugin by the transport.
Status is filled in by the plugin and holds the credentials that the transport should use to contact the API.
Cluster contains information to allow an exec plugin to communicate with the kubernetes cluster being authenticated to.
To ensure that this struct contains everything someone would need to communicate with a kubernetes cluster (just like they would via a kubeconfig), the fields should shadow "k8s.io/client-go/tools/clientcmd/api/v1".Cluster, with the exception of CertificateAuthority, since CA data will always be passed to the plugin as bytes.
Server is the address of the kubernetes cluster (https://hostname:port).
TLSServerName is passed to the server for SNI and is used in the client to check server certificates against. If ServerName is empty, the hostname used to contact the server is used.
InsecureSkipTLSVerify skips the validity check for the server's certificate. This will make your HTTPS connections insecure.
CAData contains PEM-encoded certificate authority certificates. If empty, system roots should be used.
ProxyURL is the URL to the proxy to be used for all requests to this cluster.
Config holds additional config data that is specific to the exec plugin with regards to the cluster being authenticated to.
This data is sourced from the clientcmd Cluster object's extensions[client.authentication.k8s.io/exec] field:
In some environments, the user config may be exactly the same across many clusters (i.e. call this exec plugin) minus some details that are specific to each cluster such as the audience. This field allows the per cluster config to be directly specified with the cluster info. Using this field to store secret data is not recommended as one of the prime benefits of exec plugins is that no secrets need to be stored directly in the kubeconfig.
ExecCredentialSpec holds request and runtime specific information provided by the transport.
Cluster contains information to allow an exec plugin to communicate with the kubernetes cluster being authenticated to. Note that Cluster is non-nil only when provideClusterInfo is set to true in the exec provider config (i.e., ExecConfig.ProvideClusterInfo).
Interactive declares whether stdin has been passed to this exec plugin.
ExecCredentialStatus holds credentials for the transport to use.
Token and ClientKeyData are sensitive fields. This data should only be transmitted in-memory between client and exec plugin process. Exec plugin itself should at least be protected via file permissions.
ExpirationTimestamp indicates a time when the provided credentials expire.
Token is a bearer token used by the client for request authentication.
PEM-encoded client TLS certificates (including intermediates, if any).
PEM-encoded private key for the above certificate.