| package extensions |
| |
| import ( |
| "github.com/gophercloud/gophercloud" |
| common "github.com/gophercloud/gophercloud/openstack/common/extensions" |
| "github.com/gophercloud/gophercloud/pagination" |
| ) |
| |
| // ExtensionPage is a single page of Extension results. |
| type ExtensionPage struct { |
| common.ExtensionPage |
| } |
| |
| // IsEmpty returns true if the current page contains at least one Extension. |
| func (page ExtensionPage) IsEmpty() (bool, error) { |
| is, err := ExtractExtensions(page) |
| if err != nil { |
| return true, err |
| } |
| return len(is) == 0, nil |
| } |
| |
| // ExtractExtensions accepts a Page struct, specifically an ExtensionPage struct, and extracts the |
| // elements into a slice of Extension structs. |
| func ExtractExtensions(page pagination.Page) ([]common.Extension, error) { |
| r := page.(ExtensionPage) |
| // Identity v2 adds an intermediate "values" object. |
| var s struct { |
| Extensions struct { |
| Values []common.Extension `json:"values"` |
| } `json:"extensions"` |
| } |
| err := r.ExtractInto(&s) |
| return s.Extensions.Values, err |
| } |
| |
| // Get retrieves information for a specific extension using its alias. |
| func Get(c *gophercloud.ServiceClient, alias string) common.GetResult { |
| return common.Get(c, alias) |
| } |
| |
| // List returns a Pager which allows you to iterate over the full collection of extensions. |
| // It does not accept query parameters. |
| func List(c *gophercloud.ServiceClient) pagination.Pager { |
| return common.List(c).WithPageCreator(func(r pagination.PageResult) pagination.Page { |
| return ExtensionPage{ |
| ExtensionPage: common.ExtensionPage{SinglePageBase: pagination.SinglePageBase(r)}, |
| } |
| }) |
| } |