2014-06-20 01:03:48 +00:00
|
|
|
/*
|
|
|
|
Copyright 2014 Google Inc. All rights reserved.
|
|
|
|
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
you may not use this file except in compliance with the License.
|
|
|
|
You may obtain a copy of the License at
|
|
|
|
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
See the License for the specific language governing permissions and
|
|
|
|
limitations under the License.
|
|
|
|
*/
|
|
|
|
|
2014-08-11 07:34:59 +00:00
|
|
|
package minion
|
2014-06-20 01:03:48 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2014-10-17 21:21:53 +00:00
|
|
|
"net"
|
2015-03-23 18:42:39 +00:00
|
|
|
"net/http"
|
|
|
|
"net/url"
|
2014-10-17 21:21:53 +00:00
|
|
|
"strconv"
|
2014-06-20 01:03:48 +00:00
|
|
|
|
2014-06-20 21:01:16 +00:00
|
|
|
"github.com/GoogleCloudPlatform/kubernetes/pkg/api"
|
2014-11-12 17:38:15 +00:00
|
|
|
"github.com/GoogleCloudPlatform/kubernetes/pkg/api/validation"
|
2015-03-23 18:42:39 +00:00
|
|
|
"github.com/GoogleCloudPlatform/kubernetes/pkg/client"
|
2015-03-06 23:29:03 +00:00
|
|
|
"github.com/GoogleCloudPlatform/kubernetes/pkg/fields"
|
2014-06-20 01:03:48 +00:00
|
|
|
"github.com/GoogleCloudPlatform/kubernetes/pkg/labels"
|
2015-03-13 14:49:38 +00:00
|
|
|
"github.com/GoogleCloudPlatform/kubernetes/pkg/registry/generic"
|
2014-09-06 02:22:03 +00:00
|
|
|
"github.com/GoogleCloudPlatform/kubernetes/pkg/runtime"
|
2015-03-13 14:49:38 +00:00
|
|
|
"github.com/GoogleCloudPlatform/kubernetes/pkg/util/fielderrors"
|
2014-06-20 01:03:48 +00:00
|
|
|
)
|
|
|
|
|
2015-03-13 14:49:38 +00:00
|
|
|
// nodeStrategy implements behavior for nodes
|
|
|
|
type nodeStrategy struct {
|
|
|
|
runtime.ObjectTyper
|
|
|
|
api.NameGenerator
|
2014-06-20 01:03:48 +00:00
|
|
|
}
|
|
|
|
|
2015-03-13 14:49:38 +00:00
|
|
|
// Nodes is the default logic that applies when creating and updating Node
|
|
|
|
// objects.
|
|
|
|
var Strategy = nodeStrategy{api.Scheme, api.SimpleNameGenerator}
|
2014-08-12 19:14:00 +00:00
|
|
|
|
2015-03-13 14:49:38 +00:00
|
|
|
// NamespaceScoped is false for nodes.
|
|
|
|
func (nodeStrategy) NamespaceScoped() bool {
|
|
|
|
return false
|
2014-06-20 01:03:48 +00:00
|
|
|
}
|
2014-08-11 07:34:59 +00:00
|
|
|
|
2015-03-13 14:49:38 +00:00
|
|
|
// AllowCreateOnUpdate is false for nodes.
|
|
|
|
func (nodeStrategy) AllowCreateOnUpdate() bool {
|
|
|
|
return false
|
2014-08-11 07:34:59 +00:00
|
|
|
}
|
|
|
|
|
2015-03-25 21:45:07 +00:00
|
|
|
// PrepareForCreate clears fields that are not allowed to be set by end users on creation.
|
|
|
|
func (nodeStrategy) PrepareForCreate(obj runtime.Object) {
|
2015-03-13 14:49:38 +00:00
|
|
|
_ = obj.(*api.Node)
|
|
|
|
// Nodes allow *all* fields, including status, to be set.
|
2014-08-11 07:34:59 +00:00
|
|
|
}
|
|
|
|
|
2015-03-26 00:03:30 +00:00
|
|
|
// PrepareForUpdate clears fields that are not allowed to be set by end users on update.
|
|
|
|
func (nodeStrategy) PrepareForUpdate(obj, old runtime.Object) {
|
|
|
|
_ = obj.(*api.Node)
|
|
|
|
_ = old.(*api.Node)
|
|
|
|
// Nodes allow *all* fields, including status, to be set.
|
|
|
|
}
|
|
|
|
|
2015-03-13 14:49:38 +00:00
|
|
|
// Validate validates a new node.
|
|
|
|
func (nodeStrategy) Validate(obj runtime.Object) fielderrors.ValidationErrorList {
|
|
|
|
node := obj.(*api.Node)
|
|
|
|
return validation.ValidateMinion(node)
|
2014-08-11 07:34:59 +00:00
|
|
|
}
|
|
|
|
|
2015-03-13 14:49:38 +00:00
|
|
|
// ValidateUpdate is the default update validation for an end user.
|
|
|
|
func (nodeStrategy) ValidateUpdate(obj, old runtime.Object) fielderrors.ValidationErrorList {
|
|
|
|
return validation.ValidateMinionUpdate(old.(*api.Node), obj.(*api.Node))
|
2015-01-12 05:33:25 +00:00
|
|
|
}
|
|
|
|
|
2015-03-13 14:49:38 +00:00
|
|
|
// ResourceGetter is an interface for retrieving resources by ResourceLocation.
|
|
|
|
type ResourceGetter interface {
|
|
|
|
Get(api.Context, string) (runtime.Object, error)
|
2014-08-11 07:34:59 +00:00
|
|
|
}
|
|
|
|
|
2015-03-13 14:49:38 +00:00
|
|
|
// MatchNode returns a generic matcher for a given label and field selector.
|
|
|
|
func MatchNode(label labels.Selector, field fields.Selector) generic.Matcher {
|
|
|
|
return generic.MatcherFunc(func(obj runtime.Object) (bool, error) {
|
|
|
|
nodeObj, ok := obj.(*api.Node)
|
|
|
|
if !ok {
|
|
|
|
return false, fmt.Errorf("not a node")
|
|
|
|
}
|
|
|
|
// TODO: Add support for filtering based on field, once NodeStatus is defined.
|
|
|
|
return label.Matches(labels.Set(nodeObj.Labels)), nil
|
|
|
|
})
|
2014-08-11 07:34:59 +00:00
|
|
|
}
|
2014-10-17 21:21:53 +00:00
|
|
|
|
2015-03-13 14:49:38 +00:00
|
|
|
// ResourceLocation returns a URL to which one can send traffic for the specified node.
|
|
|
|
func ResourceLocation(getter ResourceGetter, connection client.ConnectionInfoGetter, ctx api.Context, id string) (*url.URL, http.RoundTripper, error) {
|
|
|
|
nodeObj, err := getter.Get(ctx, id)
|
2014-10-17 21:21:53 +00:00
|
|
|
if err != nil {
|
2015-03-23 18:42:39 +00:00
|
|
|
return nil, nil, err
|
2014-10-17 21:21:53 +00:00
|
|
|
}
|
2015-03-13 14:49:38 +00:00
|
|
|
node := nodeObj.(*api.Node)
|
|
|
|
host := node.Name
|
2015-03-23 18:42:39 +00:00
|
|
|
|
2015-03-13 14:49:38 +00:00
|
|
|
scheme, port, transport, err := connection.GetConnectionInfo(host)
|
2015-03-23 18:42:39 +00:00
|
|
|
if err != nil {
|
|
|
|
return nil, nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return &url.URL{
|
|
|
|
Scheme: scheme,
|
|
|
|
Host: net.JoinHostPort(
|
|
|
|
host,
|
|
|
|
strconv.FormatUint(uint64(port), 10),
|
|
|
|
),
|
|
|
|
},
|
|
|
|
transport,
|
|
|
|
nil
|
2014-10-17 21:21:53 +00:00
|
|
|
}
|