Documentation ¶
Overview ¶
Package servers provides information and interaction with the server API resource in the Enterprise Cloud Compute service.
A server is a virtual machine instance in the compute system. In order for one to be provisioned, a valid flavor and image are required.
Example to List Servers
listOpts := servers.ListOpts{ AllTenants: true, } allPages, err := servers.List(computeClient, listOpts).AllPages() if err != nil { panic(err) } allServers, err := servers.ExtractServers(allPages) if err != nil { panic(err) } for _, server := range allServers { fmt.Printf("%+v\n", server) }
Example to Get a Server
serverID := "d9072956-1560-487c-97f2-18bdf65ec749" server, err := servers.Get(client, serverID).Extract() if err != nil { panic(err) } fmt.Printf("%+v\n", server)
Example to Create a Server
createOpts := servers.CreateOpts{ Name: "server_name", ImageRef: "image-uuid", FlavorRef: "flavor-uuid", } result := servers.Create(computeClient, createOpts) if result.Err != nil { panic(result.Err) }
Example to Update a Server
name := "update_name" updateOpts := servers.UpdateOpts{Name: &name} serverID := "d9072956-1560-487c-97f2-18bdf65ec749" result := servers.Update(client, serverID, updateOpts) if result.Err != nil { panic(result.Err) }
Example to Delete a Server
serverID := "d9072956-1560-487c-97f2-18bdf65ec749" result := servers.Delete(computeClient, serverID) if result.Err != nil { panic(err) }
Example to Show Metadata a server
serverID := "d9072956-1560-487c-97f2-18bdf65ec749" metadata, err := servers.Metadata(client, serverID).Extract() if err != nil { panic(err) } fmt.Printf("%+v\n", metadata)
Example to Show details for a Metadata item by key for a Server
key := "key" serverID := "d9072956-1560-487c-97f2-18bdf65ec749" metadatum, err := servers.Metadatum(client, serverID, key).Extract() if err != nil { panic(err) } fmt.Printf("%+v\n", metadatum)
Example to Create Metadata a Server
createMetadatumOpts := servers.MetadatumOpts{"key": "value"} serverID := "d9072956-1560-487c-97f2-18bdf65ec749" result := servers.CreateMetadatum(client, serverID, createMetadatumOpts) if err != nil { panic(result.Err) }
Example to Update Metadata a Server
updateMetadataOpts := servers.MetadataOpts{"key": "update"} serverID := "d9072956-1560-487c-97f2-18bdf65ec749" result := servers.UpdateMetadata(client, serverID, updateMetadataOpts) if result.Err != nil { panic(result.Err) }
Example to Delete Metadata a Server
key := "key" serverID := "d9072956-1560-487c-97f2-18bdf65ec749" result := servers.DeleteMetadatum(client, serverID, key) if result.Err != nil { panic(result.Err) }
Example to Reset Metadata a Server
resetMetadataOpts := servers.MetadataOpts{"key2": "val2"} serverID := "d9072956-1560-487c-97f2-18bdf65ec749" result := servers.ResetMetadata(client, serverID, resetMetadataOpts) if result.Err != nil { panic(nil) }
Example to Resize a Server
resizeOpts := servers.ResizeOpts{ FlavorRef: "flavor-uuid", } serverID := "d9072956-1560-487c-97f2-18bdf65ec749" result := servers.Resize(computeClient, serverID, resizeOpts) if result.Err != nil { panic(result.Err) }
Example to Snapshot a Server
snapshotOpts := servers.CreateImageOpts{ Name: "snapshot_name", } serverID := "d9072956-1560-487c-97f2-18bdf65ec749" result := servers.CreateImage(computeClient, serverID, snapshotOpts) if result.Err != nil { panic(result.Err) }
Index ¶
- func ExtractServersInto(r pagination.Page, v interface{}) error
- func IDFromName(client *eclcloud.ServiceClient, name string) (string, error)
- func List(client *eclcloud.ServiceClient, opts ListOptsBuilder) pagination.Pager
- func WaitForStatus(c *eclcloud.ServiceClient, id, status string, secs int) error
- type ActionResult
- type CreateImageOpts
- type CreateImageOptsBuilder
- type CreateImageResult
- type CreateMetadatumResult
- type CreateOpts
- type CreateOptsBuilder
- type CreateResult
- type DeleteMetadatumResult
- type DeleteResult
- type ErrInvalidHowParameterProvided
- type ErrNeitherFlavorIDNorFlavorNameProvided
- type ErrNeitherImageIDNorImageNameProvided
- type ErrNoAdminPassProvided
- type ErrNoClientProvidedForIDByName
- type ErrNoIDProvided
- type ErrNoImageIDProvided
- type ErrServer
- type ErrServerNotFound
- type Fault
- type GetMetadataResult
- type GetMetadatumResult
- type GetResult
- type ListOpts
- type ListOptsBuilder
- type MetadataOpts
- type MetadataResult
- type MetadatumOpts
- type MetadatumOptsBuilder
- type MetadatumResult
- type Network
- type ResetMetadataOptsBuilder
- type ResetMetadataResult
- type ResizeOpts
- type ResizeOptsBuilder
- type Server
- type ServerPage
- type UpdateMetadataOptsBuilder
- type UpdateMetadataResult
- type UpdateOpts
- type UpdateOptsBuilder
- type UpdateResult
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func ExtractServersInto ¶
func ExtractServersInto(r pagination.Page, v interface{}) error
func IDFromName ¶
IDFromName is a convienience function that returns a server's ID given its name.
func List ¶
func List(client *eclcloud.ServiceClient, opts ListOptsBuilder) pagination.Pager
List makes a request against the API to list servers accessible to you.
func WaitForStatus ¶
WaitForStatus will continually poll a server until it successfully transitions to a specified status. It will do this for at most the number of seconds specified.
Types ¶
type ActionResult ¶
type ActionResult struct {
eclcloud.ErrResult
}
ActionResult represents the result of server action operations, like reboot. Call its ExtractErr method to determine if the action succeeded or failed.
func Resize ¶
func Resize(client *eclcloud.ServiceClient, id string, opts ResizeOptsBuilder) (r ActionResult)
Resize instructs the provider to change the flavor of the server.
Note that this implies rebuilding it.
Unfortunately, one cannot pass rebuild parameters to the resize function. When the resize completes, the server will be in VERIFY_RESIZE state. While in this state, you can explore the use of the new server's configuration. If you like it, call ConfirmResize() to commit the resize permanently. Otherwise, call RevertResize() to restore the old configuration.
type CreateImageOpts ¶
type CreateImageOpts struct { // Name of the image/snapshot. Name string `json:"name" required:"true"` // Metadata contains key-value pairs (up to 255 bytes each) to attach to // the created image. Metadata map[string]string `json:"metadata,omitempty"` }
CreateImageOpts provides options to pass to the CreateImage request.
func (CreateImageOpts) ToServerCreateImageMap ¶
func (opts CreateImageOpts) ToServerCreateImageMap() (map[string]interface{}, error)
ToServerCreateImageMap formats a CreateImageOpts structure into a request body.
type CreateImageOptsBuilder ¶
CreateImageOptsBuilder allows extensions to add additional parameters to the CreateImage request.
type CreateImageResult ¶
type CreateImageResult struct {
eclcloud.Result
}
CreateImageResult is the response from a CreateImage operation. Call its ExtractImageID method to retrieve the ID of the newly created image.
func CreateImage ¶
func CreateImage(client *eclcloud.ServiceClient, id string, opts CreateImageOptsBuilder) (r CreateImageResult)
CreateImage makes a request against the nova API to schedule an image to be created of the server
func (CreateImageResult) ExtractImageID ¶
func (r CreateImageResult) ExtractImageID() (string, error)
ExtractImageID gets the ID of the newly created server image from the header.
type CreateMetadatumResult ¶
type CreateMetadatumResult struct {
MetadatumResult
}
CreateMetadatumResult contains the result of a Create operation. Call its Extract method to interpret it as a map[string]interface.
func CreateMetadatum ¶
func CreateMetadatum(client *eclcloud.ServiceClient, id string, opts MetadatumOptsBuilder) (r CreateMetadatumResult)
CreateMetadatum will create or update the key-value pair with the given key for the given server ID.
type CreateOpts ¶
type CreateOpts struct { // Name is the name to assign to the newly launched server. Name string `json:"name" required:"true"` // ImageRef [optional; required if ImageName is not provided] is the ID or // full URL to the image that contains the server's OS and initial state. // Also optional if using the boot-from-volume extension. ImageRef string `json:"imageRef"` // ImageName [optional; required if ImageRef is not provided] is the name of // the image that contains the server's OS and initial state. // Also optional if using the boot-from-volume extension. ImageName string `json:"-"` // FlavorRef [optional; required if FlavorName is not provided] is the ID or // full URL to the flavor that describes the server's specs. FlavorRef string `json:"flavorRef"` // FlavorName [optional; required if FlavorRef is not provided] is the name of // the flavor that describes the server's specs. FlavorName string `json:"-"` // UserData contains configuration information or scripts to use upon launch. // Create will base64-encode it for you, if it isn't already. UserData []byte `json:"-"` // AvailabilityZone in which to launch the server. AvailabilityZone string `json:"availability_zone,omitempty"` // Networks dictates how this server will be attached to available networks. // By default, the server will be attached to all isolated networks for the // tenant. Networks []Network `json:"-"` // Metadata contains key-value pairs (up to 255 bytes each) to attach to the // server. Metadata map[string]string `json:"metadata,omitempty"` // ConfigDrive enables metadata injection through a configuration drive. ConfigDrive *bool `json:"config_drive,omitempty"` // AccessIPv4 specifies an IPv4 address for the instance. AccessIPv4 string `json:"accessIPv4,omitempty"` // ServiceClient will allow calls to be made to retrieve an image or // flavor ID by name. ServiceClient *eclcloud.ServiceClient `json:"-"` }
CreateOpts specifies server creation parameters.
func (CreateOpts) ToServerCreateMap ¶
func (opts CreateOpts) ToServerCreateMap() (map[string]interface{}, error)
ToServerCreateMap assembles a request body based on the contents of a CreateOpts.
type CreateOptsBuilder ¶
CreateOptsBuilder allows extensions to add additional parameters to the Create request.
type CreateResult ¶
type CreateResult struct {
// contains filtered or unexported fields
}
CreateResult is the response from a Create operation. Call its Extract method to interpret it as a Server.
func Create ¶
func Create(client *eclcloud.ServiceClient, opts CreateOptsBuilder) (r CreateResult)
Create requests a server to be provisioned to the user in the current tenant.
func (CreateResult) ExtractInto ¶
func (r CreateResult) ExtractInto(v interface{}) error
type DeleteMetadatumResult ¶
type DeleteMetadatumResult struct {
eclcloud.ErrResult
}
DeleteMetadatumResult contains the result of a Delete operation. Call its ExtractErr method to determine if the call succeeded or failed.
func DeleteMetadatum ¶
func DeleteMetadatum(client *eclcloud.ServiceClient, id, key string) (r DeleteMetadatumResult)
DeleteMetadatum will delete the key-value pair with the given key for the given server ID.
type DeleteResult ¶
type DeleteResult struct {
eclcloud.ErrResult
}
DeleteResult is the response from a Delete operation. Call its ExtractErr method to determine if the call succeeded or failed.
func Delete ¶
func Delete(client *eclcloud.ServiceClient, id string) (r DeleteResult)
Delete requests that a server previously provisioned be removed from your account.
type ErrInvalidHowParameterProvided ¶
type ErrInvalidHowParameterProvided struct{ eclcloud.ErrInvalidInput }
ErrInvalidHowParameterProvided is the error when an unknown value is given for the `how` argument
type ErrNeitherFlavorIDNorFlavorNameProvided ¶
type ErrNeitherFlavorIDNorFlavorNameProvided struct{ eclcloud.ErrMissingInput }
ErrNeitherFlavorIDNorFlavorNameProvided is the error when neither the flavor ID nor the flavor name is provided for a server operation
func (ErrNeitherFlavorIDNorFlavorNameProvided) Error ¶
func (e ErrNeitherFlavorIDNorFlavorNameProvided) Error() string
type ErrNeitherImageIDNorImageNameProvided ¶
type ErrNeitherImageIDNorImageNameProvided struct{ eclcloud.ErrMissingInput }
ErrNeitherImageIDNorImageNameProvided is the error when neither the image ID nor the image name is provided for a server operation
func (ErrNeitherImageIDNorImageNameProvided) Error ¶
func (e ErrNeitherImageIDNorImageNameProvided) Error() string
type ErrNoAdminPassProvided ¶
type ErrNoAdminPassProvided struct{ eclcloud.ErrMissingInput }
ErrNoAdminPassProvided is the error when an administrative password isn't provided for a server operation
type ErrNoClientProvidedForIDByName ¶
type ErrNoClientProvidedForIDByName struct{ eclcloud.ErrMissingInput }
func (ErrNoClientProvidedForIDByName) Error ¶
func (e ErrNoClientProvidedForIDByName) Error() string
type ErrNoIDProvided ¶
type ErrNoIDProvided struct{ eclcloud.ErrMissingInput }
ErrNoIDProvided is the error when a server ID isn't provided for a server operation
type ErrNoImageIDProvided ¶
type ErrNoImageIDProvided struct{ eclcloud.ErrMissingInput }
ErrNoImageIDProvided is the error when an image ID isn't provided for a server operation
type ErrServer ¶
type ErrServer struct { eclcloud.ErrUnexpectedResponseCode ID string }
ErrServer is a generic error type for servers HTTP operations.
type ErrServerNotFound ¶
type ErrServerNotFound struct {
ErrServer
}
ErrServerNotFound is the error when a 404 is received during server HTTP operations.
func (ErrServerNotFound) Error ¶
func (e ErrServerNotFound) Error() string
type GetMetadataResult ¶
type GetMetadataResult struct {
MetadataResult
}
GetMetadataResult contains the result of a Get operation. Call its Extract method to interpret it as a map[string]interface.
func Metadata ¶
func Metadata(client *eclcloud.ServiceClient, id string) (r GetMetadataResult)
Metadata requests all the metadata for the given server ID.
type GetMetadatumResult ¶
type GetMetadatumResult struct {
MetadatumResult
}
GetMetadatumResult contains the result of a Get operation. Call its Extract method to interpret it as a map[string]interface.
func Metadatum ¶
func Metadatum(client *eclcloud.ServiceClient, id, key string) (r GetMetadatumResult)
Metadatum requests the key-value pair with the given key for the given server ID.
type GetResult ¶
type GetResult struct {
// contains filtered or unexported fields
}
GetResult is the response from a Get operation. Call its Extract method to interpret it as a Server.
func (GetResult) ExtractInto ¶
func (r GetResult) ExtractInto(v interface{}) error
type ListOpts ¶
type ListOpts struct { // ChangesSince is a time/date stamp for when the server last changed status. ChangesSince string `q:"changes-since"` // Image is the name of the image in URL format. Image string `q:"image"` // Flavor is the name of the flavor in URL format. Flavor string `q:"flavor"` // Name of the server as a string; can be queried with regular expressions. // Realize that ?name=bob returns both bob and bobb. If you need to match bob // only, you can use a regular expression matching the syntax of the // underlying database server implemented for Compute. Name string `q:"name"` // Status is the value of the status of the server so that you can filter on // "ACTIVE" for example. Status string `q:"status"` // Host is the name of the host as a string. Host string `q:"host"` // Marker is a UUID of the server at which you want to set a marker. Marker string `q:"marker"` // Limit is an integer value for the limit of values to return. Limit int `q:"limit"` // AllTenants is a bool to show all tenants. AllTenants bool `q:"all_tenants"` // TenantID lists servers for a particular tenant. // Setting "AllTenants = true" is required. TenantID string `q:"tenant_id"` }
ListOpts allows the filtering and sorting of paginated collections through the API. Filtering is achieved by passing in struct field values that map to the server attributes you want to see returned. Marker and Limit are used for pagination.
func (ListOpts) ToServerListQuery ¶
ToServerListQuery formats a ListOpts into a query string.
type ListOptsBuilder ¶
ListOptsBuilder allows extensions to add additional parameters to the List request.
type MetadataOpts ¶
MetadataOpts is a map that contains key-value pairs.
func (MetadataOpts) ToMetadataResetMap ¶
func (opts MetadataOpts) ToMetadataResetMap() (map[string]interface{}, error)
ToMetadataResetMap assembles a body for a Reset request based on the contents of a MetadataOpts.
func (MetadataOpts) ToMetadataUpdateMap ¶
func (opts MetadataOpts) ToMetadataUpdateMap() (map[string]interface{}, error)
ToMetadataUpdateMap assembles a body for an Update request based on the contents of a MetadataOpts.
type MetadataResult ¶
type MetadataResult struct {
eclcloud.Result
}
MetadataResult contains the result of a call for (potentially) multiple key-value pairs. Call its Extract method to interpret it as a map[string]interface.
type MetadatumOpts ¶
MetadatumOpts is a map of length one that contains a key-value pair.
func (MetadatumOpts) ToMetadatumCreateMap ¶
func (opts MetadatumOpts) ToMetadatumCreateMap() (map[string]interface{}, string, error)
ToMetadatumCreateMap assembles a body for a Create request based on the contents of a MetadataumOpts.
type MetadatumOptsBuilder ¶
type MetadatumOptsBuilder interface {
ToMetadatumCreateMap() (map[string]interface{}, string, error)
}
MetadatumOptsBuilder allows extensions to add additional parameters to the Create request.
type MetadatumResult ¶
type MetadatumResult struct {
eclcloud.Result
}
MetadatumResult contains the result of a call for individual a single key-value pair.
type Network ¶
type Network struct { // UUID of a network to attach to the newly provisioned server. // Required unless Port is provided. UUID string // Port of a neutron network to attach to the newly provisioned server. // Required unless UUID is provided. Port string // FixedIP specifies a fixed IPv4 address to be used on this network. FixedIP string }
Network is used within CreateOpts to control a new server's network attachments.
type ResetMetadataOptsBuilder ¶
ResetMetadataOptsBuilder allows extensions to add additional parameters to the Reset request.
type ResetMetadataResult ¶
type ResetMetadataResult struct {
MetadataResult
}
ResetMetadataResult contains the result of a Reset operation. Call its Extract method to interpret it as a map[string]interface.
func ResetMetadata ¶
func ResetMetadata(client *eclcloud.ServiceClient, id string, opts ResetMetadataOptsBuilder) (r ResetMetadataResult)
ResetMetadata will create multiple new key-value pairs for the given server ID. Note: Using this operation will erase any already-existing metadata and create the new metadata provided. To keep any already-existing metadata, use the UpdateMetadatas or UpdateMetadata function.
type ResizeOpts ¶
type ResizeOpts struct { // FlavorRef is the ID of the flavor you wish your server to become. FlavorRef string `json:"flavorRef" required:"true"` }
ResizeOpts represents the configuration options used to control a Resize operation.
func (ResizeOpts) ToServerResizeMap ¶
func (opts ResizeOpts) ToServerResizeMap() (map[string]interface{}, error)
ToServerResizeMap formats a ResizeOpts as a map that can be used as a JSON request body for the Resize request.
type ResizeOptsBuilder ¶
ResizeOptsBuilder allows extensions to add additional parameters to the resize request.
type Server ¶
type Server struct { // ID uniquely identifies this server amongst all other servers, // including those not accessible to the current tenant. ID string `json:"id"` // TenantID identifies the tenant owning this server resource. TenantID string `json:"tenant_id"` // UserID uniquely identifies the user account owning the tenant. UserID string `json:"user_id"` // Name contains the human-readable name for the server. Name string `json:"name"` // Updated and Created contain ISO-8601 timestamps of when the state of the // server last changed, and when it was created. Updated time.Time `json:"updated"` Created time.Time `json:"created"` // HostID is the host where the server is located in the cloud. HostID string `json:"hostid"` // Status contains the current operational status of the server, // such as IN_PROGRESS or ACTIVE. Status string `json:"status"` // Progress ranges from 0..100. // A request made against the server completes only once Progress reaches 100. Progress int `json:"progress"` // AccessIPv4 and AccessIPv6 contain the IP addresses of the server, // suitable for remote access for administration. AccessIPv4 string `json:"accessIPv4"` // Image refers to a JSON object, which itself indicates the OS image used to // deploy the server. Image map[string]interface{} `json:"-"` // Flavor refers to a JSON object, which itself indicates the hardware // configuration of the deployed server. Flavor map[string]interface{} `json:"flavor"` // Addresses includes a list of all IP addresses assigned to the server, // keyed by pool. Addresses map[string]interface{} `json:"addresses"` // Metadata includes a list of all user-specified key-value pairs attached // to the server. Metadata map[string]string `json:"metadata"` // Links includes HTTP references to the itself, useful for passing along to // other APIs that might want a server reference. Links []interface{} `json:"links"` // KeyName indicates which public key was injected into the server on launch. KeyName string `json:"key_name"` // AdminPass will generally be empty (""). However, it will contain the // administrative password chosen when provisioning a new server without a // set AdminPass setting in the first place. // Note that this is the ONLY time this field will be valid. AdminPass string `json:"adminPass"` // SecurityGroups includes the security groups that this instance has applied // to it. SecurityGroups []map[string]interface{} `json:"security_groups"` // Fault contains failure information about a server. Fault Fault `json:"fault"` // ConfigDrive is the name of the server's config drive. ConfigDrive string `json:"config_drive"` }
Server represents a server/instance in the Enterprise Cloud.
func ExtractServers ¶
func ExtractServers(r pagination.Page) ([]Server, error)
ExtractServers interprets the results of a single page from a List() call, producing a slice of Server entities.
func (*Server) UnmarshalJSON ¶
type ServerPage ¶
type ServerPage struct {
pagination.LinkedPageBase
}
ServerPage abstracts the raw results of making a List() request against the API. As Enterprise Cloud extensions may freely alter the response bodies of structures returned to the client, you may only safely access the data provided through the ExtractServers call.
func (ServerPage) IsEmpty ¶
func (r ServerPage) IsEmpty() (bool, error)
IsEmpty returns true if a page contains no Server results.
func (ServerPage) NextPageURL ¶
func (r ServerPage) NextPageURL() (string, error)
NextPageURL uses the response's embedded link reference to navigate to the next page of results.
type UpdateMetadataOptsBuilder ¶
UpdateMetadataOptsBuilder allows extensions to add additional parameters to the Create request.
type UpdateMetadataResult ¶
type UpdateMetadataResult struct {
MetadataResult
}
UpdateMetadataResult contains the result of an Update operation. Call its Extract method to interpret it as a map[string]interface.
func UpdateMetadata ¶
func UpdateMetadata(client *eclcloud.ServiceClient, id string, opts UpdateMetadataOptsBuilder) (r UpdateMetadataResult)
UpdateMetadata updates (or creates) all the metadata specified by opts for the given server ID. This operation does not affect already-existing metadata that is not specified by opts.
type UpdateOpts ¶
type UpdateOpts struct { // Name changes the displayed name of the server. // The server host name will *not* change. // Server names are not constrained to be unique, even within the same tenant. Name *string `json:"name,omitempty"` }
UpdateOpts specifies the base attributes that may be updated on an existing server.
func (UpdateOpts) ToServerUpdateMap ¶
func (opts UpdateOpts) ToServerUpdateMap() (map[string]interface{}, error)
ToServerUpdateMap formats an UpdateOpts structure into a request body.
type UpdateOptsBuilder ¶
UpdateOptsBuilder allows extensions to add additional attributes to the Update request.
type UpdateResult ¶
type UpdateResult struct {
// contains filtered or unexported fields
}
UpdateResult is the response from an Update operation. Call its Extract method to interpret it as a Server.
func Update ¶
func Update(client *eclcloud.ServiceClient, id string, opts UpdateOptsBuilder) (r UpdateResult)
Update requests that various attributes of the indicated server be changed.
func (UpdateResult) ExtractInto ¶
func (r UpdateResult) ExtractInto(v interface{}) error