Documentation ¶
Index ¶
- Variables
- type Account
- type AccountsInterface
- type Client
- type ClientOption
- type ClientOptions
- type CloudProviderName
- type ObjectMeta
- type OceanCluster
- type OceanClusterBuilder
- type OceanClusterOptions
- type OceanClustersSorter
- type OceanInterface
- type OceanLaunchSpec
- type OceanLaunchSpecBuilder
- type OceanLaunchSpecOptions
- type OceanLaunchSpecsSorter
- type OceanRollout
- type OceanRolloutBuilder
- type OceanRolloutOptions
- type OceanRolloutsSorter
- type OrchestratorName
- type ServicesInterface
- type TypeMeta
Constants ¶
This section is empty.
Variables ¶
var ErrNotImplemented = errors.New("spot: not implemented")
ErrNotImplemented is the error returned if a method is not implemented.
Functions ¶
This section is empty.
Types ¶
type Account ¶
type Account struct { // Unique account ID. ID string `json:"accountId"` // Account name. Name string `json:"name"` // Organization ID. OrganizationID string `json:"organizationId"` // External ID generated by the cloud provider bounded with this account. ExternalID *string `json:"providerExternalId"` // nullable; used by AWS only }
Account represents a Spot account.
type AccountsInterface ¶
type AccountsInterface interface { // ListAccounts returns a list of Spot accounts. ListAccounts(ctx context.Context) ([]*Account, error) }
AccountsInterface defines the interface of the Spot Accounts API.
type Client ¶
type Client interface { // Accounts returns an instance of Accounts interface. Accounts() AccountsInterface // Services returns an instance of Services interface. Services() ServicesInterface }
Client the interface of the Spot API.
func New ¶
func New(options ...ClientOption) Client
type ClientOption ¶
type ClientOption func(*ClientOptions)
ClientOption allows specifying various settings configurable by the client.
func WithBaseURL ¶
func WithBaseURL(url string) ClientOption
WithBaseURL defines the base URL of the Spot API.
func WithCredentialsProfile ¶
func WithCredentialsProfile(profile string) ClientOption
WithCredentialsProfile specifies credentials profile to use.
func WithCredentialsStatic ¶
func WithCredentialsStatic(token, account string) ClientOption
WithCredentialsStatic specifies static credentials.
func WithDryRun ¶
func WithDryRun(value bool) ClientOption
WithDryRun toggles the dry-run mode on/off.
type ClientOptions ¶
type ClientOptions struct { // Credentials profile. Defaults to `default`. Profile string // Static user credentials. Token, Account string // BaseURL configures the default base URL of the Spot API. // Defaults to `https://api.spotinst.io`. BaseURL string // DryRun configures the client to print the actions that would be executed, // without executing them. DryRun bool }
type CloudProviderName ¶
type CloudProviderName string
CloudProviderName represents the name of a cloud provider.
const ( CloudProviderAWS CloudProviderName = "aws" CloudProviderGCP CloudProviderName = "gcp" CloudProviderAzure CloudProviderName = "azure" )
Cloud Providers.
type ObjectMeta ¶
type ObjectMeta struct { // Unique ID. ID string `json:"id" table:"1,id"` // Object name. Name string `json:"name" table:"2,name"` // CreatedAt represents the timestamp when the cluster has been created. CreatedAt time.Time `json:"createdAt" table:"9,created"` // UpdatedAt represents the timestamp when the cluster has been updated. UpdatedAt time.Time `json:"updatedAt" table:"10,updated"` }
ObjectMeta is metadata that all resources must have.
type OceanCluster ¶
type OceanCluster struct { // Type's metadata. TypeMeta // Object's metadata. ObjectMeta // Obj holds the raw object which is an orchestrator-specific implementation. Obj interface{} `json:"-"` }
OceanCluster represents an Ocean cluster.
type OceanClusterBuilder ¶
type OceanClusterBuilder interface {
Build() (*OceanCluster, error)
}
OceanClusterBuilder is the interface that every Ocean cluster concrete implementation should obey.
type OceanClusterOptions ¶
type OceanClusterOptions struct { // Base. ClusterID string ControllerID string Name string Region string // Strategy. SpotPercentage float64 UtilizeReservedInstances bool FallbackToOnDemand bool DrainingTimeout int // Capacity. MinSize int MaxSize int TargetSize int // Compute SubnetIDs []string InstanceTypesWhitelist []string InstanceTypesBlacklist []string SecurityGroupIDs []string ImageID string KeyPair string UserData string RootVolumeSize int AssociatePublicIPAddress bool EnableMonitoring bool EnableEBSOptimization bool IAMInstanceProfileName string IAMInstanceProfileARN string LoadBalancerName string LoadBalancerARN string LoadBalancerType string // Auto Scaling. EnableAutoScaler bool EnableAutoConfig bool Cooldown int HeadroomCPUPerUnit int HeadroomMemoryPerUnit int HeadroomGPUPerUnit int HeadroomNumPerUnit int ResourceLimitMaxVCPU int ResourceLimitMaxMemory int EvaluationPeriods int MaxScaleDownPercentage int }
OceanClusterOptions represents an Ocean cluster.
type OceanClustersSorter ¶
type OceanClustersSorter struct {
Clusters []*OceanCluster
}
func (*OceanClustersSorter) Len ¶
func (s *OceanClustersSorter) Len() int
func (*OceanClustersSorter) Less ¶
func (s *OceanClustersSorter) Less(i, j int) bool
func (*OceanClustersSorter) Swap ¶
func (s *OceanClustersSorter) Swap(i, j int)
type OceanInterface ¶
type OceanInterface interface { // NewClusterBuilder returns new instance of OceanClusterBuilder // interface for defining fresh Ocean cluster. NewClusterBuilder(fs *pflag.FlagSet, opts *OceanClusterOptions) OceanClusterBuilder // NewLaunchSpecBuilder returns new instance of OceanLaunchSpecBuilder // interface for defining fresh Ocean launch spec. NewLaunchSpecBuilder(fs *pflag.FlagSet, opts *OceanLaunchSpecOptions) OceanLaunchSpecBuilder // NewRolloutBuilder returns new instance of OceanRolloutBuilder // interface for defining fresh Ocean rollout. NewRolloutBuilder(fs *pflag.FlagSet, opts *OceanRolloutOptions) OceanRolloutBuilder // ListClusters returns a list of Ocean clusters. ListClusters(ctx context.Context) ([]*OceanCluster, error) // ListLaunchSpecs returns a list of Ocean launch specs. ListLaunchSpecs(ctx context.Context) ([]*OceanLaunchSpec, error) // ListRollouts returns a list of Ocean rollouts. ListRollouts(ctx context.Context, clusterID string) ([]*OceanRollout, error) // GetCluster returns an Ocean cluster spec by ID. GetCluster(ctx context.Context, clusterID string) (*OceanCluster, error) // GetLaunchSpec returns an Ocean launch spec by ID. GetLaunchSpec(ctx context.Context, specID string) (*OceanLaunchSpec, error) // GetRollout returns an Ocean rollout by ID. GetRollout(ctx context.Context, clusterID, rolloutID string) (*OceanRollout, error) // CreateCluster creates a new Ocean cluster. CreateCluster(ctx context.Context, cluster *OceanCluster) (*OceanCluster, error) // CreateLaunchSpec creates a new Ocean launch spec. CreateLaunchSpec(ctx context.Context, spec *OceanLaunchSpec) (*OceanLaunchSpec, error) // CreateRollout creates a new Ocean rollout. CreateRollout(ctx context.Context, rollout *OceanRollout) (*OceanRollout, error) // UpdateCluster updates an existing Ocean cluster by ID. UpdateCluster(ctx context.Context, cluster *OceanCluster) (*OceanCluster, error) // UpdateLaunchSpec updates an existing Ocean launch spec by ID. UpdateLaunchSpec(ctx context.Context, spec *OceanLaunchSpec) (*OceanLaunchSpec, error) // UpdateRollout updates an existing Ocean rollout by ID. UpdateRollout(ctx context.Context, rollout *OceanRollout) (*OceanRollout, error) // DeleteCluster deletes an Ocean cluster spec by ID. DeleteCluster(ctx context.Context, clusterID string) error // DeleteLaunchSpec deletes an Ocean launch spec by ID. DeleteLaunchSpec(ctx context.Context, specID string) error }
OceanInterface defines the interface of the Spot Ocean API.
type OceanLaunchSpec ¶
type OceanLaunchSpec struct { // Type's metadata. TypeMeta // Object's metadata. ObjectMeta // Obj holds the raw object which is an orchestrator-specific implementation. Obj interface{} `json:"-"` }
OceanLaunchSpec represents an Ocean launch spec.
type OceanLaunchSpecBuilder ¶
type OceanLaunchSpecBuilder interface {
Build() (*OceanLaunchSpec, error)
}
OceanLaunchSpecBuilder is the interface that every Ocean launch spec concrete implementation should obey.
type OceanLaunchSpecOptions ¶
type OceanLaunchSpecOptions struct { // Base. SpecID string ClusterID string Name string // Compute. ImageID string UserData string SecurityGroupIDs []string }
OceanLaunchSpecOptions represents an Ocean launch spec.
type OceanLaunchSpecsSorter ¶
type OceanLaunchSpecsSorter struct {
LaunchSpecs []*OceanLaunchSpec
}
func (*OceanLaunchSpecsSorter) Len ¶
func (s *OceanLaunchSpecsSorter) Len() int
func (*OceanLaunchSpecsSorter) Less ¶
func (s *OceanLaunchSpecsSorter) Less(i, j int) bool
func (*OceanLaunchSpecsSorter) Swap ¶
func (s *OceanLaunchSpecsSorter) Swap(i, j int)
type OceanRollout ¶
type OceanRollout struct { // Type's metadata. TypeMeta // Object's metadata. ObjectMeta // Obj holds the raw object which is an orchestrator-specific implementation. Obj interface{} `json:"-"` }
OceanRollout represents an Ocean rollout.
type OceanRolloutBuilder ¶
type OceanRolloutBuilder interface {
Build() (*OceanRollout, error)
}
OceanRolloutBuilder is the interface that every Ocean rollout concrete implementation should obey.
type OceanRolloutOptions ¶
type OceanRolloutOptions struct { // Base. RolloutID string ClusterID string Comment string Status string // Parameters. BatchSizePercentage int DisableAutoScaling bool SpecIDs []string InstanceIDs []string }
OceanRolloutOptions represents an Ocean rollout.
type OceanRolloutsSorter ¶
type OceanRolloutsSorter struct {
Rollouts []*OceanRollout
}
func (*OceanRolloutsSorter) Len ¶
func (s *OceanRolloutsSorter) Len() int
func (*OceanRolloutsSorter) Less ¶
func (s *OceanRolloutsSorter) Less(i, j int) bool
func (*OceanRolloutsSorter) Swap ¶
func (s *OceanRolloutsSorter) Swap(i, j int)
type OrchestratorName ¶
type OrchestratorName string
OrchestratorName represents the name of a container orchestrator.
const ( OrchestratorKubernetes OrchestratorName = "kubernetes" OrchestratorECS OrchestratorName = "ecs" )
Orchestrators.
type ServicesInterface ¶
type ServicesInterface interface { // Ocean returns an instance of Ocean interface by cloud provider and // orchestrator names. Ocean(provider CloudProviderName, orchestrator OrchestratorName) (OceanInterface, error) }
ServicesInterface defines the interface of the Spot Services API.