piral-oauth2 1.6.0-beta.7216 → 1.6.0-beta.7243

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,528 +0,0 @@
1
- const DEFAULT_URL_BASE = location.origin;
2
- function defaultRequest(method, url, body, headers) {
3
- return fetch(url, {
4
- body: body,
5
- method: method,
6
- headers: headers,
7
- }).then((res) => res.text().then((body) => ({
8
- status: res.status,
9
- body: body,
10
- })));
11
- }
12
- /**
13
- * Default headers for executing OAuth 2.0 flows.
14
- */
15
- const DEFAULT_HEADERS = {
16
- Accept: 'application/json, application/x-www-form-urlencoded',
17
- 'Content-Type': 'application/x-www-form-urlencoded',
18
- };
19
- /**
20
- * Format error response types to regular strings for displaying to clients.
21
- *
22
- * Reference: http://tools.ietf.org/html/rfc6749#section-4.1.2.1
23
- */
24
- var ERROR_RESPONSES = {
25
- invalid_request: [
26
- 'The request is missing a required parameter, includes an',
27
- 'invalid parameter value, includes a parameter more than',
28
- 'once, or is otherwise malformed.',
29
- ].join(' '),
30
- invalid_client: [
31
- 'Client authentication failed (e.g., unknown client, no',
32
- 'client authentication included, or unsupported',
33
- 'authentication method).',
34
- ].join(' '),
35
- invalid_grant: [
36
- 'The provided authorization grant (e.g., authorization',
37
- 'code, resource owner credentials) or refresh token is',
38
- 'invalid, expired, revoked, does not match the redirection',
39
- 'URI used in the authorization request, or was issued to',
40
- 'another client.',
41
- ].join(' '),
42
- unauthorized_client: ['The client is not authorized to request an authorization', 'code using this method.'].join(' '),
43
- unsupported_grant_type: ['The authorization grant type is not supported by the', 'authorization server.'].join(' '),
44
- access_denied: ['The resource owner or authorization server denied the request.'].join(' '),
45
- unsupported_response_type: [
46
- 'The authorization server does not support obtaining',
47
- 'an authorization code using this method.',
48
- ].join(' '),
49
- invalid_scope: ['The requested scope is invalid, unknown, or malformed.'].join(' '),
50
- server_error: [
51
- 'The authorization server encountered an unexpected',
52
- 'condition that prevented it from fulfilling the request.',
53
- '(This error code is needed because a 500 Internal Server',
54
- 'Error HTTP status code cannot be returned to the client',
55
- 'via an HTTP redirect.)',
56
- ].join(' '),
57
- temporarily_unavailable: [
58
- 'The authorization server is currently unable to handle',
59
- 'the request due to a temporary overloading or maintenance',
60
- 'of the server.',
61
- ].join(' '),
62
- };
63
- /**
64
- * Check if properties exist on an object and throw when they aren't.
65
- */
66
- function expects(obj, ...args) {
67
- for (let i = 0; i < args.length; i++) {
68
- var prop = args[i];
69
- if (obj[prop] == null) {
70
- throw new TypeError('Expected "' + prop + '" to exist');
71
- }
72
- }
73
- }
74
- /**
75
- * Pull an authentication error from the response data.
76
- */
77
- function getAuthError(body) {
78
- var message = ERROR_RESPONSES[body.error] || body.error_description || body.error;
79
- if (message) {
80
- const err = new Error(message);
81
- err.body = body;
82
- err.code = 'EAUTH';
83
- return err;
84
- }
85
- }
86
- function parseQuerystring(str) {
87
- const q = new URLSearchParams(str);
88
- return Object.fromEntries(q.entries());
89
- }
90
- function stringifyQuerystring(obj) {
91
- const q = new URLSearchParams(obj);
92
- return q.toString();
93
- }
94
- /**
95
- * Attempt to parse response body as JSON, fall back to parsing as a query string.
96
- *
97
- * @param {string} body
98
- * @return {Object}
99
- */
100
- function parseResponseBody(body) {
101
- try {
102
- return JSON.parse(body);
103
- }
104
- catch (e) {
105
- return parseQuerystring(body);
106
- }
107
- }
108
- /**
109
- * Sanitize the scopes option to be a string.
110
- */
111
- function sanitizeScope(scopes) {
112
- return Array.isArray(scopes) ? scopes.join(' ') : toString(scopes);
113
- }
114
- /**
115
- * Create a request uri based on an options object and token type.
116
- */
117
- function createUri(options, tokenType) {
118
- // Check the required parameters are set.
119
- expects(options, 'clientId', 'authorizationUri');
120
- const qs = {
121
- client_id: options.clientId,
122
- redirect_uri: options.redirectUri,
123
- response_type: tokenType,
124
- state: options.state,
125
- };
126
- if (options.scopes !== undefined) {
127
- qs.scope = sanitizeScope(options.scopes);
128
- }
129
- const sep = options.authorizationUri.includes('?') ? '&' : '?';
130
- return options.authorizationUri + sep + stringifyQuerystring(Object.assign(qs, options.query));
131
- }
132
- /**
133
- * Create basic auth header.
134
- */
135
- function auth(username, password) {
136
- return 'Basic ' + btoa(toString(username) + ':' + toString(password));
137
- }
138
- /**
139
- * Ensure a value is a string.
140
- */
141
- function toString(str) {
142
- return str == null ? '' : String(str);
143
- }
144
- /**
145
- * Merge request options from an options object.
146
- */
147
- function requestOptions(requestOptions, options) {
148
- return {
149
- url: requestOptions.url,
150
- method: requestOptions.method,
151
- body: Object.assign({}, requestOptions.body, options.body),
152
- query: Object.assign({}, requestOptions.query, options.query),
153
- headers: Object.assign({}, requestOptions.headers, options.headers),
154
- };
155
- }
156
- /**
157
- * Construct an object that can handle the multiple OAuth 2.0 flows.
158
- *
159
- * @param {Object} options
160
- */
161
- export class ClientOAuth2 {
162
- constructor(options, request = defaultRequest) {
163
- this.options = options;
164
- this.request = request;
165
- this.code = new CodeFlow(this);
166
- this.token = new TokenFlow(this);
167
- this.owner = new OwnerFlow(this);
168
- this.credentials = new CredentialsFlow(this);
169
- this.jwt = new JwtBearerFlow(this);
170
- }
171
- /**
172
- * Create a new token from existing data.
173
- */
174
- createToken(access, refresh, type, data) {
175
- var options = Object.assign({}, data, typeof access === 'string' ? { access_token: access } : access, typeof refresh === 'string' ? { refresh_token: refresh } : refresh, typeof type === 'string' ? { token_type: type } : type);
176
- return new ClientOAuth2Token(this, options);
177
- }
178
- /**
179
- * Using the built-in request method, we'll automatically attempt to parse
180
- * the response.
181
- */
182
- _request(options) {
183
- let url = options.url;
184
- const body = stringifyQuerystring(options.body);
185
- const query = stringifyQuerystring(options.query);
186
- if (query) {
187
- url += (url.indexOf('?') === -1 ? '?' : '&') + query;
188
- }
189
- return this.request(options.method, url, body, options.headers).then((res) => {
190
- const body = parseResponseBody(res.body);
191
- const authErr = getAuthError(body);
192
- if (authErr) {
193
- return Promise.reject(authErr);
194
- }
195
- if (res.status < 200 || res.status >= 399) {
196
- const statusErr = new Error('HTTP status ' + res.status);
197
- statusErr.status = res.status;
198
- statusErr.body = res.body;
199
- statusErr.code = 'ESTATUS';
200
- return Promise.reject(statusErr);
201
- }
202
- return body;
203
- });
204
- }
205
- }
206
- /**
207
- * General purpose client token generator.
208
- *
209
- * @param {Object} client
210
- * @param {Object} data
211
- */
212
- export class ClientOAuth2Token {
213
- constructor(client, data) {
214
- this.client = client;
215
- this.data = data;
216
- this.tokenType = data.token_type && data.token_type.toLowerCase();
217
- this.accessToken = data.access_token;
218
- this.refreshToken = data.refresh_token;
219
- this.expiresIn(Number(data.expires_in));
220
- }
221
- /**
222
- * Expire the token after some time.
223
- */
224
- expiresIn(duration) {
225
- if (typeof duration === 'number') {
226
- this.expires = new Date();
227
- this.expires.setSeconds(this.expires.getSeconds() + duration);
228
- }
229
- else if (duration instanceof Date) {
230
- this.expires = new Date(duration.getTime());
231
- }
232
- else {
233
- throw new TypeError('Unknown duration: ' + duration);
234
- }
235
- return this.expires;
236
- }
237
- /**
238
- * Sign a standardised request object with user authentication information.
239
- */
240
- sign(requestObject) {
241
- if (!this.accessToken) {
242
- throw new Error('Unable to sign without access token');
243
- }
244
- requestObject.headers = requestObject.headers || {};
245
- if (this.tokenType === 'bearer') {
246
- requestObject.headers.Authorization = 'Bearer ' + this.accessToken;
247
- }
248
- else {
249
- var parts = requestObject.url.split('#');
250
- var token = 'access_token=' + this.accessToken;
251
- var url = parts[0].replace(/[?&]access_token=[^&#]/, '');
252
- var fragment = parts[1] ? '#' + parts[1] : '';
253
- // Prepend the correct query string parameter to the url.
254
- requestObject.url = url + (url.indexOf('?') > -1 ? '&' : '?') + token + fragment;
255
- // Attempt to avoid storing the url in proxies, since the access token
256
- // is exposed in the query parameters.
257
- requestObject.headers.Pragma = 'no-store';
258
- requestObject.headers['Cache-Control'] = 'no-store';
259
- }
260
- return requestObject;
261
- }
262
- /**
263
- * Refresh a user access token with the supplied token.
264
- */
265
- refresh(opts) {
266
- var self = this;
267
- var options = Object.assign({}, this.client.options, opts);
268
- if (!this.refreshToken) {
269
- return Promise.reject(new Error('No refresh token'));
270
- }
271
- return this.client
272
- ._request(requestOptions({
273
- url: options.accessTokenUri,
274
- method: 'POST',
275
- headers: Object.assign({}, DEFAULT_HEADERS, {
276
- Authorization: auth(options.clientId, options.clientSecret),
277
- }),
278
- body: {
279
- refresh_token: this.refreshToken,
280
- grant_type: 'refresh_token',
281
- },
282
- }, options))
283
- .then((data) => {
284
- return self.client.createToken(undefined, undefined, undefined, Object.assign({}, self.data, data));
285
- });
286
- }
287
- /**
288
- * Check whether the token has expired.
289
- */
290
- expired() {
291
- return Date.now() > this.expires.getTime();
292
- }
293
- }
294
- /**
295
- * Support resource owner password credentials OAuth 2.0 grant.
296
- *
297
- * Reference: http://tools.ietf.org/html/rfc6749#section-4.3
298
- */
299
- class OwnerFlow {
300
- constructor(client) {
301
- this.client = client;
302
- }
303
- /**
304
- * Make a request on behalf of the user credentials to get an access token.
305
- */
306
- getToken(username, password, opts) {
307
- var self = this;
308
- var options = Object.assign({}, this.client.options, opts);
309
- const body = {
310
- username: username,
311
- password: password,
312
- grant_type: 'password',
313
- };
314
- if (options.scopes !== undefined) {
315
- body.scope = sanitizeScope(options.scopes);
316
- }
317
- return this.client
318
- ._request(requestOptions({
319
- url: options.accessTokenUri,
320
- method: 'POST',
321
- headers: Object.assign({}, DEFAULT_HEADERS, {
322
- Authorization: auth(options.clientId, options.clientSecret),
323
- }),
324
- body: body,
325
- }, options))
326
- .then((data) => {
327
- return self.client.createToken(undefined, undefined, undefined, data);
328
- });
329
- }
330
- }
331
- /**
332
- * Support implicit OAuth 2.0 grant.
333
- *
334
- * Reference: http://tools.ietf.org/html/rfc6749#section-4.2
335
- */
336
- class TokenFlow {
337
- constructor(client) {
338
- this.client = client;
339
- }
340
- /**
341
- * Get the uri to redirect the user to for implicit authentication.
342
- */
343
- getUri(opts) {
344
- var options = Object.assign({}, this.client.options, opts);
345
- return createUri(options, 'token');
346
- }
347
- /**
348
- * Get the user access token from the uri.
349
- */
350
- getToken(uri, opts) {
351
- var options = Object.assign({}, this.client.options, opts);
352
- var url = typeof uri === 'object' ? uri : new URL(uri, DEFAULT_URL_BASE);
353
- var expectedUrl = new URL(options.redirectUri, DEFAULT_URL_BASE);
354
- if (typeof url.pathname === 'string' && url.pathname !== expectedUrl.pathname) {
355
- return Promise.reject(new TypeError('Redirected path should match configured path, but got: ' + url.pathname));
356
- }
357
- // If no query string or fragment exists, we won't be able to parse
358
- // any useful information from the uri.
359
- if (!url.hash && !url.search) {
360
- return Promise.reject(new TypeError('Unable to process uri: ' + uri));
361
- }
362
- // Extract data from both the fragment and query string. The fragment is most
363
- // important, but the query string is also used because some OAuth 2.0
364
- // implementations (Instagram) have a bug where state is passed via query.
365
- var data = Object.assign({}, typeof url.search === 'string' ? parseQuerystring(url.search.substr(1)) : url.search || {}, typeof url.hash === 'string' ? parseQuerystring(url.hash.substr(1)) : url.hash || {});
366
- var err = getAuthError(data);
367
- // Check if the query string was populated with a known error.
368
- if (err) {
369
- return Promise.reject(err);
370
- }
371
- // Check whether the state matches.
372
- if (options.state != null && data.state !== options.state) {
373
- return Promise.reject(new TypeError('Invalid state: ' + data.state));
374
- }
375
- // Initalize a new token and return.
376
- return Promise.resolve(this.client.createToken(undefined, undefined, undefined, data));
377
- }
378
- }
379
- /**
380
- * Support client credentials OAuth 2.0 grant.
381
- *
382
- * Reference: http://tools.ietf.org/html/rfc6749#section-4.4
383
- */
384
- class CredentialsFlow {
385
- constructor(client) {
386
- this.client = client;
387
- }
388
- /**
389
- * Request an access token using the client credentials.
390
- */
391
- getToken(opts) {
392
- var self = this;
393
- var options = Object.assign({}, this.client.options, opts);
394
- expects(options, 'clientId', 'clientSecret', 'accessTokenUri');
395
- const body = {
396
- grant_type: 'client_credentials',
397
- };
398
- if (options.scopes !== undefined) {
399
- body.scope = sanitizeScope(options.scopes);
400
- }
401
- return this.client
402
- ._request(requestOptions({
403
- url: options.accessTokenUri,
404
- method: 'POST',
405
- headers: Object.assign({}, DEFAULT_HEADERS, {
406
- Authorization: auth(options.clientId, options.clientSecret),
407
- }),
408
- body: body,
409
- }, options))
410
- .then((data) => {
411
- return self.client.createToken(undefined, undefined, undefined, data);
412
- });
413
- }
414
- }
415
- /**
416
- * Support authorization code OAuth 2.0 grant.
417
- *
418
- * Reference: http://tools.ietf.org/html/rfc6749#section-4.1
419
- */
420
- class CodeFlow {
421
- constructor(client) {
422
- this.client = client;
423
- }
424
- /**
425
- * Generate the uri for doing the first redirect.
426
- */
427
- getUri(opts) {
428
- var options = Object.assign({}, this.client.options, opts);
429
- return createUri(options, 'code');
430
- }
431
- /**
432
- * Get the code token from the redirected uri and make another request for
433
- * the user access token.
434
- */
435
- getToken(uri, opts) {
436
- var self = this;
437
- var options = Object.assign({}, this.client.options, opts);
438
- expects(options, 'clientId', 'accessTokenUri');
439
- var url = typeof uri === 'object' ? uri : new URL(uri, DEFAULT_URL_BASE);
440
- if (typeof options.redirectUri === 'string' &&
441
- typeof url.pathname === 'string' &&
442
- url.pathname !== new URL(options.redirectUri, DEFAULT_URL_BASE).pathname) {
443
- return Promise.reject(new TypeError('Redirected path should match configured path, but got: ' + url.pathname));
444
- }
445
- if (!url.search || !url.search.substr(1)) {
446
- return Promise.reject(new TypeError('Unable to process uri: ' + uri));
447
- }
448
- var data = typeof url.search === 'string' ? parseQuerystring(url.search.substr(1)) : url.search || {};
449
- var err = getAuthError(data);
450
- if (err) {
451
- return Promise.reject(err);
452
- }
453
- if (options.state != null && data.state !== options.state) {
454
- return Promise.reject(new TypeError('Invalid state: ' + data.state));
455
- }
456
- // Check whether the response code is set.
457
- if (!data.code) {
458
- return Promise.reject(new TypeError('Missing code, unable to request token'));
459
- }
460
- const headers = Object.assign({}, DEFAULT_HEADERS);
461
- const body = {
462
- code: data.code,
463
- grant_type: 'authorization_code',
464
- redirect_uri: options.redirectUri,
465
- };
466
- // `client_id`: REQUIRED, if the client is not authenticating with the
467
- // authorization server as described in Section 3.2.1.
468
- // Reference: https://tools.ietf.org/html/rfc6749#section-3.2.1
469
- if (options.clientSecret) {
470
- headers.Authorization = auth(options.clientId, options.clientSecret);
471
- }
472
- else {
473
- body.client_id = options.clientId;
474
- }
475
- return this.client
476
- ._request(requestOptions({
477
- url: options.accessTokenUri,
478
- method: 'POST',
479
- headers: headers,
480
- body: body,
481
- }, options))
482
- .then((data) => {
483
- return self.client.createToken(undefined, undefined, undefined, data);
484
- });
485
- }
486
- }
487
- /**
488
- * Support JSON Web Token (JWT) Bearer Token OAuth 2.0 grant.
489
- *
490
- * Reference: https://tools.ietf.org/html/draft-ietf-oauth-jwt-bearer-12#section-2.1
491
- */
492
- class JwtBearerFlow {
493
- constructor(client) {
494
- this.client = client;
495
- }
496
- /**
497
- * Request an access token using a JWT token.
498
- */
499
- getToken(token, opts) {
500
- const self = this;
501
- const options = Object.assign({}, this.client.options, opts);
502
- const headers = Object.assign({}, DEFAULT_HEADERS);
503
- expects(options, 'accessTokenUri');
504
- // Authentication of the client is optional, as described in
505
- // Section 3.2.1 of OAuth 2.0 [RFC6749]
506
- if (options.clientId) {
507
- headers.Authorization = auth(options.clientId, options.clientSecret);
508
- }
509
- const body = {
510
- grant_type: 'urn:ietf:params:oauth:grant-type:jwt-bearer',
511
- assertion: token,
512
- };
513
- if (options.scopes !== undefined) {
514
- body.scope = sanitizeScope(options.scopes);
515
- }
516
- return this.client
517
- ._request(requestOptions({
518
- url: options.accessTokenUri,
519
- method: 'POST',
520
- headers: headers,
521
- body: body,
522
- }, options))
523
- .then((data) => {
524
- return self.client.createToken(undefined, undefined, undefined, data);
525
- });
526
- }
527
- }
528
- //# sourceMappingURL=client-oauth2.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"client-oauth2.js","sourceRoot":"","sources":["../src/client-oauth2.ts"],"names":[],"mappings":"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"}
package/esm/create.d.ts DELETED
@@ -1,6 +0,0 @@
1
- import { PiralPlugin } from 'piral-core';
2
- import { OAuth2Client, PiralOAuth2Api } from './types';
3
- /**
4
- * Creates new Pilet API extensions for the integration of OAuth 2.0.
5
- */
6
- export declare function createOAuth2Api(client: OAuth2Client): PiralPlugin<PiralOAuth2Api>;
package/esm/create.js DELETED
@@ -1,14 +0,0 @@
1
- /**
2
- * Creates new Pilet API extensions for the integration of OAuth 2.0.
3
- */
4
- export function createOAuth2Api(client) {
5
- return (context) => {
6
- context.on('before-fetch', client.extendHeaders);
7
- return {
8
- getAccessToken() {
9
- return client.token();
10
- },
11
- };
12
- };
13
- }
14
- //# sourceMappingURL=create.js.map
package/esm/create.js.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"file":"create.js","sourceRoot":"","sources":["../src/create.ts"],"names":[],"mappings":"AAGA;;GAEG;AACH,MAAM,UAAU,eAAe,CAAC,MAAoB;IAClD,OAAO,CAAC,OAAO,EAAE,EAAE;QACjB,OAAO,CAAC,EAAE,CAAC,cAAc,EAAE,MAAM,CAAC,aAAa,CAAC,CAAC;QAEjD,OAAO;YACL,cAAc;gBACZ,OAAO,MAAM,CAAC,KAAK,EAAE,CAAC;YACxB,CAAC;SACF,CAAC;IACJ,CAAC,CAAC;AACJ,CAAC"}
package/esm/index.d.ts DELETED
@@ -1,4 +0,0 @@
1
- export * from './create';
2
- export * from './setup';
3
- export * from './types';
4
- export * from './utils';
package/esm/index.js DELETED
@@ -1,5 +0,0 @@
1
- export * from './create';
2
- export * from './setup';
3
- export * from './types';
4
- export * from './utils';
5
- //# sourceMappingURL=index.js.map
package/esm/index.js.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,UAAU,CAAC;AACzB,cAAc,SAAS,CAAC;AACxB,cAAc,SAAS,CAAC;AACxB,cAAc,SAAS,CAAC"}
package/esm/setup.d.ts DELETED
@@ -1,6 +0,0 @@
1
- import { OAuth2Config, OAuth2Client } from './types';
2
- /**
3
- * Sets up a new client wrapping the OAuth 2.0 API.
4
- * @param config The configuration for the client.
5
- */
6
- export declare function setupOAuth2Client(config: OAuth2Config): OAuth2Client;