blob: 9de58b9f7031b06eebe595fbe98df88de2ba3f7c [file] [log] [blame]
package securityservices
import (
"github.com/gophercloud/gophercloud"
"github.com/gophercloud/gophercloud/pagination"
)
type SecurityServiceType string
// Valid security service types
const (
LDAP SecurityServiceType = "ldap"
Kerberos SecurityServiceType = "kerberos"
ActiveDirectory SecurityServiceType = "active_directory"
)
// CreateOptsBuilder allows extensions to add additional parameters to the
// Create request.
type CreateOptsBuilder interface {
ToSecurityServiceCreateMap() (map[string]interface{}, error)
}
// CreateOpts contains options for creating a SecurityService. This object is
// passed to the securityservices.Create function. For more information about
// these parameters, see the SecurityService object.
type CreateOpts struct {
// The security service type. A valid value is ldap, kerberos, or active_directory
Type SecurityServiceType `json:"type" required:"true"`
// The security service name
Name string `json:"name,omitempty"`
// The security service description
Description string `json:"description,omitempty"`
// The DNS IP address that is used inside the tenant network
DNSIP string `json:"dns_ip,omitempty"`
// The security service user or group name that is used by the tenant
User string `json:"user,omitempty"`
// The user password, if you specify a user
Password string `json:"password,omitempty"`
// The security service domain
Domain string `json:"domain,omitempty"`
// The security service host name or IP address
Server string `json:"server,omitempty"`
}
// ToSecurityServicesCreateMap assembles a request body based on the contents of a
// CreateOpts.
func (opts CreateOpts) ToSecurityServiceCreateMap() (map[string]interface{}, error) {
return gophercloud.BuildRequestBody(opts, "security_service")
}
// Create will create a new SecurityService based on the values in CreateOpts. To
// extract the SecurityService object from the response, call the Extract method
// on the CreateResult.
func Create(client *gophercloud.ServiceClient, opts CreateOptsBuilder) (r CreateResult) {
b, err := opts.ToSecurityServiceCreateMap()
if err != nil {
r.Err = err
return
}
_, r.Err = client.Post(createURL(client), b, &r.Body, &gophercloud.RequestOpts{
OkCodes: []int{200},
})
return
}
// Delete will delete the existing SecurityService with the provided ID.
func Delete(client *gophercloud.ServiceClient, id string) (r DeleteResult) {
_, r.Err = client.Delete(deleteURL(client, id), nil)
return
}
// ListOptsBuilder allows extensions to add additional parameters to the List
// request.
type ListOptsBuilder interface {
ToSecurityServiceListQuery() (string, error)
}
// ListOpts holds options for listing SecurityServices. It is passed to the
// securityservices.List function.
type ListOpts struct {
// admin-only option. Set it to true to see all tenant security services.
AllTenants bool `q:"all_tenants"`
// The security service ID
ID string `q:"id"`
// The security service domain
Domain string `q:"domain"`
// The security service type. A valid value is ldap, kerberos, or active_directory
Type SecurityServiceType `q:"type"`
// The security service name
Name string `q:"name"`
// The DNS IP address that is used inside the tenant network
DNSIP string `q:"dns_ip"`
// The security service user or group name that is used by the tenant
User string `q:"user"`
// The security service host name or IP address
Server string `q:"server"`
// The ID of the share network using security services
ShareNetworkID string `q:"share_network_id"`
}
// ToSecurityServiceListQuery formats a ListOpts into a query string.
func (opts ListOpts) ToSecurityServiceListQuery() (string, error) {
q, err := gophercloud.BuildQueryString(opts)
return q.String(), err
}
// List returns SecurityServices 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.ToSecurityServiceListQuery()
if err != nil {
return pagination.Pager{Err: err}
}
url += query
}
return pagination.NewPager(client, url, func(r pagination.PageResult) pagination.Page {
return SecurityServicePage{pagination.SinglePageBase(r)}
})
}