Blame vendor/github.com/gophercloud/gophercloud/openstack/identity/v2/tenants/results.go

Packit 63bb0d
package tenants
Packit 63bb0d
Packit 63bb0d
import (
Packit 63bb0d
	"github.com/gophercloud/gophercloud"
Packit 63bb0d
	"github.com/gophercloud/gophercloud/pagination"
Packit 63bb0d
)
Packit 63bb0d
Packit 63bb0d
// Tenant is a grouping of users in the identity service.
Packit 63bb0d
type Tenant struct {
Packit 63bb0d
	// ID is a unique identifier for this tenant.
Packit 63bb0d
	ID string `json:"id"`
Packit 63bb0d
Packit 63bb0d
	// Name is a friendlier user-facing name for this tenant.
Packit 63bb0d
	Name string `json:"name"`
Packit 63bb0d
Packit 63bb0d
	// Description is a human-readable explanation of this Tenant's purpose.
Packit 63bb0d
	Description string `json:"description"`
Packit 63bb0d
Packit 63bb0d
	// Enabled indicates whether or not a tenant is active.
Packit 63bb0d
	Enabled bool `json:"enabled"`
Packit 63bb0d
}
Packit 63bb0d
Packit 63bb0d
// TenantPage is a single page of Tenant results.
Packit 63bb0d
type TenantPage struct {
Packit 63bb0d
	pagination.LinkedPageBase
Packit 63bb0d
}
Packit 63bb0d
Packit 63bb0d
// IsEmpty determines whether or not a page of Tenants contains any results.
Packit 63bb0d
func (r TenantPage) IsEmpty() (bool, error) {
Packit 63bb0d
	tenants, err := ExtractTenants(r)
Packit 63bb0d
	return len(tenants) == 0, err
Packit 63bb0d
}
Packit 63bb0d
Packit 63bb0d
// NextPageURL extracts the "next" link from the tenants_links section of the result.
Packit 63bb0d
func (r TenantPage) NextPageURL() (string, error) {
Packit 63bb0d
	var s struct {
Packit 63bb0d
		Links []gophercloud.Link `json:"tenants_links"`
Packit 63bb0d
	}
Packit 63bb0d
	err := r.ExtractInto(&s)
Packit 63bb0d
	if err != nil {
Packit 63bb0d
		return "", err
Packit 63bb0d
	}
Packit 63bb0d
	return gophercloud.ExtractNextURL(s.Links)
Packit 63bb0d
}
Packit 63bb0d
Packit 63bb0d
// ExtractTenants returns a slice of Tenants contained in a single page of
Packit 63bb0d
// results.
Packit 63bb0d
func ExtractTenants(r pagination.Page) ([]Tenant, error) {
Packit 63bb0d
	var s struct {
Packit 63bb0d
		Tenants []Tenant `json:"tenants"`
Packit 63bb0d
	}
Packit 63bb0d
	err := (r.(TenantPage)).ExtractInto(&s)
Packit 63bb0d
	return s.Tenants, err
Packit 63bb0d
}
Packit 63bb0d
Packit 63bb0d
type tenantResult struct {
Packit 63bb0d
	gophercloud.Result
Packit 63bb0d
}
Packit 63bb0d
Packit 63bb0d
// Extract interprets any tenantResults as a Tenant.
Packit 63bb0d
func (r tenantResult) Extract() (*Tenant, error) {
Packit 63bb0d
	var s struct {
Packit 63bb0d
		Tenant *Tenant `json:"tenant"`
Packit 63bb0d
	}
Packit 63bb0d
	err := r.ExtractInto(&s)
Packit 63bb0d
	return s.Tenant, err
Packit 63bb0d
}
Packit 63bb0d
Packit 63bb0d
// GetResult is the response from a Get request. Call its Extract method to
Packit 63bb0d
// interpret it as a Tenant.
Packit 63bb0d
type GetResult struct {
Packit 63bb0d
	tenantResult
Packit 63bb0d
}
Packit 63bb0d
Packit 63bb0d
// CreateResult is the response from a Create request. Call its Extract method
Packit 63bb0d
// to interpret it as a Tenant.
Packit 63bb0d
type CreateResult struct {
Packit 63bb0d
	tenantResult
Packit 63bb0d
}
Packit 63bb0d
Packit 63bb0d
// DeleteResult is the response from a Get request. Call its ExtractErr method
Packit 63bb0d
// to determine if the call succeeded or failed.
Packit 63bb0d
type DeleteResult struct {
Packit 63bb0d
	gophercloud.ErrResult
Packit 63bb0d
}
Packit 63bb0d
Packit 63bb0d
// UpdateResult is the response from a Update request. Call its Extract method
Packit 63bb0d
// to interpret it as a Tenant.
Packit 63bb0d
type UpdateResult struct {
Packit 63bb0d
	tenantResult
Packit 63bb0d
}