Ash Wilson | 85d8265 | 2014-08-28 13:57:46 -0400 | [diff] [blame] | 1 | package tokens |
| 2 | |
| 3 | import ( |
Ash Wilson | 2491b4c | 2015-02-12 16:13:39 -0500 | [diff] [blame] | 4 | "net/http" |
| 5 | |
Jon Perritt | 27249f4 | 2016-02-18 10:35:59 -0600 | [diff] [blame] | 6 | "github.com/gophercloud/gophercloud" |
Ash Wilson | 85d8265 | 2014-08-28 13:57:46 -0400 | [diff] [blame] | 7 | ) |
| 8 | |
Jon Perritt | db0ae14 | 2016-03-13 00:33:41 -0600 | [diff] [blame] | 9 | // AuthOptionsBuilder describes any argument that may be passed to the Create call. |
| 10 | type AuthOptionsBuilder interface { |
| 11 | // ToTokenV3CreateMap assembles the Create request body, returning an error if parameters are |
| 12 | // missing or inconsistent. |
| 13 | ToTokenV3CreateMap(*gophercloud.ScopeOptsV3) (map[string]interface{}, error) |
Ash Wilson | 85d8265 | 2014-08-28 13:57:46 -0400 | [diff] [blame] | 14 | } |
| 15 | |
Ash Wilson | 6425a41 | 2014-08-29 12:30:35 -0400 | [diff] [blame] | 16 | func subjectTokenHeaders(c *gophercloud.ServiceClient, subjectToken string) map[string]string { |
Krzysztof Kwapisiewicz | baaaf3e | 2016-02-03 15:18:16 +0100 | [diff] [blame] | 17 | return map[string]string{ |
| 18 | "X-Subject-Token": subjectToken, |
| 19 | } |
Ash Wilson | 46d913f | 2014-08-29 11:00:11 -0400 | [diff] [blame] | 20 | } |
| 21 | |
Ash Wilson | e555086 | 2014-08-28 15:37:09 -0400 | [diff] [blame] | 22 | // Create authenticates and either generates a new token, or changes the Scope of an existing token. |
Jon Perritt | 2be387a | 2016-03-31 09:31:58 -0500 | [diff] [blame^] | 23 | func Create(c *gophercloud.ServiceClient, opts AuthOptionsBuilder, scopeOpts *gophercloud.ScopeOptsV3) (r CreateResult) { |
Jon Perritt | db0ae14 | 2016-03-13 00:33:41 -0600 | [diff] [blame] | 24 | b, err := opts.ToTokenV3CreateMap(scopeOpts) |
| 25 | if err != nil { |
| 26 | r.Err = err |
Jon Perritt | 2be387a | 2016-03-31 09:31:58 -0500 | [diff] [blame^] | 27 | return |
Ash Wilson | 85d8265 | 2014-08-28 13:57:46 -0400 | [diff] [blame] | 28 | } |
Jon Perritt | db0ae14 | 2016-03-13 00:33:41 -0600 | [diff] [blame] | 29 | var resp *http.Response |
| 30 | resp, r.Err = c.Post(tokenURL(c), b, &r.Body, nil) |
| 31 | if resp != nil { |
| 32 | r.Header = resp.Header |
Ash Wilson | 85d8265 | 2014-08-28 13:57:46 -0400 | [diff] [blame] | 33 | } |
Ash Wilson | 85d8265 | 2014-08-28 13:57:46 -0400 | [diff] [blame] | 34 | } |
Ash Wilson | 46d913f | 2014-08-29 11:00:11 -0400 | [diff] [blame] | 35 | |
Ash Wilson | 5266e49 | 2014-09-09 15:44:30 -0400 | [diff] [blame] | 36 | // Get validates and retrieves information about another token. |
Jon Perritt | 2be387a | 2016-03-31 09:31:58 -0500 | [diff] [blame^] | 37 | func Get(c *gophercloud.ServiceClient, token string) (r GetResult) { |
Jon Perritt | db0ae14 | 2016-03-13 00:33:41 -0600 | [diff] [blame] | 38 | var resp *http.Response |
| 39 | resp, r.Err = c.Get(tokenURL(c), &r.Body, &gophercloud.RequestOpts{ |
Jamie Hannaford | 562a7d5 | 2015-03-24 16:20:16 +0100 | [diff] [blame] | 40 | MoreHeaders: subjectTokenHeaders(c, token), |
| 41 | OkCodes: []int{200, 203}, |
Ash Wilson | 46d913f | 2014-08-29 11:00:11 -0400 | [diff] [blame] | 42 | }) |
Jon Perritt | db0ae14 | 2016-03-13 00:33:41 -0600 | [diff] [blame] | 43 | if resp != nil { |
| 44 | r.Header = resp.Header |
Ash Wilson | 46d913f | 2014-08-29 11:00:11 -0400 | [diff] [blame] | 45 | } |
Ash Wilson | 46d913f | 2014-08-29 11:00:11 -0400 | [diff] [blame] | 46 | } |
| 47 | |
| 48 | // Validate determines if a specified token is valid or not. |
Ash Wilson | 6425a41 | 2014-08-29 12:30:35 -0400 | [diff] [blame] | 49 | func Validate(c *gophercloud.ServiceClient, token string) (bool, error) { |
Jon Perritt | a33da23 | 2016-03-02 04:43:08 -0600 | [diff] [blame] | 50 | response, err := c.Request("HEAD", tokenURL(c), &gophercloud.RequestOpts{ |
Ash Wilson | 46d913f | 2014-08-29 11:00:11 -0400 | [diff] [blame] | 51 | MoreHeaders: subjectTokenHeaders(c, token), |
| 52 | OkCodes: []int{204, 404}, |
| 53 | }) |
| 54 | if err != nil { |
| 55 | return false, err |
| 56 | } |
| 57 | |
| 58 | return response.StatusCode == 204, nil |
| 59 | } |
| 60 | |
| 61 | // Revoke immediately makes specified token invalid. |
Jon Perritt | 2be387a | 2016-03-31 09:31:58 -0500 | [diff] [blame^] | 62 | func Revoke(c *gophercloud.ServiceClient, token string) (r RevokeResult) { |
Jon Perritt | db0ae14 | 2016-03-13 00:33:41 -0600 | [diff] [blame] | 63 | _, r.Err = c.Delete(tokenURL(c), &gophercloud.RequestOpts{ |
Ash Wilson | 46d913f | 2014-08-29 11:00:11 -0400 | [diff] [blame] | 64 | MoreHeaders: subjectTokenHeaders(c, token), |
Ash Wilson | 46d913f | 2014-08-29 11:00:11 -0400 | [diff] [blame] | 65 | }) |
Ash Wilson | 46d913f | 2014-08-29 11:00:11 -0400 | [diff] [blame] | 66 | } |