2018-02-12 18:10:05 +01:00
package egoscale
import (
2018-09-14 10:06:03 +02:00
"context"
"fmt"
2018-02-12 18:10:05 +01:00
"net/url"
)
// AffinityGroup represents an (anti-)affinity group
2018-09-14 10:06:03 +02:00
//
// Affinity and Anti-Affinity groups provide a way to influence where VMs should run.
// See: http://docs.cloudstack.apache.org/projects/cloudstack-administration/en/stable/virtual_machines.html#affinity-groups
2018-02-12 18:10:05 +01:00
type AffinityGroup struct {
2019-03-14 11:04:04 +01:00
Account string ` json:"account,omitempty" doc:"the account owning the affinity group" `
Description string ` json:"description,omitempty" doc:"the description of the affinity group" `
ID * UUID ` json:"id,omitempty" doc:"the ID of the affinity group" `
Name string ` json:"name,omitempty" doc:"the name of the affinity group" `
Type string ` json:"type,omitempty" doc:"the type of the affinity group" `
VirtualMachineIDs [ ] UUID ` json:"virtualmachineIds,omitempty" doc:"virtual machine Ids associated with this affinity group" `
2018-09-14 10:06:03 +02:00
}
// ListRequest builds the ListAffinityGroups request
func ( ag AffinityGroup ) ListRequest ( ) ( ListCommand , error ) {
return & ListAffinityGroups {
ID : ag . ID ,
Name : ag . Name ,
} , nil
}
// Delete removes the given Affinity Group
func ( ag AffinityGroup ) Delete ( ctx context . Context , client * Client ) error {
if ag . ID == nil && ag . Name == "" {
return fmt . Errorf ( "an Affinity Group may only be deleted using ID or Name" )
}
2019-03-14 11:04:04 +01:00
req := & DeleteAffinityGroup { }
2018-09-14 10:06:03 +02:00
if ag . ID != nil {
req . ID = ag . ID
} else {
req . Name = ag . Name
}
return client . BooleanRequestWithContext ( ctx , req )
2018-02-12 18:10:05 +01:00
}
// AffinityGroupType represent an affinity group type
type AffinityGroupType struct {
2018-09-14 10:06:03 +02:00
Type string ` json:"type,omitempty" doc:"the type of the affinity group" `
2018-02-12 18:10:05 +01:00
}
// CreateAffinityGroup (Async) represents a new (anti-)affinity group
type CreateAffinityGroup struct {
2019-03-14 11:04:04 +01:00
Description string ` json:"description,omitempty" doc:"Optional description of the affinity group" `
Name string ` json:"name,omitempty" doc:"Name of the affinity group" `
2018-09-14 10:06:03 +02:00
Type string ` json:"type" doc:"Type of the affinity group from the available affinity/anti-affinity group types" `
_ bool ` name:"createAffinityGroup" description:"Creates an affinity/anti-affinity group" `
2018-02-12 18:10:05 +01:00
}
2019-03-14 11:04:04 +01:00
func ( req CreateAffinityGroup ) onBeforeSend ( params url . Values ) error {
// Name must be set, but can be empty
if req . Name == "" {
params . Set ( "name" , "" )
}
return nil
}
// Response returns the struct to unmarshal
func ( CreateAffinityGroup ) Response ( ) interface { } {
2018-09-14 10:06:03 +02:00
return new ( AsyncJobResult )
2018-02-12 18:10:05 +01:00
}
2019-03-14 11:04:04 +01:00
// AsyncResponse returns the struct to unmarshal the async job
func ( CreateAffinityGroup ) AsyncResponse ( ) interface { } {
2018-09-14 10:06:03 +02:00
return new ( AffinityGroup )
2018-02-12 18:10:05 +01:00
}
// UpdateVMAffinityGroup (Async) represents a modification of a (anti-)affinity group
type UpdateVMAffinityGroup struct {
2018-09-14 10:06:03 +02:00
ID * UUID ` json:"id" doc:"The ID of the virtual machine" `
AffinityGroupIDs [ ] UUID ` json:"affinitygroupids,omitempty" doc:"comma separated list of affinity groups id that are going to be applied to the virtual machine. Should be passed only when vm is created from a zone with Basic Network support. Mutually exclusive with securitygroupnames parameter" `
AffinityGroupNames [ ] string ` json:"affinitygroupnames,omitempty" doc:"comma separated list of affinity groups names that are going to be applied to the virtual machine. Should be passed only when vm is created from a zone with Basic Network support. Mutually exclusive with securitygroupids parameter" `
_ bool ` name:"updateVMAffinityGroup" description:"Updates the affinity/anti-affinity group associations of a virtual machine. The VM has to be stopped and restarted for the new properties to take effect." `
2018-02-12 18:10:05 +01:00
}
2018-09-14 10:06:03 +02:00
func ( req UpdateVMAffinityGroup ) onBeforeSend ( params url . Values ) error {
2018-02-12 18:10:05 +01:00
// Either AffinityGroupIDs or AffinityGroupNames must be set
if len ( req . AffinityGroupIDs ) == 0 && len ( req . AffinityGroupNames ) == 0 {
params . Set ( "affinitygroupids" , "" )
}
return nil
}
2019-03-14 11:04:04 +01:00
// Response returns the struct to unmarshal
func ( UpdateVMAffinityGroup ) Response ( ) interface { } {
2018-09-14 10:06:03 +02:00
return new ( AsyncJobResult )
}
2019-03-14 11:04:04 +01:00
// AsyncResponse returns the struct to unmarshal the async job
func ( UpdateVMAffinityGroup ) AsyncResponse ( ) interface { } {
2018-09-14 10:06:03 +02:00
return new ( VirtualMachine )
}
2018-02-12 18:10:05 +01:00
// DeleteAffinityGroup (Async) represents an (anti-)affinity group to be deleted
type DeleteAffinityGroup struct {
2019-03-14 11:04:04 +01:00
ID * UUID ` json:"id,omitempty" doc:"The ID of the affinity group. Mutually exclusive with name parameter" `
Name string ` json:"name,omitempty" doc:"The name of the affinity group. Mutually exclusive with ID parameter" `
_ bool ` name:"deleteAffinityGroup" description:"Deletes affinity group" `
2018-02-12 18:10:05 +01:00
}
2019-03-14 11:04:04 +01:00
// Response returns the struct to unmarshal
func ( DeleteAffinityGroup ) Response ( ) interface { } {
2018-09-14 10:06:03 +02:00
return new ( AsyncJobResult )
2018-02-12 18:10:05 +01:00
}
2019-03-14 11:04:04 +01:00
// AsyncResponse returns the struct to unmarshal the async job
func ( DeleteAffinityGroup ) AsyncResponse ( ) interface { } {
return new ( BooleanResponse )
2018-02-12 18:10:05 +01:00
}
2019-03-14 11:04:04 +01:00
//go:generate go run generate/main.go -interface=Listable ListAffinityGroups
2018-02-12 18:10:05 +01:00
// ListAffinityGroups represents an (anti-)affinity groups search
type ListAffinityGroups struct {
2019-03-14 11:04:04 +01:00
ID * UUID ` json:"id,omitempty" doc:"List the affinity group by the ID provided" `
2018-09-14 10:06:03 +02:00
Keyword string ` json:"keyword,omitempty" doc:"List by keyword" `
2019-03-14 11:04:04 +01:00
Name string ` json:"name,omitempty" doc:"Lists affinity groups by name" `
2018-02-12 18:10:05 +01:00
Page int ` json:"page,omitempty" `
PageSize int ` json:"pagesize,omitempty" `
2019-03-14 11:04:04 +01:00
Type string ` json:"type,omitempty" doc:"Lists affinity groups by type" `
VirtualMachineID * UUID ` json:"virtualmachineid,omitempty" doc:"Lists affinity groups by virtual machine ID" `
2018-09-14 10:06:03 +02:00
_ bool ` name:"listAffinityGroups" description:"Lists affinity groups" `
2018-02-12 18:10:05 +01:00
}
// ListAffinityGroupsResponse represents a list of (anti-)affinity groups
type ListAffinityGroupsResponse struct {
Count int ` json:"count" `
AffinityGroup [ ] AffinityGroup ` json:"affinitygroup" `
}
2018-09-14 10:06:03 +02:00
// ListAffinityGroupTypes represents an (anti-)affinity groups search
type ListAffinityGroupTypes struct {
Keyword string ` json:"keyword,omitempty" doc:"List by keyword" `
Page int ` json:"page,omitempty" `
PageSize int ` json:"pagesize,omitempty" `
_ bool ` name:"listAffinityGroupTypes" description:"Lists affinity group types available" `
2018-02-12 18:10:05 +01:00
}
2019-03-14 11:04:04 +01:00
// Response returns the struct to unmarshal
func ( ListAffinityGroupTypes ) Response ( ) interface { } {
2018-09-14 10:06:03 +02:00
return new ( ListAffinityGroupTypesResponse )
2018-02-12 18:10:05 +01:00
}
2018-09-14 10:06:03 +02:00
// ListAffinityGroupTypesResponse represents a list of (anti-)affinity group types
type ListAffinityGroupTypesResponse struct {
Count int ` json:"count" `
AffinityGroupType [ ] AffinityGroupType ` json:"affinitygrouptype" `
2018-02-12 18:10:05 +01:00
}