|  | package instances | 
|  |  | 
|  | import ( | 
|  | "github.com/gophercloud/gophercloud" | 
|  | db "gerrit.mcp.mirantis.net/debian/gophercloud.git/openstack/db/v1/databases" | 
|  | "gerrit.mcp.mirantis.net/debian/gophercloud.git/openstack/db/v1/users" | 
|  | "gerrit.mcp.mirantis.net/debian/gophercloud.git/pagination" | 
|  | ) | 
|  |  | 
|  | // CreateOptsBuilder is the top-level interface for create options. | 
|  | type CreateOptsBuilder interface { | 
|  | ToInstanceCreateMap() (map[string]interface{}, error) | 
|  | } | 
|  |  | 
|  | // DatastoreOpts represents the configuration for how an instance stores data. | 
|  | type DatastoreOpts struct { | 
|  | Version string `json:"version"` | 
|  | Type    string `json:"type"` | 
|  | } | 
|  |  | 
|  | // ToMap converts a DatastoreOpts to a map[string]string (for a request body) | 
|  | func (opts DatastoreOpts) ToMap() (map[string]interface{}, error) { | 
|  | return gophercloud.BuildRequestBody(opts, "") | 
|  | } | 
|  |  | 
|  | // NetworkOpts is used within CreateOpts to control a new server's network attachments. | 
|  | type NetworkOpts struct { | 
|  | // UUID of a nova-network to attach to the newly provisioned server. | 
|  | // Required unless Port is provided. | 
|  | UUID string `json:"net-id,omitempty"` | 
|  |  | 
|  | // Port of a neutron network to attach to the newly provisioned server. | 
|  | // Required unless UUID is provided. | 
|  | Port string `json:"port-id,omitempty"` | 
|  |  | 
|  | // V4FixedIP [optional] specifies a fixed IPv4 address to be used on this network. | 
|  | V4FixedIP string `json:"v4-fixed-ip,omitempty"` | 
|  |  | 
|  | // V6FixedIP [optional] specifies a fixed IPv6 address to be used on this network. | 
|  | V6FixedIP string `json:"v6-fixed-ip,omitempty"` | 
|  | } | 
|  |  | 
|  | // ToMap converts a NetworkOpts to a map[string]string (for a request body) | 
|  | func (opts NetworkOpts) ToMap() (map[string]interface{}, error) { | 
|  | return gophercloud.BuildRequestBody(opts, "") | 
|  | } | 
|  |  | 
|  | // CreateOpts is the struct responsible for configuring a new database instance. | 
|  | type CreateOpts struct { | 
|  | // Either the integer UUID (in string form) of the flavor, or its URI | 
|  | // reference as specified in the response from the List() call. Required. | 
|  | FlavorRef string | 
|  | // Specifies the volume size in gigabytes (GB). The value must be between 1 | 
|  | // and 300. Required. | 
|  | Size int | 
|  | // Name of the instance to create. The length of the name is limited to | 
|  | // 255 characters and any characters are permitted. Optional. | 
|  | Name string | 
|  | // A slice of database information options. | 
|  | Databases db.CreateOptsBuilder | 
|  | // A slice of user information options. | 
|  | Users users.CreateOptsBuilder | 
|  | // Options to configure the type of datastore the instance will use. This is | 
|  | // optional, and if excluded will default to MySQL. | 
|  | Datastore *DatastoreOpts | 
|  | // Networks dictates how this server will be attached to available networks. | 
|  | Networks []NetworkOpts | 
|  | } | 
|  |  | 
|  | // ToInstanceCreateMap will render a JSON map. | 
|  | func (opts CreateOpts) ToInstanceCreateMap() (map[string]interface{}, error) { | 
|  | if opts.Size > 300 || opts.Size < 1 { | 
|  | err := gophercloud.ErrInvalidInput{} | 
|  | err.Argument = "instances.CreateOpts.Size" | 
|  | err.Value = opts.Size | 
|  | err.Info = "Size (GB) must be between 1-300" | 
|  | return nil, err | 
|  | } | 
|  |  | 
|  | if opts.FlavorRef == "" { | 
|  | return nil, gophercloud.ErrMissingInput{Argument: "instances.CreateOpts.FlavorRef"} | 
|  | } | 
|  |  | 
|  | instance := map[string]interface{}{ | 
|  | "volume":    map[string]int{"size": opts.Size}, | 
|  | "flavorRef": opts.FlavorRef, | 
|  | } | 
|  |  | 
|  | if opts.Name != "" { | 
|  | instance["name"] = opts.Name | 
|  | } | 
|  | if opts.Databases != nil { | 
|  | dbs, err := opts.Databases.ToDBCreateMap() | 
|  | if err != nil { | 
|  | return nil, err | 
|  | } | 
|  | instance["databases"] = dbs["databases"] | 
|  | } | 
|  | if opts.Users != nil { | 
|  | users, err := opts.Users.ToUserCreateMap() | 
|  | if err != nil { | 
|  | return nil, err | 
|  | } | 
|  | instance["users"] = users["users"] | 
|  | } | 
|  | if opts.Datastore != nil { | 
|  | datastore, err := opts.Datastore.ToMap() | 
|  | if err != nil { | 
|  | return nil, err | 
|  | } | 
|  | instance["datastore"] = datastore | 
|  | } | 
|  |  | 
|  | if len(opts.Networks) > 0 { | 
|  | networks := make([]map[string]interface{}, len(opts.Networks)) | 
|  | for i, net := range opts.Networks { | 
|  | var err error | 
|  | networks[i], err = net.ToMap() | 
|  | if err != nil { | 
|  | return nil, err | 
|  | } | 
|  | } | 
|  | instance["nics"] = networks | 
|  | } | 
|  |  | 
|  | return map[string]interface{}{"instance": instance}, nil | 
|  | } | 
|  |  | 
|  | // Create asynchronously provisions a new database instance. It requires the | 
|  | // user to specify a flavor and a volume size. The API service then provisions | 
|  | // the instance with the requested flavor and sets up a volume of the specified | 
|  | // size, which is the storage for the database instance. | 
|  | // | 
|  | // Although this call only allows the creation of 1 instance per request, you | 
|  | // can create an instance with multiple databases and users. The default | 
|  | // binding for a MySQL instance is port 3306. | 
|  | func Create(client *gophercloud.ServiceClient, opts CreateOptsBuilder) (r CreateResult) { | 
|  | b, err := opts.ToInstanceCreateMap() | 
|  | if err != nil { | 
|  | r.Err = err | 
|  | return | 
|  | } | 
|  | _, r.Err = client.Post(baseURL(client), &b, &r.Body, &gophercloud.RequestOpts{OkCodes: []int{200}}) | 
|  | return | 
|  | } | 
|  |  | 
|  | // List retrieves the status and information for all database instances. | 
|  | func List(client *gophercloud.ServiceClient) pagination.Pager { | 
|  | return pagination.NewPager(client, baseURL(client), func(r pagination.PageResult) pagination.Page { | 
|  | return InstancePage{pagination.LinkedPageBase{PageResult: r}} | 
|  | }) | 
|  | } | 
|  |  | 
|  | // Get retrieves the status and information for a specified database instance. | 
|  | func Get(client *gophercloud.ServiceClient, id string) (r GetResult) { | 
|  | _, r.Err = client.Get(resourceURL(client, id), &r.Body, nil) | 
|  | return | 
|  | } | 
|  |  | 
|  | // Delete permanently destroys the database instance. | 
|  | func Delete(client *gophercloud.ServiceClient, id string) (r DeleteResult) { | 
|  | _, r.Err = client.Delete(resourceURL(client, id), nil) | 
|  | return | 
|  | } | 
|  |  | 
|  | // EnableRootUser enables the login from any host for the root user and | 
|  | // provides the user with a generated root password. | 
|  | func EnableRootUser(client *gophercloud.ServiceClient, id string) (r EnableRootUserResult) { | 
|  | _, r.Err = client.Post(userRootURL(client, id), nil, &r.Body, &gophercloud.RequestOpts{OkCodes: []int{200}}) | 
|  | return | 
|  | } | 
|  |  | 
|  | // IsRootEnabled checks an instance to see if root access is enabled. It returns | 
|  | // True if root user is enabled for the specified database instance or False | 
|  | // otherwise. | 
|  | func IsRootEnabled(client *gophercloud.ServiceClient, id string) (r IsRootEnabledResult) { | 
|  | _, r.Err = client.Get(userRootURL(client, id), &r.Body, nil) | 
|  | return | 
|  | } | 
|  |  | 
|  | // Restart will restart only the MySQL Instance. Restarting MySQL will | 
|  | // erase any dynamic configuration settings that you have made within MySQL. | 
|  | // The MySQL service will be unavailable until the instance restarts. | 
|  | func Restart(client *gophercloud.ServiceClient, id string) (r ActionResult) { | 
|  | b := map[string]interface{}{"restart": struct{}{}} | 
|  | _, r.Err = client.Post(actionURL(client, id), &b, nil, nil) | 
|  | return | 
|  | } | 
|  |  | 
|  | // Resize changes the memory size of the instance, assuming a valid | 
|  | // flavorRef is provided. It will also restart the MySQL service. | 
|  | func Resize(client *gophercloud.ServiceClient, id, flavorRef string) (r ActionResult) { | 
|  | b := map[string]interface{}{"resize": map[string]string{"flavorRef": flavorRef}} | 
|  | _, r.Err = client.Post(actionURL(client, id), &b, nil, nil) | 
|  | return | 
|  | } | 
|  |  | 
|  | // ResizeVolume will resize the attached volume for an instance. It supports | 
|  | // only increasing the volume size and does not support decreasing the size. | 
|  | // The volume size is in gigabytes (GB) and must be an integer. | 
|  | func ResizeVolume(client *gophercloud.ServiceClient, id string, size int) (r ActionResult) { | 
|  | b := map[string]interface{}{"resize": map[string]interface{}{"volume": map[string]int{"size": size}}} | 
|  | _, r.Err = client.Post(actionURL(client, id), &b, nil, nil) | 
|  | return | 
|  | } |