|  | package securityservices | 
|  |  | 
|  | import ( | 
|  | "github.com/gophercloud/gophercloud" | 
|  | "gerrit.mcp.mirantis.net/debian/gophercloud.git/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)} | 
|  | }) | 
|  | } |