vendor: Updating Gophercloud
This commit is contained in:
parent
52dff703ad
commit
02eda6f0c9
28
vendor/github.com/gophercloud/gophercloud/openstack/imageservice/v2/imagedata/requests.go
generated
vendored
Normal file
28
vendor/github.com/gophercloud/gophercloud/openstack/imageservice/v2/imagedata/requests.go
generated
vendored
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
package imagedata
|
||||||
|
|
||||||
|
import (
|
||||||
|
"io"
|
||||||
|
"net/http"
|
||||||
|
|
||||||
|
"github.com/gophercloud/gophercloud"
|
||||||
|
)
|
||||||
|
|
||||||
|
// Upload uploads image file
|
||||||
|
func Upload(client *gophercloud.ServiceClient, id string, data io.ReadSeeker) (r UploadResult) {
|
||||||
|
_, r.Err = client.Put(uploadURL(client, id), data, nil, &gophercloud.RequestOpts{
|
||||||
|
MoreHeaders: map[string]string{"Content-Type": "application/octet-stream"},
|
||||||
|
OkCodes: []int{204},
|
||||||
|
})
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
// Download retrieves file
|
||||||
|
func Download(client *gophercloud.ServiceClient, id string) (r DownloadResult) {
|
||||||
|
var resp *http.Response
|
||||||
|
resp, r.Err = client.Get(downloadURL(client, id), nil, nil)
|
||||||
|
if resp != nil {
|
||||||
|
r.Body = resp.Body
|
||||||
|
r.Header = resp.Header
|
||||||
|
}
|
||||||
|
return
|
||||||
|
}
|
26
vendor/github.com/gophercloud/gophercloud/openstack/imageservice/v2/imagedata/results.go
generated
vendored
Normal file
26
vendor/github.com/gophercloud/gophercloud/openstack/imageservice/v2/imagedata/results.go
generated
vendored
Normal file
|
@ -0,0 +1,26 @@
|
||||||
|
package imagedata
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"io"
|
||||||
|
|
||||||
|
"github.com/gophercloud/gophercloud"
|
||||||
|
)
|
||||||
|
|
||||||
|
// UploadResult is the result of an upload image operation
|
||||||
|
type UploadResult struct {
|
||||||
|
gophercloud.ErrResult
|
||||||
|
}
|
||||||
|
|
||||||
|
// DownloadResult is the result of a download image operation
|
||||||
|
type DownloadResult struct {
|
||||||
|
gophercloud.Result
|
||||||
|
}
|
||||||
|
|
||||||
|
// Extract builds images model from io.Reader
|
||||||
|
func (r DownloadResult) Extract() (io.Reader, error) {
|
||||||
|
if r, ok := r.Body.(io.Reader); ok {
|
||||||
|
return r, nil
|
||||||
|
}
|
||||||
|
return nil, fmt.Errorf("Expected io.Reader but got: %T(%#v)", r.Body, r.Body)
|
||||||
|
}
|
13
vendor/github.com/gophercloud/gophercloud/openstack/imageservice/v2/imagedata/urls.go
generated
vendored
Normal file
13
vendor/github.com/gophercloud/gophercloud/openstack/imageservice/v2/imagedata/urls.go
generated
vendored
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
package imagedata
|
||||||
|
|
||||||
|
import "github.com/gophercloud/gophercloud"
|
||||||
|
|
||||||
|
// `imageDataURL(c,i)` is the URL for the binary image data for the
|
||||||
|
// image identified by ID `i` in the service `c`.
|
||||||
|
func uploadURL(c *gophercloud.ServiceClient, imageID string) string {
|
||||||
|
return c.ServiceURL("images", imageID, "file")
|
||||||
|
}
|
||||||
|
|
||||||
|
func downloadURL(c *gophercloud.ServiceClient, imageID string) string {
|
||||||
|
return uploadURL(c, imageID)
|
||||||
|
}
|
238
vendor/github.com/gophercloud/gophercloud/openstack/imageservice/v2/images/requests.go
generated
vendored
Normal file
238
vendor/github.com/gophercloud/gophercloud/openstack/imageservice/v2/images/requests.go
generated
vendored
Normal file
|
@ -0,0 +1,238 @@
|
||||||
|
package images
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/gophercloud/gophercloud"
|
||||||
|
"github.com/gophercloud/gophercloud/pagination"
|
||||||
|
)
|
||||||
|
|
||||||
|
// ListOptsBuilder allows extensions to add additional parameters to the
|
||||||
|
// List request.
|
||||||
|
type ListOptsBuilder interface {
|
||||||
|
ToImageListQuery() (string, error)
|
||||||
|
}
|
||||||
|
|
||||||
|
// 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.
|
||||||
|
//http://developer.openstack.org/api-ref-image-v2.html
|
||||||
|
type ListOpts struct {
|
||||||
|
// Integer value for the limit of values to return.
|
||||||
|
Limit int `q:"limit"`
|
||||||
|
|
||||||
|
// UUID of the server at which you want to set a marker.
|
||||||
|
Marker string `q:"marker"`
|
||||||
|
|
||||||
|
Name string `q:"name"`
|
||||||
|
Visibility ImageVisibility `q:"visibility"`
|
||||||
|
MemberStatus ImageMemberStatus `q:"member_status"`
|
||||||
|
Owner string `q:"owner"`
|
||||||
|
Status ImageStatus `q:"status"`
|
||||||
|
SizeMin int64 `q:"size_min"`
|
||||||
|
SizeMax int64 `q:"size_max"`
|
||||||
|
SortKey string `q:"sort_key"`
|
||||||
|
SortDir string `q:"sort_dir"`
|
||||||
|
Tag string `q:"tag"`
|
||||||
|
}
|
||||||
|
|
||||||
|
// ToImageListQuery formats a ListOpts into a query string.
|
||||||
|
func (opts ListOpts) ToImageListQuery() (string, error) {
|
||||||
|
q, err := gophercloud.BuildQueryString(opts)
|
||||||
|
return q.String(), err
|
||||||
|
}
|
||||||
|
|
||||||
|
// List implements image list request
|
||||||
|
func List(c *gophercloud.ServiceClient, opts ListOptsBuilder) pagination.Pager {
|
||||||
|
url := listURL(c)
|
||||||
|
if opts != nil {
|
||||||
|
query, err := opts.ToImageListQuery()
|
||||||
|
if err != nil {
|
||||||
|
return pagination.Pager{Err: err}
|
||||||
|
}
|
||||||
|
url += query
|
||||||
|
}
|
||||||
|
return pagination.NewPager(c, url, func(r pagination.PageResult) pagination.Page {
|
||||||
|
return ImagePage{pagination.LinkedPageBase{PageResult: r}}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
// CreateOptsBuilder describes struct types that can be accepted by the Create call.
|
||||||
|
// The CreateOpts struct in this package does.
|
||||||
|
type CreateOptsBuilder interface {
|
||||||
|
// Returns value that can be passed to json.Marshal
|
||||||
|
ToImageCreateMap() (map[string]interface{}, error)
|
||||||
|
}
|
||||||
|
|
||||||
|
// CreateOpts implements CreateOptsBuilder
|
||||||
|
type CreateOpts struct {
|
||||||
|
// Name is the name of the new image.
|
||||||
|
Name string `json:"name" required:"true"`
|
||||||
|
|
||||||
|
// Id is the the image ID.
|
||||||
|
ID string `json:"id,omitempty"`
|
||||||
|
|
||||||
|
// Visibility defines who can see/use the image.
|
||||||
|
Visibility *ImageVisibility `json:"visibility,omitempty"`
|
||||||
|
|
||||||
|
// Tags is a set of image tags.
|
||||||
|
Tags []string `json:"tags,omitempty"`
|
||||||
|
|
||||||
|
// ContainerFormat is the format of the
|
||||||
|
// container. Valid values are ami, ari, aki, bare, and ovf.
|
||||||
|
ContainerFormat string `json:"container_format,omitempty"`
|
||||||
|
|
||||||
|
// DiskFormat is the format of the disk. If set,
|
||||||
|
// valid values are ami, ari, aki, vhd, vmdk, raw, qcow2, vdi,
|
||||||
|
// and iso.
|
||||||
|
DiskFormat string `json:"disk_format,omitempty"`
|
||||||
|
|
||||||
|
// MinDisk is the amount of disk space in
|
||||||
|
// GB that is required to boot the image.
|
||||||
|
MinDisk int `json:"min_disk,omitempty"`
|
||||||
|
|
||||||
|
// MinRAM is the amount of RAM in MB that
|
||||||
|
// is required to boot the image.
|
||||||
|
MinRAM int `json:"min_ram,omitempty"`
|
||||||
|
|
||||||
|
// protected is whether the image is not deletable.
|
||||||
|
Protected *bool `json:"protected,omitempty"`
|
||||||
|
|
||||||
|
// properties is a set of properties, if any, that
|
||||||
|
// are associated with the image.
|
||||||
|
Properties map[string]string `json:"-,omitempty"`
|
||||||
|
}
|
||||||
|
|
||||||
|
// ToImageCreateMap assembles a request body based on the contents of
|
||||||
|
// a CreateOpts.
|
||||||
|
func (opts CreateOpts) ToImageCreateMap() (map[string]interface{}, error) {
|
||||||
|
b, err := gophercloud.BuildRequestBody(opts, "")
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
if opts.Properties != nil {
|
||||||
|
for k, v := range opts.Properties {
|
||||||
|
b[k] = v
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return b, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// Create implements create image request
|
||||||
|
func Create(client *gophercloud.ServiceClient, opts CreateOptsBuilder) (r CreateResult) {
|
||||||
|
b, err := opts.ToImageCreateMap()
|
||||||
|
if err != nil {
|
||||||
|
r.Err = err
|
||||||
|
return r
|
||||||
|
}
|
||||||
|
_, r.Err = client.Post(createURL(client), b, &r.Body, &gophercloud.RequestOpts{OkCodes: []int{201}})
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
// Delete implements image delete request
|
||||||
|
func Delete(client *gophercloud.ServiceClient, id string) (r DeleteResult) {
|
||||||
|
_, r.Err = client.Delete(deleteURL(client, id), nil)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get implements image get request
|
||||||
|
func Get(client *gophercloud.ServiceClient, id string) (r GetResult) {
|
||||||
|
_, r.Err = client.Get(getURL(client, id), &r.Body, nil)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
// Update implements image updated request
|
||||||
|
func Update(client *gophercloud.ServiceClient, id string, opts UpdateOptsBuilder) (r UpdateResult) {
|
||||||
|
b, err := opts.ToImageUpdateMap()
|
||||||
|
if err != nil {
|
||||||
|
r.Err = err
|
||||||
|
return r
|
||||||
|
}
|
||||||
|
_, r.Err = client.Patch(updateURL(client, id), b, &r.Body, &gophercloud.RequestOpts{
|
||||||
|
OkCodes: []int{200},
|
||||||
|
MoreHeaders: map[string]string{"Content-Type": "application/openstack-images-v2.1-json-patch"},
|
||||||
|
})
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
// UpdateOptsBuilder implements UpdateOptsBuilder
|
||||||
|
type UpdateOptsBuilder interface {
|
||||||
|
// returns value implementing json.Marshaler which when marshaled matches the patch schema:
|
||||||
|
// http://specs.openstack.org/openstack/glance-specs/specs/api/v2/http-patch-image-api-v2.html
|
||||||
|
ToImageUpdateMap() ([]interface{}, error)
|
||||||
|
}
|
||||||
|
|
||||||
|
// UpdateOpts implements UpdateOpts
|
||||||
|
type UpdateOpts []Patch
|
||||||
|
|
||||||
|
// ToImageUpdateMap builder
|
||||||
|
func (opts UpdateOpts) ToImageUpdateMap() ([]interface{}, error) {
|
||||||
|
m := make([]interface{}, len(opts))
|
||||||
|
for i, patch := range opts {
|
||||||
|
patchJSON := patch.ToImagePatchMap()
|
||||||
|
m[i] = patchJSON
|
||||||
|
}
|
||||||
|
return m, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// Patch represents a single update to an existing image. Multiple updates to an image can be
|
||||||
|
// submitted at the same time.
|
||||||
|
type Patch interface {
|
||||||
|
ToImagePatchMap() map[string]interface{}
|
||||||
|
}
|
||||||
|
|
||||||
|
// UpdateVisibility updated visibility
|
||||||
|
type UpdateVisibility struct {
|
||||||
|
Visibility ImageVisibility
|
||||||
|
}
|
||||||
|
|
||||||
|
// ToImagePatchMap builder
|
||||||
|
func (u UpdateVisibility) ToImagePatchMap() map[string]interface{} {
|
||||||
|
return map[string]interface{}{
|
||||||
|
"op": "replace",
|
||||||
|
"path": "/visibility",
|
||||||
|
"value": u.Visibility,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// ReplaceImageName implements Patch
|
||||||
|
type ReplaceImageName struct {
|
||||||
|
NewName string
|
||||||
|
}
|
||||||
|
|
||||||
|
// ToImagePatchMap builder
|
||||||
|
func (r ReplaceImageName) ToImagePatchMap() map[string]interface{} {
|
||||||
|
return map[string]interface{}{
|
||||||
|
"op": "replace",
|
||||||
|
"path": "/name",
|
||||||
|
"value": r.NewName,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// ReplaceImageChecksum implements Patch
|
||||||
|
type ReplaceImageChecksum struct {
|
||||||
|
Checksum string
|
||||||
|
}
|
||||||
|
|
||||||
|
// ReplaceImageChecksum builder
|
||||||
|
func (rc ReplaceImageChecksum) ToImagePatchMap() map[string]interface{} {
|
||||||
|
return map[string]interface{}{
|
||||||
|
"op": "replace",
|
||||||
|
"path": "/checksum",
|
||||||
|
"value": rc.Checksum,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// ReplaceImageTags implements Patch
|
||||||
|
type ReplaceImageTags struct {
|
||||||
|
NewTags []string
|
||||||
|
}
|
||||||
|
|
||||||
|
// ToImagePatchMap builder
|
||||||
|
func (r ReplaceImageTags) ToImagePatchMap() map[string]interface{} {
|
||||||
|
return map[string]interface{}{
|
||||||
|
"op": "replace",
|
||||||
|
"path": "/tags",
|
||||||
|
"value": r.NewTags,
|
||||||
|
}
|
||||||
|
}
|
169
vendor/github.com/gophercloud/gophercloud/openstack/imageservice/v2/images/results.go
generated
vendored
Normal file
169
vendor/github.com/gophercloud/gophercloud/openstack/imageservice/v2/images/results.go
generated
vendored
Normal file
|
@ -0,0 +1,169 @@
|
||||||
|
package images
|
||||||
|
|
||||||
|
import (
|
||||||
|
"encoding/json"
|
||||||
|
"fmt"
|
||||||
|
"reflect"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
"github.com/gophercloud/gophercloud"
|
||||||
|
"github.com/gophercloud/gophercloud/pagination"
|
||||||
|
)
|
||||||
|
|
||||||
|
// Image model
|
||||||
|
// Does not include the literal image data; just metadata.
|
||||||
|
// returned by listing images, and by fetching a specific image.
|
||||||
|
type Image struct {
|
||||||
|
// ID is the image UUID
|
||||||
|
ID string `json:"id"`
|
||||||
|
|
||||||
|
// Name is the human-readable display name for the image.
|
||||||
|
Name string `json:"name"`
|
||||||
|
|
||||||
|
// Status is the image status. It can be "queued" or "active"
|
||||||
|
// See imageservice/v2/images/type.go
|
||||||
|
Status ImageStatus `json:"status"`
|
||||||
|
|
||||||
|
// Tags is a list of image tags. Tags are arbitrarily defined strings
|
||||||
|
// attached to an image.
|
||||||
|
Tags []string `json:"tags"`
|
||||||
|
|
||||||
|
// ContainerFormat is the format of the container.
|
||||||
|
// Valid values are ami, ari, aki, bare, and ovf.
|
||||||
|
ContainerFormat string `json:"container_format"`
|
||||||
|
|
||||||
|
// DiskFormat is the format of the disk.
|
||||||
|
// If set, valid values are ami, ari, aki, vhd, vmdk, raw, qcow2, vdi, and iso.
|
||||||
|
DiskFormat string `json:"disk_format"`
|
||||||
|
|
||||||
|
// MinDiskGigabytes is the amount of disk space in GB that is required to boot the image.
|
||||||
|
MinDiskGigabytes int `json:"min_disk"`
|
||||||
|
|
||||||
|
// MinRAMMegabytes [optional] is the amount of RAM in MB that is required to boot the image.
|
||||||
|
MinRAMMegabytes int `json:"min_ram"`
|
||||||
|
|
||||||
|
// Owner is the tenant the image belongs to.
|
||||||
|
Owner string `json:"owner"`
|
||||||
|
|
||||||
|
// Protected is whether the image is deletable or not.
|
||||||
|
Protected bool `json:"protected"`
|
||||||
|
|
||||||
|
// Visibility defines who can see/use the image.
|
||||||
|
Visibility ImageVisibility `json:"visibility"`
|
||||||
|
|
||||||
|
// Checksum is the checksum of the data that's associated with the image
|
||||||
|
Checksum string `json:"checksum"`
|
||||||
|
|
||||||
|
// SizeBytes is the size of the data that's associated with the image.
|
||||||
|
SizeBytes int64 `json:"size"`
|
||||||
|
|
||||||
|
// Metadata is a set of metadata associated with the image.
|
||||||
|
// Image metadata allow for meaningfully define the image properties
|
||||||
|
// and tags. See http://docs.openstack.org/developer/glance/metadefs-concepts.html.
|
||||||
|
Metadata map[string]string `json:"metadata"`
|
||||||
|
|
||||||
|
// Properties is a set of key-value pairs, if any, that are associated with the image.
|
||||||
|
Properties map[string]string `json:"properties"`
|
||||||
|
|
||||||
|
// CreatedAt is the date when the image has been created.
|
||||||
|
CreatedAt time.Time `json:"created_at"`
|
||||||
|
|
||||||
|
// UpdatedAt is the date when the last change has been made to the image or it's properties.
|
||||||
|
UpdatedAt time.Time `json:"updated_at"`
|
||||||
|
|
||||||
|
// File is the trailing path after the glance endpoint that represent the location
|
||||||
|
// of the image or the path to retrieve it.
|
||||||
|
File string `json:"file"`
|
||||||
|
|
||||||
|
// Schema is the path to the JSON-schema that represent the image or image entity.
|
||||||
|
Schema string `json:"schema"`
|
||||||
|
}
|
||||||
|
|
||||||
|
func (r *Image) UnmarshalJSON(b []byte) error {
|
||||||
|
type tmp Image
|
||||||
|
var s struct {
|
||||||
|
tmp
|
||||||
|
SizeBytes interface{} `json:"size"`
|
||||||
|
}
|
||||||
|
err := json.Unmarshal(b, &s)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
*r = Image(s.tmp)
|
||||||
|
|
||||||
|
switch t := s.SizeBytes.(type) {
|
||||||
|
case nil:
|
||||||
|
return nil
|
||||||
|
case float32:
|
||||||
|
r.SizeBytes = int64(t)
|
||||||
|
case float64:
|
||||||
|
r.SizeBytes = int64(t)
|
||||||
|
default:
|
||||||
|
return fmt.Errorf("Unknown type for SizeBytes: %v (value: %v)", reflect.TypeOf(t), t)
|
||||||
|
}
|
||||||
|
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
type commonResult struct {
|
||||||
|
gophercloud.Result
|
||||||
|
}
|
||||||
|
|
||||||
|
// Extract interprets any commonResult as an Image.
|
||||||
|
func (r commonResult) Extract() (*Image, error) {
|
||||||
|
var s *Image
|
||||||
|
err := r.ExtractInto(&s)
|
||||||
|
return s, err
|
||||||
|
}
|
||||||
|
|
||||||
|
// CreateResult represents the result of a Create operation
|
||||||
|
type CreateResult struct {
|
||||||
|
commonResult
|
||||||
|
}
|
||||||
|
|
||||||
|
// UpdateResult represents the result of an Update operation
|
||||||
|
type UpdateResult struct {
|
||||||
|
commonResult
|
||||||
|
}
|
||||||
|
|
||||||
|
// GetResult represents the result of a Get operation
|
||||||
|
type GetResult struct {
|
||||||
|
commonResult
|
||||||
|
}
|
||||||
|
|
||||||
|
//DeleteResult model
|
||||||
|
type DeleteResult struct {
|
||||||
|
gophercloud.ErrResult
|
||||||
|
}
|
||||||
|
|
||||||
|
// ImagePage represents page
|
||||||
|
type ImagePage struct {
|
||||||
|
pagination.LinkedPageBase
|
||||||
|
}
|
||||||
|
|
||||||
|
// IsEmpty returns true if a page contains no Images results.
|
||||||
|
func (r ImagePage) IsEmpty() (bool, error) {
|
||||||
|
images, err := ExtractImages(r)
|
||||||
|
return len(images) == 0, err
|
||||||
|
}
|
||||||
|
|
||||||
|
// NextPageURL uses the response's embedded link reference to navigate to the next page of results.
|
||||||
|
func (r ImagePage) NextPageURL() (string, error) {
|
||||||
|
var s struct {
|
||||||
|
Next string `json:"next"`
|
||||||
|
}
|
||||||
|
err := r.ExtractInto(&s)
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
return nextPageURL(r.URL.String(), s.Next), nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// ExtractImages interprets the results of a single page from a List() call, producing a slice of Image entities.
|
||||||
|
func ExtractImages(r pagination.Page) ([]Image, error) {
|
||||||
|
var s struct {
|
||||||
|
Images []Image `json:"images"`
|
||||||
|
}
|
||||||
|
err := (r.(ImagePage)).ExtractInto(&s)
|
||||||
|
return s.Images, err
|
||||||
|
}
|
75
vendor/github.com/gophercloud/gophercloud/openstack/imageservice/v2/images/types.go
generated
vendored
Normal file
75
vendor/github.com/gophercloud/gophercloud/openstack/imageservice/v2/images/types.go
generated
vendored
Normal file
|
@ -0,0 +1,75 @@
|
||||||
|
package images
|
||||||
|
|
||||||
|
// ImageStatus image statuses
|
||||||
|
// http://docs.openstack.org/developer/glance/statuses.html
|
||||||
|
type ImageStatus string
|
||||||
|
|
||||||
|
const (
|
||||||
|
// ImageStatusQueued is a status for an image which identifier has
|
||||||
|
// been reserved for an image in the image registry.
|
||||||
|
ImageStatusQueued ImageStatus = "queued"
|
||||||
|
|
||||||
|
// ImageStatusSaving denotes that an image’s raw data is currently being uploaded to Glance
|
||||||
|
ImageStatusSaving ImageStatus = "saving"
|
||||||
|
|
||||||
|
// ImageStatusActive denotes an image that is fully available in Glance.
|
||||||
|
ImageStatusActive ImageStatus = "active"
|
||||||
|
|
||||||
|
// ImageStatusKilled denotes that an error occurred during the uploading
|
||||||
|
// of an image’s data, and that the image is not readable.
|
||||||
|
ImageStatusKilled ImageStatus = "killed"
|
||||||
|
|
||||||
|
// ImageStatusDeleted is used for an image that is no longer available to use.
|
||||||
|
// The image information is retained in the image registry.
|
||||||
|
ImageStatusDeleted ImageStatus = "deleted"
|
||||||
|
|
||||||
|
// ImageStatusPendingDelete is similar to Delete, but the image is not yet deleted.
|
||||||
|
ImageStatusPendingDelete ImageStatus = "pending_delete"
|
||||||
|
|
||||||
|
// ImageStatusDeactivated denotes that access to image data is not allowed to any non-admin user.
|
||||||
|
ImageStatusDeactivated ImageStatus = "deactivated"
|
||||||
|
)
|
||||||
|
|
||||||
|
// ImageVisibility denotes an image that is fully available in Glance.
|
||||||
|
// This occurs when the image data is uploaded, or the image size
|
||||||
|
// is explicitly set to zero on creation.
|
||||||
|
// According to design
|
||||||
|
// https://wiki.openstack.org/wiki/Glance-v2-community-image-visibility-design
|
||||||
|
type ImageVisibility string
|
||||||
|
|
||||||
|
const (
|
||||||
|
// ImageVisibilityPublic all users
|
||||||
|
ImageVisibilityPublic ImageVisibility = "public"
|
||||||
|
|
||||||
|
// ImageVisibilityPrivate users with tenantId == tenantId(owner)
|
||||||
|
ImageVisibilityPrivate ImageVisibility = "private"
|
||||||
|
|
||||||
|
// ImageVisibilityShared images are visible to:
|
||||||
|
// - users with tenantId == tenantId(owner)
|
||||||
|
// - users with tenantId in the member-list of the image
|
||||||
|
// - users with tenantId in the member-list with member_status == 'accepted'
|
||||||
|
ImageVisibilityShared ImageVisibility = "shared"
|
||||||
|
|
||||||
|
// ImageVisibilityCommunity images:
|
||||||
|
// - all users can see and boot it
|
||||||
|
// - users with tenantId in the member-list of the image with member_status == 'accepted'
|
||||||
|
// have this image in their default image-list
|
||||||
|
ImageVisibilityCommunity ImageVisibility = "community"
|
||||||
|
)
|
||||||
|
|
||||||
|
// MemberStatus is a status for adding a new member (tenant) to an image member list.
|
||||||
|
type ImageMemberStatus string
|
||||||
|
|
||||||
|
const (
|
||||||
|
// ImageMemberStatusAccepted is the status for an accepted image member.
|
||||||
|
ImageMemberStatusAccepted ImageMemberStatus = "accepted"
|
||||||
|
|
||||||
|
// ImageMemberStatusPending shows that the member addition is pending
|
||||||
|
ImageMemberStatusPending ImageMemberStatus = "pending"
|
||||||
|
|
||||||
|
// ImageMemberStatusAccepted is the status for a rejected image member
|
||||||
|
ImageMemberStatusRejected ImageMemberStatus = "rejected"
|
||||||
|
|
||||||
|
// ImageMemberStatusAll
|
||||||
|
ImageMemberStatusAll ImageMemberStatus = "all"
|
||||||
|
)
|
44
vendor/github.com/gophercloud/gophercloud/openstack/imageservice/v2/images/urls.go
generated
vendored
Normal file
44
vendor/github.com/gophercloud/gophercloud/openstack/imageservice/v2/images/urls.go
generated
vendored
Normal file
|
@ -0,0 +1,44 @@
|
||||||
|
package images
|
||||||
|
|
||||||
|
import (
|
||||||
|
"strings"
|
||||||
|
|
||||||
|
"github.com/gophercloud/gophercloud"
|
||||||
|
)
|
||||||
|
|
||||||
|
// `listURL` is a pure function. `listURL(c)` is a URL for which a GET
|
||||||
|
// request will respond with a list of images in the service `c`.
|
||||||
|
func listURL(c *gophercloud.ServiceClient) string {
|
||||||
|
return c.ServiceURL("images")
|
||||||
|
}
|
||||||
|
|
||||||
|
func createURL(c *gophercloud.ServiceClient) string {
|
||||||
|
return c.ServiceURL("images")
|
||||||
|
}
|
||||||
|
|
||||||
|
// `imageURL(c,i)` is the URL for the image identified by ID `i` in
|
||||||
|
// the service `c`.
|
||||||
|
func imageURL(c *gophercloud.ServiceClient, imageID string) string {
|
||||||
|
return c.ServiceURL("images", imageID)
|
||||||
|
}
|
||||||
|
|
||||||
|
// `getURL(c,i)` is a URL for which a GET request will respond with
|
||||||
|
// information about the image identified by ID `i` in the service
|
||||||
|
// `c`.
|
||||||
|
func getURL(c *gophercloud.ServiceClient, imageID string) string {
|
||||||
|
return imageURL(c, imageID)
|
||||||
|
}
|
||||||
|
|
||||||
|
func updateURL(c *gophercloud.ServiceClient, imageID string) string {
|
||||||
|
return imageURL(c, imageID)
|
||||||
|
}
|
||||||
|
|
||||||
|
func deleteURL(c *gophercloud.ServiceClient, imageID string) string {
|
||||||
|
return imageURL(c, imageID)
|
||||||
|
}
|
||||||
|
|
||||||
|
// builds next page full url based on current url
|
||||||
|
func nextPageURL(currentURL string, next string) string {
|
||||||
|
base := currentURL[:strings.Index(currentURL, "/images")]
|
||||||
|
return base + next
|
||||||
|
}
|
|
@ -1433,6 +1433,18 @@
|
||||||
"revision": "ed2f96ce05eb76a9fe89e671467ebf1818f49234",
|
"revision": "ed2f96ce05eb76a9fe89e671467ebf1818f49234",
|
||||||
"revisionTime": "2017-01-20T19:02:54Z"
|
"revisionTime": "2017-01-20T19:02:54Z"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"checksumSHA1": "ApyhoqnMmvOyj4SVmCAMEPRt0CY=",
|
||||||
|
"path": "github.com/gophercloud/gophercloud/openstack/imageservice/v2/imagedata",
|
||||||
|
"revision": "b06120d13e262ceaf890ef38ee30898813696af0",
|
||||||
|
"revisionTime": "2017-02-14T04:36:15Z"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"checksumSHA1": "suBNiSHEsfnRAY+kGSGg0P2TaUQ=",
|
||||||
|
"path": "github.com/gophercloud/gophercloud/openstack/imageservice/v2/images",
|
||||||
|
"revision": "b06120d13e262ceaf890ef38ee30898813696af0",
|
||||||
|
"revisionTime": "2017-02-14T04:36:15Z"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"checksumSHA1": "aTHxjMlfNXFJ3l2TZyvIwqt/3kM=",
|
"checksumSHA1": "aTHxjMlfNXFJ3l2TZyvIwqt/3kM=",
|
||||||
"path": "github.com/gophercloud/gophercloud/openstack/networking/v2/extensions/fwaas/firewalls",
|
"path": "github.com/gophercloud/gophercloud/openstack/networking/v2/extensions/fwaas/firewalls",
|
||||||
|
|
Loading…
Reference in New Issue