mirror of
https://github.com/k3s-io/kubernetes.git
synced 2025-08-04 09:49:50 +00:00
experimental.go
This commit is contained in:
parent
307fbeec3f
commit
10917084df
@ -28,9 +28,9 @@ import (
|
|||||||
|
|
||||||
// Interface holds the experimental methods for clients of Kubernetes
|
// Interface holds the experimental methods for clients of Kubernetes
|
||||||
// to allow mock testing.
|
// to allow mock testing.
|
||||||
// Experimental features are not supported and may be changed or removed in
|
// Features of Extensions group are not supported and may be changed or removed in
|
||||||
// incompatible ways at any time.
|
// incompatible ways at any time.
|
||||||
type ExperimentalInterface interface {
|
type ExtensionsInterface interface {
|
||||||
VersionInterface
|
VersionInterface
|
||||||
HorizontalPodAutoscalersNamespacer
|
HorizontalPodAutoscalersNamespacer
|
||||||
ScaleNamespacer
|
ScaleNamespacer
|
||||||
@ -40,15 +40,15 @@ type ExperimentalInterface interface {
|
|||||||
IngressNamespacer
|
IngressNamespacer
|
||||||
}
|
}
|
||||||
|
|
||||||
// ExperimentalClient is used to interact with experimental Kubernetes features.
|
// ExtensionsClient is used to interact with experimental Kubernetes features.
|
||||||
// Experimental features are not supported and may be changed or removed in
|
// Features of Extensions group are not supported and may be changed or removed in
|
||||||
// incompatible ways at any time.
|
// incompatible ways at any time.
|
||||||
type ExperimentalClient struct {
|
type ExtensionsClient struct {
|
||||||
*RESTClient
|
*RESTClient
|
||||||
}
|
}
|
||||||
|
|
||||||
// ServerVersion retrieves and parses the server's version.
|
// ServerVersion retrieves and parses the server's version.
|
||||||
func (c *ExperimentalClient) ServerVersion() (*version.Info, error) {
|
func (c *ExtensionsClient) ServerVersion() (*version.Info, error) {
|
||||||
body, err := c.Get().AbsPath("/version").Do().Raw()
|
body, err := c.Get().AbsPath("/version").Do().Raw()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
@ -63,7 +63,7 @@ func (c *ExperimentalClient) ServerVersion() (*version.Info, error) {
|
|||||||
|
|
||||||
// ServerAPIVersions retrieves and parses the list of experimental API versions the
|
// ServerAPIVersions retrieves and parses the list of experimental API versions the
|
||||||
// server supports.
|
// server supports.
|
||||||
func (c *ExperimentalClient) ServerAPIVersions() (*unversioned.APIVersions, error) {
|
func (c *ExtensionsClient) ServerAPIVersions() (*unversioned.APIVersions, error) {
|
||||||
body, err := c.Get().UnversionedPath("").Do().Raw()
|
body, err := c.Get().UnversionedPath("").Do().Raw()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
@ -76,59 +76,59 @@ func (c *ExperimentalClient) ServerAPIVersions() (*unversioned.APIVersions, erro
|
|||||||
return &v, nil
|
return &v, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *ExperimentalClient) HorizontalPodAutoscalers(namespace string) HorizontalPodAutoscalerInterface {
|
func (c *ExtensionsClient) HorizontalPodAutoscalers(namespace string) HorizontalPodAutoscalerInterface {
|
||||||
return newHorizontalPodAutoscalers(c, namespace)
|
return newHorizontalPodAutoscalers(c, namespace)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *ExperimentalClient) Scales(namespace string) ScaleInterface {
|
func (c *ExtensionsClient) Scales(namespace string) ScaleInterface {
|
||||||
return newScales(c, namespace)
|
return newScales(c, namespace)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *ExperimentalClient) DaemonSets(namespace string) DaemonSetInterface {
|
func (c *ExtensionsClient) DaemonSets(namespace string) DaemonSetInterface {
|
||||||
return newDaemonSets(c, namespace)
|
return newDaemonSets(c, namespace)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *ExperimentalClient) Deployments(namespace string) DeploymentInterface {
|
func (c *ExtensionsClient) Deployments(namespace string) DeploymentInterface {
|
||||||
return newDeployments(c, namespace)
|
return newDeployments(c, namespace)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *ExperimentalClient) Jobs(namespace string) JobInterface {
|
func (c *ExtensionsClient) Jobs(namespace string) JobInterface {
|
||||||
return newJobs(c, namespace)
|
return newJobs(c, namespace)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *ExperimentalClient) Ingress(namespace string) IngressInterface {
|
func (c *ExtensionsClient) Ingress(namespace string) IngressInterface {
|
||||||
return newIngress(c, namespace)
|
return newIngress(c, namespace)
|
||||||
}
|
}
|
||||||
|
|
||||||
// NewExperimental creates a new ExperimentalClient for the given config. This client
|
// NewExtensions creates a new ExtensionsClient for the given config. This client
|
||||||
// provides access to experimental Kubernetes features.
|
// provides access to experimental Kubernetes features.
|
||||||
// Experimental features are not supported and may be changed or removed in
|
// Features of Extensions group are not supported and may be changed or removed in
|
||||||
// incompatible ways at any time.
|
// incompatible ways at any time.
|
||||||
func NewExperimental(c *Config) (*ExperimentalClient, error) {
|
func NewExtensions(c *Config) (*ExtensionsClient, error) {
|
||||||
config := *c
|
config := *c
|
||||||
if err := setExperimentalDefaults(&config); err != nil {
|
if err := setExtensionsDefaults(&config); err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
client, err := RESTClientFor(&config)
|
client, err := RESTClientFor(&config)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
return &ExperimentalClient{client}, nil
|
return &ExtensionsClient{client}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// NewExperimentalOrDie creates a new ExperimentalClient for the given config and
|
// NewExtensionsOrDie creates a new ExtensionsClient for the given config and
|
||||||
// panics if there is an error in the config.
|
// panics if there is an error in the config.
|
||||||
// Experimental features are not supported and may be changed or removed in
|
// Features of Extensions group are not supported and may be changed or removed in
|
||||||
// incompatible ways at any time.
|
// incompatible ways at any time.
|
||||||
func NewExperimentalOrDie(c *Config) *ExperimentalClient {
|
func NewExtensionsOrDie(c *Config) *ExtensionsClient {
|
||||||
client, err := NewExperimental(c)
|
client, err := NewExtensions(c)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
return client
|
return client
|
||||||
}
|
}
|
||||||
|
|
||||||
func setExperimentalDefaults(config *Config) error {
|
func setExtensionsDefaults(config *Config) error {
|
||||||
// if experimental group is not registered, return an error
|
// if experimental group is not registered, return an error
|
||||||
g, err := latest.Group("extensions")
|
g, err := latest.Group("extensions")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -145,7 +145,7 @@ func setExperimentalDefaults(config *Config) error {
|
|||||||
|
|
||||||
versionInterfaces, err := g.InterfacesFor(config.Version)
|
versionInterfaces, err := g.InterfacesFor(config.Version)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf("Experimental API version '%s' is not recognized (valid values: %s)",
|
return fmt.Errorf("Extensions API version '%s' is not recognized (valid values: %s)",
|
||||||
config.Version, strings.Join(latest.GroupOrDie("extensions").Versions, ", "))
|
config.Version, strings.Join(latest.GroupOrDie("extensions").Versions, ", "))
|
||||||
}
|
}
|
||||||
config.Codec = versionInterfaces.Codec
|
config.Codec = versionInterfaces.Codec
|
Loading…
Reference in New Issue
Block a user