Ash Wilson | 1f11051 | 2014-10-02 15:43:47 -0400 | [diff] [blame] | 1 | package tokens |
| 2 | |
Jon Perritt | a3302e1 | 2016-03-07 03:48:59 -0600 | [diff] [blame] | 3 | import "github.com/gophercloud/gophercloud" |
Ash Wilson | 1f11051 | 2014-10-02 15:43:47 -0400 | [diff] [blame] | 4 | |
jrperritt | 29ae6b3 | 2016-04-13 12:59:37 -0500 | [diff] [blame] | 5 | type PasswordCredentialsV2 struct { |
| 6 | Username string `json:"username" required:"true"` |
| 7 | Password string `json:"password" required:"true"` |
| 8 | } |
| 9 | |
| 10 | type TokenCredentialsV2 struct { |
| 11 | ID string `json:"id,omitempty" required:"true"` |
| 12 | } |
| 13 | |
| 14 | // AuthOptionsV2 wraps a gophercloud AuthOptions in order to adhere to the AuthOptionsBuilder |
| 15 | // interface. |
| 16 | type AuthOptionsV2 struct { |
| 17 | PasswordCredentials *PasswordCredentialsV2 `json:"passwordCredentials,omitempty" xor:"TokenCredentials"` |
| 18 | |
| 19 | // The TenantID and TenantName fields are optional for the Identity V2 API. |
| 20 | // Some providers allow you to specify a TenantName instead of the TenantId. |
| 21 | // Some require both. Your provider's authentication policies will determine |
| 22 | // how these fields influence authentication. |
| 23 | TenantID string `json:"tenantId,omitempty"` |
| 24 | TenantName string `json:"tenantName,omitempty"` |
| 25 | |
| 26 | // TokenCredentials allows users to authenticate (possibly as another user) with an |
| 27 | // authentication token ID. |
| 28 | TokenCredentials *TokenCredentialsV2 `json:"token,omitempty" xor:"PasswordCredentials"` |
| 29 | } |
| 30 | |
Ash Wilson | 40095f0 | 2014-10-07 15:46:40 -0400 | [diff] [blame] | 31 | // AuthOptionsBuilder describes any argument that may be passed to the Create call. |
| 32 | type AuthOptionsBuilder interface { |
Ash Wilson | 40095f0 | 2014-10-07 15:46:40 -0400 | [diff] [blame] | 33 | // ToTokenCreateMap assembles the Create request body, returning an error if parameters are |
| 34 | // missing or inconsistent. |
Jon Perritt | db0ae14 | 2016-03-13 00:33:41 -0600 | [diff] [blame] | 35 | ToTokenV2CreateMap() (map[string]interface{}, error) |
Ash Wilson | 40095f0 | 2014-10-07 15:46:40 -0400 | [diff] [blame] | 36 | } |
| 37 | |
jrperritt | 64d0ef0 | 2016-04-13 13:10:04 -0500 | [diff] [blame^] | 38 | // AuthOptions are the valid options for Openstack Identity v2 authentication. |
| 39 | // For field descriptions, see gophercloud.AuthOptions. |
jrperritt | 29ae6b3 | 2016-04-13 12:59:37 -0500 | [diff] [blame] | 40 | type AuthOptions struct { |
jrperritt | 64d0ef0 | 2016-04-13 13:10:04 -0500 | [diff] [blame^] | 41 | IdentityEndpoint string `json:"-"` |
| 42 | Username string `json:"username,omitempty"` |
| 43 | Password string `json:"password,omitempty"` |
| 44 | TenantID string `json:"tenantId,omitempty"` |
| 45 | TenantName string `json:"tenantName,omitempty"` |
| 46 | AllowReauth bool `json:"-"` |
| 47 | TokenID string |
jrperritt | 29ae6b3 | 2016-04-13 12:59:37 -0500 | [diff] [blame] | 48 | } |
| 49 | |
| 50 | // ToTokenV2CreateMap allows AuthOptions to satisfy the AuthOptionsBuilder |
| 51 | // interface in the v2 tokens package |
| 52 | func (opts AuthOptions) ToTokenV2CreateMap() (map[string]interface{}, error) { |
| 53 | v2Opts := AuthOptionsV2{ |
| 54 | TenantID: opts.TenantID, |
| 55 | TenantName: opts.TenantName, |
| 56 | } |
| 57 | |
| 58 | if opts.Password != "" { |
| 59 | v2Opts.PasswordCredentials = &PasswordCredentialsV2{ |
| 60 | Username: opts.Username, |
| 61 | Password: opts.Password, |
| 62 | } |
| 63 | } else { |
| 64 | v2Opts.TokenCredentials = &TokenCredentialsV2{ |
| 65 | ID: opts.TokenID, |
| 66 | } |
| 67 | } |
| 68 | |
| 69 | b, err := gophercloud.BuildRequestBody(v2Opts, "auth") |
| 70 | if err != nil { |
| 71 | return nil, err |
| 72 | } |
| 73 | return b, nil |
| 74 | } |
| 75 | |
Ash Wilson | 40095f0 | 2014-10-07 15:46:40 -0400 | [diff] [blame] | 76 | // Create authenticates to the identity service and attempts to acquire a Token. |
| 77 | // If successful, the CreateResult |
| 78 | // Generally, rather than interact with this call directly, end users should call openstack.AuthenticatedClient(), |
| 79 | // which abstracts all of the gory details about navigating service catalogs and such. |
Jon Perritt | 2be387a | 2016-03-31 09:31:58 -0500 | [diff] [blame] | 80 | func Create(client *gophercloud.ServiceClient, auth AuthOptionsBuilder) (r CreateResult) { |
Jon Perritt | db0ae14 | 2016-03-13 00:33:41 -0600 | [diff] [blame] | 81 | b, err := auth.ToTokenV2CreateMap() |
Ash Wilson | 40095f0 | 2014-10-07 15:46:40 -0400 | [diff] [blame] | 82 | if err != nil { |
Jon Perritt | db0ae14 | 2016-03-13 00:33:41 -0600 | [diff] [blame] | 83 | r.Err = err |
Jon Perritt | 2be387a | 2016-03-31 09:31:58 -0500 | [diff] [blame] | 84 | return |
Ash Wilson | 40095f0 | 2014-10-07 15:46:40 -0400 | [diff] [blame] | 85 | } |
Jon Perritt | db0ae14 | 2016-03-13 00:33:41 -0600 | [diff] [blame] | 86 | _, r.Err = client.Post(CreateURL(client), b, &r.Body, &gophercloud.RequestOpts{ |
Jamie Hannaford | 562a7d5 | 2015-03-24 16:20:16 +0100 | [diff] [blame] | 87 | OkCodes: []int{200, 203}, |
Ash Wilson | 1f11051 | 2014-10-02 15:43:47 -0400 | [diff] [blame] | 88 | }) |
jrperritt | 29ae6b3 | 2016-04-13 12:59:37 -0500 | [diff] [blame] | 89 | return |
Ash Wilson | 1f11051 | 2014-10-02 15:43:47 -0400 | [diff] [blame] | 90 | } |
hzlouchao | f6e2926 | 2015-10-27 12:51:08 +0800 | [diff] [blame] | 91 | |
Jon Perritt | a3302e1 | 2016-03-07 03:48:59 -0600 | [diff] [blame] | 92 | // Get validates and retrieves information for user's token. |
Jon Perritt | 2be387a | 2016-03-31 09:31:58 -0500 | [diff] [blame] | 93 | func Get(client *gophercloud.ServiceClient, token string) (r GetResult) { |
Jon Perritt | db0ae14 | 2016-03-13 00:33:41 -0600 | [diff] [blame] | 94 | _, r.Err = client.Get(GetURL(client, token), &r.Body, &gophercloud.RequestOpts{ |
hzlouchao | b764089 | 2015-11-04 21:37:20 +0800 | [diff] [blame] | 95 | OkCodes: []int{200, 203}, |
| 96 | }) |
jrperritt | 29ae6b3 | 2016-04-13 12:59:37 -0500 | [diff] [blame] | 97 | return |
hzlouchao | b764089 | 2015-11-04 21:37:20 +0800 | [diff] [blame] | 98 | } |