2017-02-07 22:33:23 +01:00
|
|
|
/*
|
2017-12-19 16:00:09 +01:00
|
|
|
Copyright 2016 The go-marathon Authors All rights reserved.
|
2017-02-07 22:33:23 +01:00
|
|
|
|
|
|
|
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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
package marathon
|
|
|
|
|
|
|
|
// PortDefinition is a definition of a port that should be considered
|
|
|
|
// part of a resource. Port definitions are necessary when you are
|
|
|
|
// using HOST networking and no port mappings are specified.
|
|
|
|
type PortDefinition struct {
|
|
|
|
Port *int `json:"port,omitempty"`
|
|
|
|
Protocol string `json:"protocol,omitempty"`
|
|
|
|
Name string `json:"name,omitempty"`
|
|
|
|
Labels *map[string]string `json:"labels,omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// SetPort sets the given port for the PortDefinition
|
2017-12-19 16:00:09 +01:00
|
|
|
func (p *PortDefinition) SetPort(port int) *PortDefinition {
|
|
|
|
if p.Port == nil {
|
|
|
|
p.EmptyPort()
|
|
|
|
}
|
|
|
|
p.Port = &port
|
|
|
|
return p
|
|
|
|
}
|
|
|
|
|
|
|
|
// EmptyPort sets the port to 0 for the PortDefinition
|
|
|
|
func (p *PortDefinition) EmptyPort() *PortDefinition {
|
|
|
|
port := 0
|
2017-02-07 22:33:23 +01:00
|
|
|
p.Port = &port
|
|
|
|
return p
|
|
|
|
}
|
|
|
|
|
2017-12-19 16:00:09 +01:00
|
|
|
// SetProtocol sets the protocol for the PortDefinition
|
|
|
|
// protocol: the protocol as a string
|
|
|
|
func (p *PortDefinition) SetProtocol(protocol string) *PortDefinition {
|
|
|
|
p.Protocol = protocol
|
|
|
|
return p
|
|
|
|
}
|
|
|
|
|
|
|
|
// SetName sets the name for the PortDefinition
|
|
|
|
// name: the name of the PortDefinition
|
|
|
|
func (p *PortDefinition) SetName(name string) *PortDefinition {
|
|
|
|
p.Name = name
|
|
|
|
return p
|
|
|
|
}
|
|
|
|
|
2017-02-07 22:33:23 +01:00
|
|
|
// AddLabel adds a label to the PortDefinition
|
|
|
|
// name: the name of the label
|
|
|
|
// value: value for this label
|
2017-12-19 16:00:09 +01:00
|
|
|
func (p *PortDefinition) AddLabel(name, value string) *PortDefinition {
|
2017-02-07 22:33:23 +01:00
|
|
|
if p.Labels == nil {
|
|
|
|
p.EmptyLabels()
|
|
|
|
}
|
|
|
|
(*p.Labels)[name] = value
|
|
|
|
|
|
|
|
return p
|
|
|
|
}
|
|
|
|
|
|
|
|
// EmptyLabels explicitly empties the labels -- use this if you need to empty
|
|
|
|
// the labels of a PortDefinition that already has labels set
|
|
|
|
// (setting labels to nill will keep the current value)
|
|
|
|
func (p *PortDefinition) EmptyLabels() *PortDefinition {
|
|
|
|
p.Labels = &map[string]string{}
|
|
|
|
|
|
|
|
return p
|
|
|
|
}
|