| 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)} |
| }) |
| } |