blob: 90a176aeddce3dcdc0f65dff65d48827082cb0e1 [file] [log] [blame]
package users
import (
"gerrit.mcp.mirantis.net/debian/gophercloud.git"
db "gerrit.mcp.mirantis.net/debian/gophercloud.git/openstack/db/v1/databases"
"gerrit.mcp.mirantis.net/debian/gophercloud.git/pagination"
)
// User represents a database user
type User struct {
// The user name
Name string
// The user password
Password string
// The databases associated with this user
Databases []db.Database
}
// CreateResult represents the result of a create operation.
type CreateResult struct {
gophercloud.ErrResult
}
// DeleteResult represents the result of a delete operation.
type DeleteResult struct {
gophercloud.ErrResult
}
// UserPage represents a single page of a paginated user collection.
type UserPage struct {
pagination.LinkedPageBase
}
// IsEmpty checks to see whether the collection is empty.
func (page UserPage) IsEmpty() (bool, error) {
users, err := ExtractUsers(page)
return len(users) == 0, err
}
// NextPageURL will retrieve the next page URL.
func (page UserPage) NextPageURL() (string, error) {
var s struct {
Links []gophercloud.Link `json:"users_links"`
}
err := page.ExtractInto(&s)
if err != nil {
return "", err
}
return gophercloud.ExtractNextURL(s.Links)
}
// ExtractUsers will convert a generic pagination struct into a more
// relevant slice of User structs.
func ExtractUsers(r pagination.Page) ([]User, error) {
var s struct {
Users []User `json:"users"`
}
err := (r.(UserPage)).ExtractInto(&s)
return s.Users, err
}