| package snapshots |
| |
| import ( |
| "fmt" |
| |
| "github.com/rackspace/gophercloud" |
| "github.com/rackspace/gophercloud/pagination" |
| |
| "github.com/racker/perigee" |
| ) |
| |
| // CreateOptsBuilder allows extensions to add additional parameters to the |
| // Create request. |
| type CreateOptsBuilder interface { |
| ToSnapshotCreateMap() (map[string]interface{}, error) |
| } |
| |
| // CreateOpts contains options for creating a Snapshot. This object is passed to |
| // the snapshots.Create function. For more information about these parameters, |
| // see the Snapshot object. |
| type CreateOpts struct { |
| // OPTIONAL |
| Description string |
| // OPTIONAL |
| Force bool |
| // OPTIONAL |
| Metadata map[string]interface{} |
| // OPTIONAL |
| Name string |
| // REQUIRED |
| VolumeID string |
| } |
| |
| // ToSnapshotCreateMap assembles a request body based on the contents of a |
| // CreateOpts. |
| func (opts CreateOpts) ToSnapshotCreateMap() (map[string]interface{}, error) { |
| s := make(map[string]interface{}) |
| |
| if opts.VolumeID == "" { |
| return nil, fmt.Errorf("Required CreateOpts field 'VolumeID' not set.") |
| } |
| s["volume_id"] = opts.VolumeID |
| |
| if opts.Description != "" { |
| s["display_description"] = opts.Description |
| } |
| if opts.Force == true { |
| s["force"] = opts.Force |
| } |
| if opts.Metadata != nil { |
| s["metadata"] = opts.Metadata |
| } |
| if opts.Name != "" { |
| s["display_name"] = opts.Name |
| } |
| |
| return map[string]interface{}{"snapshot": s}, nil |
| } |
| |
| // Create will create a new Snapshot based on the values in CreateOpts. To |
| // extract the Snapshot object from the response, call the Extract method on the |
| // CreateResult. |
| func Create(client *gophercloud.ServiceClient, opts CreateOptsBuilder) CreateResult { |
| var res CreateResult |
| |
| reqBody, err := opts.ToSnapshotCreateMap() |
| if err != nil { |
| res.Err = err |
| return res |
| } |
| |
| _, res.Err = perigee.Request("POST", createURL(client), perigee.Options{ |
| MoreHeaders: client.Provider.AuthenticatedHeaders(), |
| OkCodes: []int{200, 201}, |
| ReqBody: &reqBody, |
| Results: &res.Body, |
| }) |
| return res |
| } |
| |
| // Delete will delete the existing Snapshot with the provided ID. |
| func Delete(client *gophercloud.ServiceClient, id string) error { |
| _, err := perigee.Request("DELETE", deleteURL(client, id), perigee.Options{ |
| MoreHeaders: client.Provider.AuthenticatedHeaders(), |
| OkCodes: []int{202, 204}, |
| }) |
| return err |
| } |
| |
| // Get retrieves the Snapshot with the provided ID. To extract the Snapshot |
| // object from the response, call the Extract method on the GetResult. |
| func Get(client *gophercloud.ServiceClient, id string) GetResult { |
| var res GetResult |
| _, res.Err = perigee.Request("GET", getURL(client, id), perigee.Options{ |
| Results: &res.Body, |
| MoreHeaders: client.Provider.AuthenticatedHeaders(), |
| OkCodes: []int{200}, |
| }) |
| return res |
| } |
| |
| // ListOptsBuilder allows extensions to add additional parameters to the List |
| // request. |
| type ListOptsBuilder interface { |
| ToSnapshotListQuery() (string, error) |
| } |
| |
| // ListOpts hold options for listing Snapshots. It is passed to the |
| // snapshots.List function. |
| type ListOpts struct { |
| Name string `q:"display_name"` |
| Status string `q:"status"` |
| VolumeID string `q:"volume_id"` |
| } |
| |
| // ToSnapshotListQuery formats a ListOpts into a query string. |
| func (opts ListOpts) ToSnapshotListQuery() (string, error) { |
| q, err := gophercloud.BuildQueryString(opts) |
| if err != nil { |
| return "", err |
| } |
| return q.String(), nil |
| } |
| |
| // List returns Snapshots optionally limited by the conditions provided in |
| // ListOpts. |
| func List(client *gophercloud.ServiceClient, opts ListOptsBuilder) pagination.Pager { |
| url := listURL(client) |
| if opts != nil { |
| query, err := opts.ToSnapshotListQuery() |
| if err != nil { |
| return pagination.Pager{Err: err} |
| } |
| url += query |
| } |
| |
| createPage := func(r pagination.PageResult) pagination.Page { |
| return ListResult{pagination.SinglePageBase(r)} |
| } |
| return pagination.NewPager(client, url, createPage) |
| } |
| |
| // UpdateMetadataOptsBuilder allows extensions to add additional parameters to |
| // the Update request. |
| type UpdateMetadataOptsBuilder interface { |
| ToSnapshotUpdateMetadataMap() (map[string]interface{}, error) |
| } |
| |
| // UpdateMetadataOpts contain options for updating an existing Snapshot. This |
| // object is passed to the snapshots.Update function. For more information |
| // about the parameters, see the Snapshot object. |
| type UpdateMetadataOpts struct { |
| Metadata map[string]interface{} |
| } |
| |
| // ToSnapshotUpdateMetadataMap assembles a request body based on the contents of |
| // an UpdateMetadataOpts. |
| func (opts UpdateMetadataOpts) ToSnapshotUpdateMetadataMap() (map[string]interface{}, error) { |
| v := make(map[string]interface{}) |
| |
| if opts.Metadata != nil { |
| v["metadata"] = opts.Metadata |
| } |
| |
| return v, nil |
| } |
| |
| // UpdateMetadata will update the Snapshot with provided information. To |
| // extract the updated Snapshot from the response, call the ExtractMetadata |
| // method on the UpdateMetadataResult. |
| func UpdateMetadata(client *gophercloud.ServiceClient, id string, opts UpdateMetadataOptsBuilder) UpdateMetadataResult { |
| var res UpdateMetadataResult |
| |
| reqBody, err := opts.ToSnapshotUpdateMetadataMap() |
| if err != nil { |
| res.Err = err |
| return res |
| } |
| |
| _, res.Err = perigee.Request("PUT", updateMetadataURL(client, id), perigee.Options{ |
| MoreHeaders: client.Provider.AuthenticatedHeaders(), |
| OkCodes: []int{200}, |
| ReqBody: &reqBody, |
| Results: &res.Body, |
| }) |
| return res |
| } |