-
Notifications
You must be signed in to change notification settings - Fork 29
/
Copy pathV1_oauth_token_code.yml
114 lines (114 loc) · 3.81 KB
/
V1_oauth_token_code.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
swagger: '2.0'
info:
x-copyright: 'Copyright IBM Corp. 2017'
title: Get User Access Token
description: "Request an access token for a user"
version: 1.0.0
host: api.watsonwork.ibm.com
schemes:
- https
definitions:
AuthorizationCodeGrantRequest:
type: object
description: "Entity for requesting tokens using an authorization code grant."
properties:
grant_type:
type: string
default: authorization_code
description: "Authorization code grant"
code:
type: string
description: "Authorization code previously received from the /oauth/authorize response."
redirect_uri:
type: string
description: "Must match the value that was previously sent to the /oauth/authorize request."
TokenResponse:
type: object
description: "Client credentials authentication object"
properties:
access_token:
type: string
description: "Access token."
token_type:
type: string
description: "Type of the token returned. Currently always set to `bearer`."
refresh_token:
type: string
description: "Refresh token."
expires_in:
type: integer
description: "Time, in seconds, before the access token expires."
scope:
type: string
description: "Access scopes granted to the returned access token."
Error:
type: object
description: "Response entity resulting from a failed API call."
required: [error]
properties:
error:
type: string
description: "Type of error that occurred."
error_description:
type: string
description: "(optional) Additional details about the resulting error."
timestamp:
type: string
description: "(optional) Time at which the error occurred, in the following format: yyyy-MM-dd'T'HH:mm:ss.SSSZ"
status:
type: string
description: "(optional) HTTP response code."
message:
type: string
description: "(optional) Service-defined description of error."
path:
type: string
description: "(optional) HTTP request path."
parameters:
Authorization:
name: Authorization
in: header
type: string
description: "Authorization header where the appId and the appSecret are base64 encoded, and are sent via `Basic base64(appId:appSecret)`; e.g. `Basic YXBwOnNlY3JldA==` "
required: true
responses:
BadRequest:
description: "Improperly formed authentication body."
schema:
$ref: '#/definitions/Error'
Unauthorized:
description: "Unauthorized."
schema:
$ref: '#/definitions/Error'
InternalServerError:
description: "Internal server error."
schema:
$ref: '#/definitions/Error'
paths:
'/oauth/token':
post:
summary: OAuth2 Authorization Code flow for requesting an access token for a user
description: "Standard OAuth2 endpoint for authenticating users via OAuth2 authorization code. \n\nMore Information in [Section 4.1.3 of RFC 6749](https://tools.ietf.org/html/rfc6749#section-4.1.3)"
consumes:
- application/x-www-form-urlencoded
produces:
- application/json
parameters:
- $ref: '#/parameters/Authorization'
- name: body
in: body
description: "Request Body"
required: true
schema:
$ref: '#/definitions/AuthorizationCodeGrantRequest'
responses:
'200':
description: "Authentication successful"
schema:
$ref: '#/definitions/TokenResponse'
'400':
$ref: '#/responses/BadRequest'
'401':
$ref: '#/responses/Unauthorized'
'500':
$ref: '#/responses/InternalServerError'