Documentation ¶
Index ¶
- Constants
- func StringID(id ID) string
- func WaitFor(desc string, d time.Duration, i time.Duration, fn func() (bool, error)) error
- type App
- type BytesValue
- type Component
- type ComponentAddresses
- type ContainerBlueprint
- type CoresValue
- type CpuAllocation
- type CustomDeployScript
- type Entrypoint
- type EnvVar
- type ID
- type ImageRegistry
- type ImageRepo
- type Instance
- type Meta
- type Mount
- type Node
- type Port
- type PortAddress
- type RamAllocation
- type Release
- type ResourceMetrics
- type Tags
- type Task
- type Timestamp
- type VolumeBlueprint
Constants ¶
const ( InstanceStatusStopped = "STOPPED" InstanceStatusStarted = "STARTED" )
Variables ¶
This section is empty.
Functions ¶
Types ¶
type App ¶
type App struct { Name ID `json:"name" validate:"nonzero,max=24,regexp=^[a-z]([-a-z0-9]*[a-z0-9])?$"` *Meta }
App is the main top-level Resource within Supergiant, acting as a logical namespace for Components and all of their controlled assets -- along with provisioning an actual Kubernetes Namespace, it is used as a base name for app-specific cloud assets.
type BytesValue ¶
type BytesValue struct {
Bytes int64
}
func BytesFromString ¶ added in v0.5.4
func BytesFromString(str string) *BytesValue
func (*BytesValue) Gibibytes ¶ added in v0.5.3
func (v *BytesValue) Gibibytes() float64
func (*BytesValue) MarshalJSON ¶ added in v0.5.1
func (b *BytesValue) MarshalJSON() ([]byte, error)
func (*BytesValue) Mebibytes ¶ added in v0.5.3
func (v *BytesValue) Mebibytes() float64
func (*BytesValue) ToKubeMebibytes ¶
func (v *BytesValue) ToKubeMebibytes() string
func (*BytesValue) UnmarshalJSON ¶ added in v0.5.1
func (b *BytesValue) UnmarshalJSON(raw []byte) error
type Component ¶
type Component struct { Name ID `json:"name" validate:"nonzero,max=24,regexp=^[a-z]([-a-z0-9]*[a-z0-9])?$"` CustomDeployScript *CustomDeployScript `json:"custom_deploy_script"` CurrentReleaseTimestamp ID `json:"current_release_id" sg:"readonly"` TargetReleaseTimestamp ID `json:"target_release_id" sg:"readonly"` Addresses *ComponentAddresses `json:"addresses,omitempty" sg:"readonly,nostore"` *Meta }
type ComponentAddresses ¶
type ComponentAddresses struct { External []*PortAddress `json:"external"` Internal []*PortAddress `json:"internal"` }
type ContainerBlueprint ¶
type ContainerBlueprint struct { Image string `json:"image" validate:"nonzero,regexp=^[-\\w\\.\\/]+(:[-\\w\\.]+)?$"` Name string `json:"name,omitempty"` // TODO can we do regex validations, that only fire if the value is provided? (i.e. not-nonzero) Command []string `json:"command,omitempty"` Ports []*Port `json:"ports,omitempty"` Env []*EnvVar `json:"env,omitempty"` CPU *CpuAllocation `json:"cpu" validate:"nonzero"` RAM *RamAllocation `json:"ram" validate:"nonzero"` Mounts []*Mount `json:"mounts,omitempty"` }
type CoresValue ¶
type CoresValue struct {
Millicores int
}
func CoresFromString ¶ added in v0.5.4
func CoresFromString(str string) *CoresValue
func (*CoresValue) Cores ¶ added in v0.5.3
func (v *CoresValue) Cores() float64
func (*CoresValue) MarshalJSON ¶ added in v0.5.1
func (c *CoresValue) MarshalJSON() ([]byte, error)
func (*CoresValue) ToKubeMillicores ¶
func (v *CoresValue) ToKubeMillicores() string
func (*CoresValue) UnmarshalJSON ¶ added in v0.5.1
func (c *CoresValue) UnmarshalJSON(raw []byte) error
type CpuAllocation ¶ added in v0.5.1
type CpuAllocation struct { Min *CoresValue `json:"min"` // NOTE validations removed since they are not numerical values anymore Max *CoresValue `json:"max"` }
type CustomDeployScript ¶
type Entrypoint ¶
type Entrypoint struct { // NOTE eventually the plan for Domain is to use it for DNS application. // That's not hooked up yet, and thus, we aren't doing any type of validation // on hostnames. Domain ID `json:"domain" validate:"nonzero"` // e.g. test.example.com // the ELB address Address string `json:"address" sg:"readonly"` *Meta }
type ID ¶
type ID *string
ID is defined as a string pointer in order to check for nil in the context of relations. NOTE this may not be best practice.
type ImageRegistry ¶ added in v0.5.0
type ImageRepo ¶
type ImageRepo struct { Name ID `json:"name" validate:"nonzero"` Key string `json:"key" validate:"nonzero" sg:"private"` *Meta }
TODO this should really be renamed to Org probably
type Instance ¶
type Instance struct { ID ID `json:"id"` // actually just the number (starting w/ 1) of the instance order in the release // BaseName is the name of the instance without the Release ID appended. It is // used for naming volumes, which move between releases. BaseName string `json:"base_name"` Name string `json:"name"` Status string `json:"status"` CPU *ResourceMetrics `json:"cpu"` RAM *ResourceMetrics `json:"ram"` }
NOTE Instances are not stored in etcd, so the json tags here apply to HTTP
type Meta ¶
type Meta struct { Created *Timestamp `json:"created" sg:"readonly"` Updated *Timestamp `json:"updated" sg:"readonly"` Tags Tags `json:"tags"` }
Meta is a set of fields on all Resources for holding metadata.
type Node ¶ added in v0.5.0
type Node struct { ID ID `json:"id" sg:"readonly"` Name string `json:"name" sg:"readonly"` // This is the only input for Node Class string `json:"class" validate:"nonzero"` ExternalIP string `json:"external_ip" sg:"readonly"` ProviderCreationTimestamp *Timestamp `json:"provider_creation_timestamp" sg:"readonly"` OutOfDisk bool `json:"out_of_disk" sg:"readonly,nostore"` Status string `json:"status" sg:"readonly,nostore"` CPU *ResourceMetrics `json:"cpu" sg:"readonly,nostore"` RAM *ResourceMetrics `json:"ram" sg:"readonly,nostore"` *Meta }
type Port ¶
type Port struct { // TODO Kube only accepts TCP|UDP for protocol values, but we accept values // like HTTP, which are used to display component addresses. We should either // build a map defining the accepted application protocols on top of TCP|UDP, // or make a sep. field. Protocol string `json:"protocol" validate:"nonzero" sg:"default=TCP"` Number int `json:"number" validate:"nonzero,max=40000"` Public bool `json:"public"` // EntrypointDomain specifies which Entrypoint this Port is added to. Does not // apply when Public is false. EntrypointDomain ID `json:"entrypoint_domain,omitempty"` // ExternalNumber instructs the Entrypoint to set the actual Port number // specified as the external load balancer port. Does not apply when // EntrypointDomain is nil. // // TODO validation needed just like on Number, but it can't be nonzero since // the value provided can be 0. ExternalNumber int `json:"external_number"` }
type PortAddress ¶
type RamAllocation ¶ added in v0.5.1
type RamAllocation struct { Min *BytesValue `json:"min"` Max *BytesValue `json:"max"` }
type Release ¶
type Release struct { // NOTE Timestamp here does not use the Timestamp type. Timestamp ID `json:"timestamp" sg:"readonly"` // TODO // InstanceGroup is used as a labeling mechanism for instances. If nil, // InstanceGroup is set equal to the release's Timestamp. If a value is // supplied by the user, it MUST be the current (previous) Release's // Timestamp. // // The purpose of InstanceGroup is to prevent restarting between Releases. // I'm pretty sure the ONLY scenario in which this value makes sense is when // changing InstanceCount, and the value supplied in such a scenario must be // the previous Release's timestamp. // // It seems as though we need to break deploys up into: // - config changes // - adding/removing instances // // It might still makes sense to have Release as a grouping mechanism, though, // because it could allow for grouping metrics recorded per-Release. However, // you may be able to separate the operations, but have every operation create // a new record that records the config / instance count at that time. InstanceGroup ID `json:"instance_group"` InstanceCount int `json:"instance_count" validate:"min=1" sg:"default=1"` // These attributes, when changed from last Release, indicate a restart is // needed (or just new instances through other means). Volumes []*VolumeBlueprint `json:"volumes"` Containers []*ContainerBlueprint `json:"containers" validate:"min=1"` TerminationGracePeriod int `json:"termination_grace_period" validate:"min=0" sg:"default=10"` // Retired defines whether or not a Release still has active assets, like pods // or services. When retired is true, we skip attempting to delete assets. Retired bool `json:"retired" sg:"readonly"` // Committed defines whether or not a Release is being / has been deployed. Committed bool `json:"committed" sg:"readonly"` *Meta }
NOTE the word Blueprint is used for Volumes and Containers, since they are both "definitions" that create "instances" of the real thing
type ResourceMetrics ¶ added in v0.5.0
NOTE this is not to be confused with our concept of Resources like Apps and Components -- this is for CPU / RAM / disk.
type Task ¶
type Task struct { ID ID `json:"id" sg:"readonly"` ActionData string `json:"action_data" validate:"nonzero"` MaxAttempts int `json:"max_attempts" validate:"min=1" sg:"default=10"` Status string `json:"status" sg:"readonly"` Attempts int `json:"attempts" sg:"readonly"` Error string `json:"error" sg:"readonly"` *Meta }
type Timestamp ¶
func NewTimestamp ¶
func NewTimestamp() *Timestamp