@cloudbase/oauth 2.4.4-beta.0 → 2.5.0-beta.0
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.
- package/.eslintrc.js +15 -0
- package/dist/cjs/auth/apis.d.ts +3 -3
- package/dist/cjs/auth/apis.js +69 -69
- package/dist/cjs/captcha/captcha.d.ts +9 -9
- package/dist/cjs/captcha/captcha.js +43 -46
- package/dist/cjs/index.d.ts +3 -3
- package/dist/cjs/index.js +6 -6
- package/dist/cjs/oauth2client/interface.d.ts +1 -1
- package/dist/cjs/oauth2client/interface.js +1 -1
- package/dist/cjs/oauth2client/models.js +1 -1
- package/dist/cjs/oauth2client/oauth2client.d.ts +31 -31
- package/dist/cjs/oauth2client/oauth2client.js +229 -229
- package/dist/cjs/utils/function/single-promise.d.ts +2 -2
- package/dist/cjs/utils/function/single-promise.js +40 -33
- package/dist/cjs/utils/uuid.js +2 -2
- package/dist/esm/auth/apis.d.ts +3 -3
- package/dist/esm/auth/apis.js +69 -69
- package/dist/esm/captcha/captcha.d.ts +9 -9
- package/dist/esm/captcha/captcha.js +44 -47
- package/dist/esm/index.d.ts +3 -3
- package/dist/esm/index.js +5 -5
- package/dist/esm/oauth2client/interface.d.ts +1 -1
- package/dist/esm/oauth2client/interface.js +1 -1
- package/dist/esm/oauth2client/models.js +1 -1
- package/dist/esm/oauth2client/oauth2client.d.ts +31 -31
- package/dist/esm/oauth2client/oauth2client.js +229 -229
- package/dist/esm/utils/function/single-promise.d.ts +2 -2
- package/dist/esm/utils/function/single-promise.js +40 -33
- package/dist/esm/utils/uuid.js +2 -2
- package/package.json +13 -6
- package/src/auth/apis.ts +135 -158
- package/src/captcha/captcha.ts +71 -78
- package/src/index.ts +13 -14
- package/src/oauth2client/interface.ts +5 -5
- package/src/oauth2client/models.ts +38 -38
- package/src/oauth2client/oauth2client.ts +255 -268
- package/src/utils/function/single-promise.ts +22 -21
- package/src/utils/uuid.ts +4 -4
- package/.eslintrc +0 -26
|
@@ -34,18 +34,18 @@ var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
|
34
34
|
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
35
35
|
}
|
|
36
36
|
};
|
|
37
|
-
import { defaultStorage } from
|
|
37
|
+
import { defaultStorage } from '../oauth2client/oauth2client';
|
|
38
38
|
var GET_CAPTCHA_URL = '/auth/v1/captcha/init';
|
|
39
39
|
var Captcha = (function () {
|
|
40
40
|
function Captcha(opts) {
|
|
41
41
|
if (!opts.openURIWithCallback) {
|
|
42
|
-
opts.openURIWithCallback = this.
|
|
42
|
+
opts.openURIWithCallback = this.getDefaultOpenURIWithCallback();
|
|
43
43
|
}
|
|
44
44
|
if (!opts.storage) {
|
|
45
45
|
opts.storage = defaultStorage;
|
|
46
46
|
}
|
|
47
|
-
this.
|
|
48
|
-
this.
|
|
47
|
+
this.config = opts;
|
|
48
|
+
this.tokenSectionName = "captcha_" + opts.clientId;
|
|
49
49
|
}
|
|
50
50
|
Captcha.prototype.request = function (url, options) {
|
|
51
51
|
return __awaiter(this, void 0, void 0, function () {
|
|
@@ -62,50 +62,49 @@ var Captcha = (function () {
|
|
|
62
62
|
state = options.method + ":" + url;
|
|
63
63
|
reqURL = url;
|
|
64
64
|
if (!options.withCaptcha) return [3, 2];
|
|
65
|
-
return [4, this.
|
|
65
|
+
return [4, this.appendCaptchaTokenToURL(url, state, false)];
|
|
66
66
|
case 1:
|
|
67
67
|
reqURL = _a.sent();
|
|
68
68
|
_a.label = 2;
|
|
69
69
|
case 2:
|
|
70
|
-
_a.trys.push([2, 4, ,
|
|
71
|
-
return [4, this.
|
|
70
|
+
_a.trys.push([2, 4, , 7]);
|
|
71
|
+
return [4, this.config.request(reqURL, options)];
|
|
72
72
|
case 3:
|
|
73
73
|
resp = _a.sent();
|
|
74
|
-
return [3,
|
|
74
|
+
return [3, 7];
|
|
75
75
|
case 4:
|
|
76
76
|
err_1 = _a.sent();
|
|
77
77
|
if (!(err_1.error === 'captcha_required' || err_1.error === 'captcha_invalid')) return [3, 6];
|
|
78
|
-
return [4, this.
|
|
78
|
+
return [4, this.appendCaptchaTokenToURL(url, state, err_1.error === 'captcha_invalid')];
|
|
79
79
|
case 5:
|
|
80
80
|
url = _a.sent();
|
|
81
|
-
return [2, this.
|
|
81
|
+
return [2, this.config.request(url, options)];
|
|
82
82
|
case 6: return [2, Promise.reject(err_1)];
|
|
83
|
-
case 7: return [
|
|
84
|
-
case 8: return [2, resp];
|
|
83
|
+
case 7: return [2, resp];
|
|
85
84
|
}
|
|
86
85
|
});
|
|
87
86
|
});
|
|
88
87
|
};
|
|
89
|
-
Captcha.prototype.
|
|
88
|
+
Captcha.prototype.getDefaultOpenURIWithCallback = function () {
|
|
90
89
|
if (window.location.search.indexOf('__captcha') > 0) {
|
|
91
90
|
document.body.style.display = 'none';
|
|
92
91
|
}
|
|
93
92
|
if (document.getElementById('captcha_panel_wrap') === null) {
|
|
94
|
-
var
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
elementDiv.setAttribute('id', 'captcha_panel_wrap');
|
|
93
|
+
var elementDiv_1 = document.createElement('div');
|
|
94
|
+
elementDiv_1.style.cssText = 'background-color: rgba(0, 0, 0, 0.7);position: fixed;left: 0px;right: 0px;top: 0px;bottom: 0px;padding: 9vw 0 0 0;display: none;z-index:100;';
|
|
95
|
+
elementDiv_1.setAttribute('id', 'captcha_panel_wrap');
|
|
98
96
|
setTimeout(function () {
|
|
99
|
-
document.body.appendChild(
|
|
97
|
+
document.body.appendChild(elementDiv_1);
|
|
100
98
|
}, 0);
|
|
101
99
|
}
|
|
102
|
-
return this.
|
|
100
|
+
return this.defaultOpenURIWithCallback;
|
|
103
101
|
};
|
|
104
|
-
Captcha.prototype.
|
|
102
|
+
Captcha.prototype.defaultOpenURIWithCallback = function (url) {
|
|
105
103
|
return __awaiter(this, void 0, void 0, function () {
|
|
106
104
|
var target, iframe;
|
|
107
105
|
return __generator(this, function (_a) {
|
|
108
|
-
target = document.getElementById('captcha_panel_wrap')
|
|
106
|
+
target = document.getElementById('captcha_panel_wrap');
|
|
107
|
+
iframe = document.createElement('iframe');
|
|
109
108
|
target.innerHTML = '';
|
|
110
109
|
iframe.setAttribute('src', url);
|
|
111
110
|
iframe.setAttribute('id', 'review-panel-iframe');
|
|
@@ -117,27 +116,25 @@ var Captcha = (function () {
|
|
|
117
116
|
try {
|
|
118
117
|
var windowLocation = window.location;
|
|
119
118
|
var iframeLocation = iframe.contentWindow.location;
|
|
120
|
-
if (iframeLocation.host
|
|
121
|
-
iframeLocation.pathname
|
|
122
|
-
windowLocation.host
|
|
123
|
-
windowLocation.pathname) {
|
|
119
|
+
if (iframeLocation.host
|
|
120
|
+
+ iframeLocation.pathname
|
|
121
|
+
=== windowLocation.host
|
|
122
|
+
+ windowLocation.pathname) {
|
|
124
123
|
target.style.display = 'none';
|
|
125
124
|
var iframeUrlParams = new URLSearchParams(iframeLocation.search);
|
|
126
125
|
var captchToken = iframeUrlParams.get('captcha_token');
|
|
127
126
|
if (captchToken) {
|
|
128
127
|
return resolve({
|
|
129
128
|
captcha_token: captchToken,
|
|
130
|
-
expires_in: Number(iframeUrlParams.get('expires_in'))
|
|
129
|
+
expires_in: Number(iframeUrlParams.get('expires_in')),
|
|
131
130
|
});
|
|
132
131
|
}
|
|
133
132
|
return reject({
|
|
134
133
|
error: iframeUrlParams.get('error'),
|
|
135
|
-
error_description: iframeUrlParams.get('error_description')
|
|
134
|
+
error_description: iframeUrlParams.get('error_description'),
|
|
136
135
|
});
|
|
137
136
|
}
|
|
138
|
-
|
|
139
|
-
target.style.display = 'block';
|
|
140
|
-
}
|
|
137
|
+
target.style.display = 'block';
|
|
141
138
|
}
|
|
142
139
|
catch (error) {
|
|
143
140
|
target.style.display = 'block';
|
|
@@ -147,14 +144,14 @@ var Captcha = (function () {
|
|
|
147
144
|
});
|
|
148
145
|
});
|
|
149
146
|
};
|
|
150
|
-
Captcha.prototype.
|
|
147
|
+
Captcha.prototype.getCaptchaToken = function (forceNewToken, state) {
|
|
151
148
|
return __awaiter(this, void 0, void 0, function () {
|
|
152
149
|
var captchaToken_1, redirectURL, captchaTokenResp, captchaToken_2, captchaToken;
|
|
153
150
|
return __generator(this, function (_a) {
|
|
154
151
|
switch (_a.label) {
|
|
155
152
|
case 0:
|
|
156
153
|
if (!!forceNewToken) return [3, 2];
|
|
157
|
-
return [4, this.
|
|
154
|
+
return [4, this.findCaptchaToken()];
|
|
158
155
|
case 1:
|
|
159
156
|
captchaToken_1 = _a.sent();
|
|
160
157
|
if (captchaToken_1) {
|
|
@@ -163,12 +160,12 @@ var Captcha = (function () {
|
|
|
163
160
|
_a.label = 2;
|
|
164
161
|
case 2:
|
|
165
162
|
redirectURL = window.location.origin + window.location.pathname + "?__captcha=on";
|
|
166
|
-
return [4, this.
|
|
163
|
+
return [4, this.config.request(GET_CAPTCHA_URL, {
|
|
167
164
|
method: 'POST',
|
|
168
165
|
body: {
|
|
169
|
-
client_id: this.
|
|
166
|
+
client_id: this.config.clientId,
|
|
170
167
|
redirect_uri: redirectURL,
|
|
171
|
-
state: state
|
|
168
|
+
state: state,
|
|
172
169
|
},
|
|
173
170
|
withCredentials: false,
|
|
174
171
|
})];
|
|
@@ -179,27 +176,27 @@ var Captcha = (function () {
|
|
|
179
176
|
captcha_token: captchaTokenResp.captcha_token,
|
|
180
177
|
expires_in: captchaTokenResp.expires_in,
|
|
181
178
|
};
|
|
182
|
-
this.
|
|
179
|
+
this.saveCaptchaToken(captchaToken_2);
|
|
183
180
|
return [2, captchaTokenResp.captcha_token];
|
|
184
181
|
}
|
|
185
|
-
return [4, this.
|
|
182
|
+
return [4, this.config.openURIWithCallback(captchaTokenResp.url)];
|
|
186
183
|
case 4:
|
|
187
184
|
captchaToken = _a.sent();
|
|
188
|
-
this.
|
|
185
|
+
this.saveCaptchaToken(captchaToken);
|
|
189
186
|
return [2, captchaToken.captcha_token];
|
|
190
187
|
}
|
|
191
188
|
});
|
|
192
189
|
});
|
|
193
190
|
};
|
|
194
|
-
Captcha.prototype.
|
|
191
|
+
Captcha.prototype.appendCaptchaTokenToURL = function (url, state, forceNewToken) {
|
|
195
192
|
return __awaiter(this, void 0, void 0, function () {
|
|
196
193
|
var captchaToken;
|
|
197
194
|
return __generator(this, function (_a) {
|
|
198
195
|
switch (_a.label) {
|
|
199
|
-
case 0: return [4, this.
|
|
196
|
+
case 0: return [4, this.getCaptchaToken(forceNewToken, state)];
|
|
200
197
|
case 1:
|
|
201
198
|
captchaToken = _a.sent();
|
|
202
|
-
if (url.indexOf(
|
|
199
|
+
if (url.indexOf('?') > 0) {
|
|
203
200
|
url += "&captcha_token=" + captchaToken;
|
|
204
201
|
}
|
|
205
202
|
else {
|
|
@@ -210,7 +207,7 @@ var Captcha = (function () {
|
|
|
210
207
|
});
|
|
211
208
|
});
|
|
212
209
|
};
|
|
213
|
-
Captcha.prototype.
|
|
210
|
+
Captcha.prototype.saveCaptchaToken = function (token) {
|
|
214
211
|
return __awaiter(this, void 0, void 0, function () {
|
|
215
212
|
var tokenStr;
|
|
216
213
|
return __generator(this, function (_a) {
|
|
@@ -218,7 +215,7 @@ var Captcha = (function () {
|
|
|
218
215
|
case 0:
|
|
219
216
|
token.expires_at = new Date(Date.now() + (token.expires_in - 10) * 1000);
|
|
220
217
|
tokenStr = JSON.stringify(token);
|
|
221
|
-
return [4, this.
|
|
218
|
+
return [4, this.config.storage.setItem(this.tokenSectionName, tokenStr)];
|
|
222
219
|
case 1:
|
|
223
220
|
_a.sent();
|
|
224
221
|
return [2];
|
|
@@ -226,12 +223,12 @@ var Captcha = (function () {
|
|
|
226
223
|
});
|
|
227
224
|
});
|
|
228
225
|
};
|
|
229
|
-
Captcha.prototype.
|
|
226
|
+
Captcha.prototype.findCaptchaToken = function () {
|
|
230
227
|
return __awaiter(this, void 0, void 0, function () {
|
|
231
228
|
var tokenStr, captchaToken, isExpired, error_1;
|
|
232
229
|
return __generator(this, function (_a) {
|
|
233
230
|
switch (_a.label) {
|
|
234
|
-
case 0: return [4, this.
|
|
231
|
+
case 0: return [4, this.config.storage.getItem(this.tokenSectionName)];
|
|
235
232
|
case 1:
|
|
236
233
|
tokenStr = _a.sent();
|
|
237
234
|
if (!(tokenStr !== undefined && tokenStr !== null)) return [3, 5];
|
|
@@ -249,7 +246,7 @@ var Captcha = (function () {
|
|
|
249
246
|
return [2, captchaToken.captcha_token];
|
|
250
247
|
case 3:
|
|
251
248
|
error_1 = _a.sent();
|
|
252
|
-
return [4, this.
|
|
249
|
+
return [4, this.config.storage.removeItem(this.tokenSectionName)];
|
|
253
250
|
case 4:
|
|
254
251
|
_a.sent();
|
|
255
252
|
return [2, null];
|
|
@@ -261,4 +258,4 @@ var Captcha = (function () {
|
|
|
261
258
|
return Captcha;
|
|
262
259
|
}());
|
|
263
260
|
export { Captcha };
|
|
264
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"captcha.js","sourceRoot":"","sources":["../../../src/captcha/captcha.ts"],"names":[],"mappings":"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","sourcesContent":["import { SimpleStorage, RequestFunction } from '../oauth2client/interface';\nimport { AuthClientRequestOptions } from \"../oauth2client/models\";\nimport { defaultStorage } from \"../oauth2client/oauth2client\";\n\nexport interface CaptchaOptions {\n  clientId: string\n  request: RequestFunction;\n  storage: SimpleStorage;\n  // 打开网页并通过URL回调获取 CaptchaToken，针对不通的平台，该函数可以自定义实现, 默认集成浏览器端认证\n  openURIWithCallback?: OpenURIWithCallbackFuction;\n}\n\ntype OpenURIWithCallbackFuction = (url: string) => Promise<CaptchaToken>;\n\nexport interface CaptchaToken {\n  captcha_token: string\n  expires_in: number\n  expires_at?: Date | null;\n}\n\nexport interface CaptchaRequestOptions extends AuthClientRequestOptions {\n  withCaptcha?: boolean;\n}\n\nexport interface GetCaptchaResponse {\n  captcha_token?: string\n  expires_in?: number\n  url?: string\n}\n\nconst GET_CAPTCHA_URL = '/auth/v1/captcha/init'\n\nexport class Captcha {\n  private _config: CaptchaOptions;\n  private _tokenSectionName: string;\n\n  /**\n   * constructor\n   * @param {CaptchaOptions} opts\n   */\n  constructor(opts: CaptchaOptions) {\n    if (!opts.openURIWithCallback) {\n      opts.openURIWithCallback = this._getDefaultOpenURIWithCallback()\n    }\n    if (!opts.storage) {\n      opts.storage = defaultStorage\n    }\n    this._config = opts\n    this._tokenSectionName = 'captcha_' + opts.clientId\n  }\n\n  /**\n   * request http like simple fetch api, exp:request('/v1/user/me', {withCredentials:true})\n   * @param {string} url\n   * @param {AuthClientRequestOptions} options\n   */\n  public async request<T>(\n    url: string,\n    options?: CaptchaRequestOptions,\n  ): Promise<T> {\n    if (!options) {\n      options = {};\n    }\n    if (!options.method) {\n      options.method = 'GET'\n    }\n    const state = options.method + \":\" + url\n    let reqURL = url;\n    if (options.withCaptcha) {\n      reqURL = await this._appendCaptchaTokenToURL(url, state, false);\n    }\n\n    let resp: T;\n    try {\n      resp = await this._config.request<T>(reqURL, options)\n    } catch (err) {\n      if (err.error === 'captcha_required' || err.error === 'captcha_invalid') {\n        url = await this._appendCaptchaTokenToURL(url, state, err.error === 'captcha_invalid')\n        return this._config.request<T>(url, options)\n      } else {\n        return Promise.reject(err)\n      }\n    }\n    return resp\n  }\n\n  private _getDefaultOpenURIWithCallback(): OpenURIWithCallbackFuction {\n    if (window.location.search.indexOf('__captcha') > 0) {\n      document.body.style.display = 'none';\n    }\n    if (document.getElementById('captcha_panel_wrap') === null) {\n      var elementDiv = document.createElement('div');\n      elementDiv.style.cssText =\n        'background-color: rgba(0, 0, 0, 0.7);position: fixed;left: 0px;right: 0px;top: 0px;bottom: 0px;padding: 9vw 0 0 0;display: none;z-index:100;';\n      elementDiv.setAttribute('id', 'captcha_panel_wrap');\n      setTimeout(() => {\n        document.body.appendChild(elementDiv);\n      }, 0)\n    }\n    return this._defaultOpenURIWithCallback\n  }\n\n  /**\n   * 默认通过浏览器打开网页并获取回调\n   */\n  private async _defaultOpenURIWithCallback(url: string): Promise<CaptchaToken> {\n    const target = document.getElementById('captcha_panel_wrap'),\n      iframe = document.createElement('iframe')\n    target.innerHTML = '';\n    iframe.setAttribute('src', url)\n    iframe.setAttribute('id', 'review-panel-iframe')\n    iframe.style.cssText = 'min-width:355px;display:block;height:355px;margin:0 auto;background-color: rgb(255, 255, 255);border: none;';\n    target.appendChild(iframe);\n    target.style.display = 'block';\n    return new Promise<CaptchaToken>((resolve, reject) => {\n      iframe.onload = function () {\n        try {\n          var windowLocation = window.location;\n          var iframeLocation = iframe.contentWindow.location;\n          if (\n            iframeLocation.host +\n            iframeLocation.pathname ===\n            windowLocation.host +\n            windowLocation.pathname\n          ) {\n            target.style.display = 'none';\n            const iframeUrlParams = new URLSearchParams(iframeLocation.search);\n            const captchToken = iframeUrlParams.get('captcha_token');\n            if (captchToken) {\n              return resolve({\n                captcha_token: captchToken,\n                expires_in: Number(iframeUrlParams.get('expires_in'))\n              })\n            }\n            return reject({\n              error: iframeUrlParams.get('error'),\n              error_description: iframeUrlParams.get('error_description')\n            })\n          } else {\n            target.style.display = 'block';\n          }\n        } catch (error) {\n          target.style.display = 'block';\n        }\n      };\n    })\n  }\n  /**\n   * _getCaptchaToken 获取captchaToken\n   */\n  private async _getCaptchaToken(forceNewToken: boolean, state: string): Promise<string> {\n    if (!forceNewToken) {\n      // 如果本地存在，则直接返回\n      const captchaToken = await this._findCaptchaToken()\n      if (captchaToken) {\n        return captchaToken\n      }\n    }\n    const redirectURL = window.location.origin + window.location.pathname + \"?__captcha=on\"\n    const captchaTokenResp = await this._config.request<GetCaptchaResponse>(GET_CAPTCHA_URL, {\n      method: 'POST',\n      body: {\n        client_id: this._config.clientId,\n        redirect_uri: redirectURL,\n        state: state\n      },\n      withCredentials: false,\n    })\n    if (captchaTokenResp.captcha_token) {\n      const captchaToken = {\n        captcha_token: captchaTokenResp.captcha_token,\n        expires_in: captchaTokenResp.expires_in,\n      }\n      this._saveCaptchaToken(captchaToken)\n      return captchaTokenResp.captcha_token\n    }\n    const captchaToken = await this._config.openURIWithCallback(captchaTokenResp.url)\n    this._saveCaptchaToken(captchaToken)\n    return captchaToken.captcha_token\n  }\n\n  private async _appendCaptchaTokenToURL(url: string, state: string, forceNewToken: boolean): Promise<string> {\n    const captchaToken = await this._getCaptchaToken(forceNewToken, state);\n    if (url.indexOf(\"?\") > 0) {\n      url += \"&captcha_token=\" + captchaToken\n    } else {\n      url += \"?captcha_token=\" + captchaToken\n    }\n    return url\n  }\n\n  private async _saveCaptchaToken(token: CaptchaToken) {\n    token.expires_at = new Date(\n      Date.now() + (token.expires_in - 10) * 1000,\n    );\n    const tokenStr: string = JSON.stringify(token);\n    await this._config.storage.setItem(this._tokenSectionName, tokenStr);\n  }\n\n  private async _findCaptchaToken(): Promise<string> {\n    const tokenStr: string = await this._config.storage.getItem(\n      this._tokenSectionName,\n    );\n    if (tokenStr !== undefined && tokenStr !== null) {\n      try {\n        const captchaToken = JSON.parse(tokenStr);\n        if (captchaToken?.expires_at) {\n          captchaToken.expires_at = new Date(captchaToken.expires_at);\n        }\n        const isExpired = captchaToken.expires_at < new Date();\n        if (isExpired) {\n          return null\n        }\n        return captchaToken.captcha_token\n      } catch (error) {\n        await this._config.storage.removeItem(this._tokenSectionName);\n        return null\n      }\n    }\n    return null\n  }\n}"]}
|
|
261
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"captcha.js","sourceRoot":"","sources":["../../../src/captcha/captcha.ts"],"names":[],"mappings":"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","sourcesContent":["import { SimpleStorage, RequestFunction } from '../oauth2client/interface'\nimport { AuthClientRequestOptions } from '../oauth2client/models'\nimport { defaultStorage } from '../oauth2client/oauth2client'\n\nexport interface CaptchaOptions {\n  clientId: string\n  request: RequestFunction;\n  storage: SimpleStorage;\n  // 打开网页并通过URL回调获取 CaptchaToken，针对不通的平台，该函数可以自定义实现, 默认集成浏览器端认证\n  openURIWithCallback?: OpenURIWithCallbackFuction;\n}\n\ntype OpenURIWithCallbackFuction = (url: string) => Promise<CaptchaToken>;\n\nexport interface CaptchaToken {\n  captcha_token: string\n  expires_in: number\n  expires_at?: Date | null;\n}\n\nexport interface CaptchaRequestOptions extends AuthClientRequestOptions {\n  withCaptcha?: boolean;\n}\n\nexport interface GetCaptchaResponse {\n  captcha_token?: string\n  expires_in?: number\n  url?: string\n}\n\nconst GET_CAPTCHA_URL = '/auth/v1/captcha/init'\n\nexport class Captcha {\n  private config: CaptchaOptions\n  private tokenSectionName: string\n\n  /**\n   * constructor\n   * @param {CaptchaOptions} opts\n   */\n  constructor(opts: CaptchaOptions) {\n    if (!opts.openURIWithCallback) {\n      opts.openURIWithCallback = this.getDefaultOpenURIWithCallback()\n    }\n    if (!opts.storage) {\n      opts.storage = defaultStorage\n    }\n    this.config = opts\n    this.tokenSectionName = `captcha_${opts.clientId}`\n  }\n\n  /**\n   * request http like simple fetch api, exp:request('/v1/user/me', {withCredentials:true})\n   * @param {string} url\n   * @param {AuthClientRequestOptions} options\n   */\n  public async request<T>(\n    url: string,\n    options?: CaptchaRequestOptions,\n  ): Promise<T> {\n    if (!options) {\n      options = {}\n    }\n    if (!options.method) {\n      options.method = 'GET'\n    }\n    const state = `${options.method}:${url}`\n    let reqURL = url\n    if (options.withCaptcha) {\n      reqURL = await this.appendCaptchaTokenToURL(url, state, false)\n    }\n\n    let resp: T\n    try {\n      resp = await this.config.request<T>(reqURL, options)\n    } catch (err) {\n      if (err.error === 'captcha_required' || err.error === 'captcha_invalid') {\n        url = await this.appendCaptchaTokenToURL(url, state, err.error === 'captcha_invalid')\n        return this.config.request<T>(url, options)\n      }\n      return Promise.reject(err)\n    }\n    return resp\n  }\n\n  private getDefaultOpenURIWithCallback(): OpenURIWithCallbackFuction {\n    if (window.location.search.indexOf('__captcha') > 0) {\n      document.body.style.display = 'none'\n    }\n    if (document.getElementById('captcha_panel_wrap') === null) {\n      const elementDiv = document.createElement('div')\n      elementDiv.style.cssText =        'background-color: rgba(0, 0, 0, 0.7);position: fixed;left: 0px;right: 0px;top: 0px;bottom: 0px;padding: 9vw 0 0 0;display: none;z-index:100;'\n      elementDiv.setAttribute('id', 'captcha_panel_wrap')\n      setTimeout(() => {\n        document.body.appendChild(elementDiv)\n      }, 0)\n    }\n    return this.defaultOpenURIWithCallback\n  }\n\n  /**\n   * 默认通过浏览器打开网页并获取回调\n   */\n  private async defaultOpenURIWithCallback(url: string): Promise<CaptchaToken> {\n    const target = document.getElementById('captcha_panel_wrap')\n    const iframe = document.createElement('iframe')\n    target.innerHTML = ''\n    iframe.setAttribute('src', url)\n    iframe.setAttribute('id', 'review-panel-iframe')\n    iframe.style.cssText = 'min-width:355px;display:block;height:355px;margin:0 auto;background-color: rgb(255, 255, 255);border: none;'\n    target.appendChild(iframe)\n    target.style.display = 'block'\n    return new Promise<CaptchaToken>((resolve, reject) => {\n      iframe.onload = function () {\n        try {\n          const windowLocation = window.location\n          const iframeLocation = iframe.contentWindow.location\n          if (\n            iframeLocation.host\n            + iframeLocation.pathname\n            === windowLocation.host\n            + windowLocation.pathname\n          ) {\n            target.style.display = 'none'\n            const iframeUrlParams = new URLSearchParams(iframeLocation.search)\n            const captchToken = iframeUrlParams.get('captcha_token')\n            if (captchToken) {\n              return resolve({\n                captcha_token: captchToken,\n                expires_in: Number(iframeUrlParams.get('expires_in')),\n              })\n            }\n            return reject({\n              error: iframeUrlParams.get('error'),\n              error_description: iframeUrlParams.get('error_description'),\n            })\n          }\n          target.style.display = 'block'\n        } catch (error) {\n          target.style.display = 'block'\n        }\n      }\n    })\n  }\n  /**\n   * getCaptchaToken 获取captchaToken\n   */\n  private async getCaptchaToken(forceNewToken: boolean, state: string): Promise<string> {\n    if (!forceNewToken) {\n      // 如果本地存在，则直接返回\n      const captchaToken = await this.findCaptchaToken()\n      if (captchaToken) {\n        return captchaToken\n      }\n    }\n    const redirectURL = `${window.location.origin + window.location.pathname}?__captcha=on`\n    const captchaTokenResp = await this.config.request<GetCaptchaResponse>(GET_CAPTCHA_URL, {\n      method: 'POST',\n      body: {\n        client_id: this.config.clientId,\n        redirect_uri: redirectURL,\n        state,\n      },\n      withCredentials: false,\n    })\n    if (captchaTokenResp.captcha_token) {\n      const captchaToken = {\n        captcha_token: captchaTokenResp.captcha_token,\n        expires_in: captchaTokenResp.expires_in,\n      }\n      this.saveCaptchaToken(captchaToken)\n      return captchaTokenResp.captcha_token\n    }\n    const captchaToken = await this.config.openURIWithCallback(captchaTokenResp.url)\n    this.saveCaptchaToken(captchaToken)\n    return captchaToken.captcha_token\n  }\n\n  private async appendCaptchaTokenToURL(url: string, state: string, forceNewToken: boolean): Promise<string> {\n    const captchaToken = await this.getCaptchaToken(forceNewToken, state)\n    if (url.indexOf('?') > 0) {\n      url += `&captcha_token=${captchaToken}`\n    } else {\n      url += `?captcha_token=${captchaToken}`\n    }\n    return url\n  }\n\n  private async saveCaptchaToken(token: CaptchaToken) {\n    token.expires_at = new Date(Date.now() + (token.expires_in - 10) * 1000,)\n    const tokenStr: string = JSON.stringify(token)\n    await this.config.storage.setItem(this.tokenSectionName, tokenStr)\n  }\n\n  private async findCaptchaToken(): Promise<string> {\n    const tokenStr: string = await this.config.storage.getItem(this.tokenSectionName,)\n    if (tokenStr !== undefined && tokenStr !== null) {\n      try {\n        const captchaToken = JSON.parse(tokenStr)\n        if (captchaToken?.expires_at) {\n          captchaToken.expires_at = new Date(captchaToken.expires_at)\n        }\n        const isExpired = captchaToken.expires_at < new Date()\n        if (isExpired) {\n          return null\n        }\n        return captchaToken.captcha_token\n      } catch (error) {\n        await this.config.storage.removeItem(this.tokenSectionName)\n        return null\n      }\n    }\n    return null\n  }\n}\n"]}
|
package/dist/esm/index.d.ts
CHANGED
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
export { Syntax, ErrorType } from './oauth2client/consts';
|
|
2
1
|
import { OAuth2Client } from './oauth2client/oauth2client';
|
|
2
|
+
import { AuthOptions, Auth } from './auth/apis';
|
|
3
|
+
import * as authModels from './auth/models';
|
|
4
|
+
export { Syntax, ErrorType } from './oauth2client/consts';
|
|
3
5
|
export { defaultStorage, defaultRequest, ToResponseErrorOptions, toResponseError, generateRequestId, OAuth2Client, } from './oauth2client/oauth2client';
|
|
4
6
|
export { AuthClient, SimpleStorage } from './oauth2client/interface';
|
|
5
7
|
export { Credentials, ResponseError, OAuth2ClientOptions, AuthClientRequestOptions, } from './oauth2client/models';
|
|
6
|
-
import { AuthOptions, Auth } from './auth/apis';
|
|
7
8
|
export { AuthOptions, Auth } from './auth/apis';
|
|
8
|
-
import * as authModels from './auth/models';
|
|
9
9
|
export { authModels };
|
|
10
10
|
export declare class CloudbaseOAuth {
|
|
11
11
|
oauth2client: OAuth2Client;
|
package/dist/esm/index.js
CHANGED
|
@@ -9,24 +9,24 @@ var __assign = (this && this.__assign) || function () {
|
|
|
9
9
|
};
|
|
10
10
|
return __assign.apply(this, arguments);
|
|
11
11
|
};
|
|
12
|
-
export { Syntax, ErrorType } from './oauth2client/consts';
|
|
13
12
|
import { OAuth2Client } from './oauth2client/oauth2client';
|
|
13
|
+
import { Auth } from './auth/apis';
|
|
14
|
+
import * as authModels from './auth/models';
|
|
15
|
+
export { Syntax, ErrorType } from './oauth2client/consts';
|
|
14
16
|
export { defaultStorage, defaultRequest, toResponseError, generateRequestId, OAuth2Client, } from './oauth2client/oauth2client';
|
|
15
17
|
export { AuthClient } from './oauth2client/interface';
|
|
16
|
-
import { Auth } from './auth/apis';
|
|
17
18
|
export { Auth } from './auth/apis';
|
|
18
|
-
import * as authModels from './auth/models';
|
|
19
19
|
export { authModels };
|
|
20
20
|
var CloudbaseOAuth = (function () {
|
|
21
21
|
function CloudbaseOAuth(authOptions) {
|
|
22
22
|
var apiOrigin = authOptions.apiOrigin, clientId = authOptions.clientId;
|
|
23
23
|
this.oauth2client = new OAuth2Client({
|
|
24
24
|
apiOrigin: apiOrigin,
|
|
25
|
-
clientId: clientId
|
|
25
|
+
clientId: clientId,
|
|
26
26
|
});
|
|
27
27
|
this.authApi = new Auth(__assign({ credentialsClient: this.oauth2client }, authOptions));
|
|
28
28
|
}
|
|
29
29
|
return CloudbaseOAuth;
|
|
30
30
|
}());
|
|
31
31
|
export { CloudbaseOAuth };
|
|
32
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7QUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sNkJBQTZCLENBQUE7QUFFMUQsT0FBTyxFQUFlLElBQUksRUFBRSxNQUFNLGFBQWEsQ0FBQTtBQUUvQyxPQUFPLEtBQUssVUFBVSxNQUFNLGVBQWUsQ0FBQTtBQUUzQyxPQUFPLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBRSxNQUFNLHVCQUF1QixDQUFBO0FBRXpELE9BQU8sRUFDTCxjQUFjLEVBQ2QsY0FBYyxFQUVkLGVBQWUsRUFDZixpQkFBaUIsRUFDakIsWUFBWSxHQUNiLE1BQU0sNkJBQTZCLENBQUE7QUFFcEMsT0FBTyxFQUFFLFVBQVUsRUFBaUIsTUFBTSwwQkFBMEIsQ0FBQTtBQVNwRSxPQUFPLEVBQWUsSUFBSSxFQUFFLE1BQU0sYUFBYSxDQUFBO0FBQy9DLE9BQU8sRUFBRSxVQUFVLEVBQUUsQ0FBQTtBQUdyQjtJQUlFLHdCQUFZLFdBQXdCO1FBQzFCLElBQUEsU0FBUyxHQUFlLFdBQVcsVUFBMUIsRUFBRSxRQUFRLEdBQUssV0FBVyxTQUFoQixDQUFnQjtRQUMzQyxJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksWUFBWSxDQUFDO1lBQ25DLFNBQVMsV0FBQTtZQUNULFFBQVEsVUFBQTtTQUNULENBQUMsQ0FBQTtRQUVGLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxJQUFJLFlBQ3JCLGlCQUFpQixFQUFFLElBQUksQ0FBQyxZQUFZLElBQ2pDLFdBQVcsRUFDZCxDQUFBO0lBQ0osQ0FBQztJQUNILHFCQUFDO0FBQUQsQ0FBQyxBQWhCRCxJQWdCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE9BdXRoMkNsaWVudCB9IGZyb20gJy4vb2F1dGgyY2xpZW50L29hdXRoMmNsaWVudCdcblxuaW1wb3J0IHsgQXV0aE9wdGlvbnMsIEF1dGggfSBmcm9tICcuL2F1dGgvYXBpcydcblxuaW1wb3J0ICogYXMgYXV0aE1vZGVscyBmcm9tICcuL2F1dGgvbW9kZWxzJ1xuXG5leHBvcnQgeyBTeW50YXgsIEVycm9yVHlwZSB9IGZyb20gJy4vb2F1dGgyY2xpZW50L2NvbnN0cydcblxuZXhwb3J0IHtcbiAgZGVmYXVsdFN0b3JhZ2UsXG4gIGRlZmF1bHRSZXF1ZXN0LFxuICBUb1Jlc3BvbnNlRXJyb3JPcHRpb25zLFxuICB0b1Jlc3BvbnNlRXJyb3IsXG4gIGdlbmVyYXRlUmVxdWVzdElkLFxuICBPQXV0aDJDbGllbnQsXG59IGZyb20gJy4vb2F1dGgyY2xpZW50L29hdXRoMmNsaWVudCdcblxuZXhwb3J0IHsgQXV0aENsaWVudCwgU2ltcGxlU3RvcmFnZSB9IGZyb20gJy4vb2F1dGgyY2xpZW50L2ludGVyZmFjZSdcblxuZXhwb3J0IHtcbiAgQ3JlZGVudGlhbHMsXG4gIFJlc3BvbnNlRXJyb3IsXG4gIE9BdXRoMkNsaWVudE9wdGlvbnMsXG4gIEF1dGhDbGllbnRSZXF1ZXN0T3B0aW9ucyxcbn0gZnJvbSAnLi9vYXV0aDJjbGllbnQvbW9kZWxzJ1xuXG5leHBvcnQgeyBBdXRoT3B0aW9ucywgQXV0aCB9IGZyb20gJy4vYXV0aC9hcGlzJ1xuZXhwb3J0IHsgYXV0aE1vZGVscyB9XG5cblxuZXhwb3J0IGNsYXNzIENsb3VkYmFzZU9BdXRoIHtcbiAgcHVibGljIG9hdXRoMmNsaWVudDogT0F1dGgyQ2xpZW50XG4gIHB1YmxpYyBhdXRoQXBpOiBBdXRoXG5cbiAgY29uc3RydWN0b3IoYXV0aE9wdGlvbnM6IEF1dGhPcHRpb25zKSB7XG4gICAgY29uc3QgeyBhcGlPcmlnaW4sIGNsaWVudElkIH0gPSBhdXRoT3B0aW9uc1xuICAgIHRoaXMub2F1dGgyY2xpZW50ID0gbmV3IE9BdXRoMkNsaWVudCh7XG4gICAgICBhcGlPcmlnaW4sXG4gICAgICBjbGllbnRJZCxcbiAgICB9KVxuXG4gICAgdGhpcy5hdXRoQXBpID0gbmV3IEF1dGgoe1xuICAgICAgY3JlZGVudGlhbHNDbGllbnQ6IHRoaXMub2F1dGgyY2xpZW50LFxuICAgICAgLi4uYXV0aE9wdGlvbnMsXG4gICAgfSlcbiAgfVxufVxuXG4iXX0=
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { Credentials, AuthClientRequestOptions } from './models';
|
|
2
2
|
export declare abstract class AuthClient {
|
|
3
|
-
abstract setCredentials(credentials?: Credentials): void;
|
|
4
3
|
abstract request: RequestFunction;
|
|
4
|
+
abstract setCredentials(credentials?: Credentials): void;
|
|
5
5
|
abstract getAccessToken(): Promise<string>;
|
|
6
6
|
}
|
|
7
7
|
export declare type RequestFunction = <T>(url: string, options?: AuthClientRequestOptions) => Promise<T>;
|
|
@@ -4,4 +4,4 @@ var AuthClient = (function () {
|
|
|
4
4
|
return AuthClient;
|
|
5
5
|
}());
|
|
6
6
|
export { AuthClient };
|
|
7
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL29hdXRoMmNsaWVudC9pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBS0E7SUFBQTtJQW9CQSxDQUFDO0lBQUQsaUJBQUM7QUFBRCxDQUFDLEFBcEJELElBb0JDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ3JlZGVudGlhbHMsIEF1dGhDbGllbnRSZXF1ZXN0T3B0aW9ucyB9IGZyb20gJy4vbW9kZWxzJ1xuXG4vKipcbiAqIHRoZSBpbnRlcmZhY2UgZm9yIHRoZSBPYXV0aDJDbGllbnRcbiAqL1xuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEF1dGhDbGllbnQge1xuICAvKipcbiAgICogUHJvdmlkZXMgYW4gYWx0ZXJuYXRpdmUgZmV0Y2ggYXBpIHJlcXVlc3QgaW1wbGVtZW50YXRpb24gd2l0aCBhdXRoIGNyZWRlbnRpYWxzXG4gICAqIGlmIG9wdGlvbnMud2l0aENyZWRlbnRpYWxzOnRydWUsIHRoZSByZXF1ZXN0IHdpbGwgYXV0byBhZGQgQXV0aG9yaXphdGlvbjogQmVhcmVyIDxBY2Nlc3NUb2tlbj4gaW4gdGhlIHJlcXVlc3RcbiAgICogZXJyb3I6XG4gICAqICAgICAtIHVucmVhY2hhYmxlLCB0aGUgbmV0d29yayBlcnJvciBvciByZXNwb25zZSBpcyBub3QganNvblxuICAgKiAgICAgLSB1bmF1dGhlbnRpY2F0ZWQ6IGhhcyBubyB2YWxpZGF0ZSBhY2Nlc3MgdG9rZW5cbiAgICovXG4gIGFic3RyYWN0IHJlcXVlc3Q6IFJlcXVlc3RGdW5jdGlvbjtcbiAgLyoqXG4gICAqIFNldHMgdGhlIGF1dGggY3JlZGVudGlhbHMuXG4gICAqL1xuICBhYnN0cmFjdCBzZXRDcmVkZW50aWFscyhjcmVkZW50aWFscz86IENyZWRlbnRpYWxzKTogdm9pZDtcblxuICAvKipcbiAgICogZ2V0IHRoZSBjdXJyZW50IGFjY2Vzc1Rva2VuIGZyb20gQXV0aENsaWVudCwgeW91IGNhbiB1c2UgdGhpcyB0byBkZXRlY3QgbG9naW4gc3RhdHVzXG4gICAqIGVycm9yOlxuICAgKiAgICAtICB1bmF1dGhlbnRpY2F0ZWQ6IGhhcyBubyB2YWxpZGF0ZSBhY2Nlc3MgdG9rZW5cbiAgICovXG4gIGFic3RyYWN0IGdldEFjY2Vzc1Rva2VuKCk6IFByb21pc2U8c3RyaW5nPjtcbn1cblxuZXhwb3J0IHR5cGUgUmVxdWVzdEZ1bmN0aW9uID0gPFQ+KHVybDogc3RyaW5nLCBvcHRpb25zPzogQXV0aENsaWVudFJlcXVlc3RPcHRpb25zKSA9PiBQcm9taXNlPFQ+O1xuXG4vKiogQW4gaW50ZXJmYWNlIG9mIHRoZSBTaW1wbGUgIFdlYiBTdG9yYWdlIEFQSSAgKi9cbmV4cG9ydCBpbnRlcmZhY2UgU2ltcGxlU3RvcmFnZSB7XG4gIC8qKlxuICAgKiB2YWx1ZSA9IHN0b3JhZ2Vba2V5XVxuICAgKi9cbiAgZ2V0SXRlbTogKGtleTogc3RyaW5nKSA9PiBQcm9taXNlPHN0cmluZyB8IG51bGw+O1xuICAvKipcbiAgICogZGVsZXRlIHN0b3JhZ2Vba2V5XVxuICAgKi9cbiAgcmVtb3ZlSXRlbTogKGtleTogc3RyaW5nKSA9PiBQcm9taXNlPHZvaWQ+O1xuICAvKipcbiAgICogc3RvcmFnZVtrZXldID0gdmFsdWVcbiAgICovXG4gIHNldEl0ZW06IChrZXk6IHN0cmluZywgdmFsdWU6IHN0cmluZykgPT4gUHJvbWlzZTx2b2lkPjtcblxuICAvKipcbiAgICogdmFsdWUgPSBzdG9yYWdlW2tleV1cbiAgICovXG4gIGdldEl0ZW1TeW5jOiAoa2V5OiBzdHJpbmcpID0+IHN0cmluZyB8IG51bGw7XG4gIC8qKlxuICAgKiBkZWxldGUgc3RvcmFnZVtrZXldXG4gICAqL1xuICByZW1vdmVJdGVtU3luYzogKGtleTogc3RyaW5nKSA9PiB2b2lkO1xuICAvKipcbiAgICogc3RvcmFnZVtrZXldID0gdmFsdWVcbiAgICovXG4gIHNldEl0ZW1TeW5jOiAoa2V5OiBzdHJpbmcsIHZhbHVlOiBzdHJpbmcpID0+IHZvaWQ7XG59XG4iXX0=
|
|
@@ -1 +1 @@
|
|
|
1
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kZWxzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL29hdXRoMmNsaWVudC9tb2RlbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNpbXBsZVN0b3JhZ2UgfSBmcm9tICcuL2ludGVyZmFjZSdcbmltcG9ydCB7IEVycm9yVHlwZSB9IGZyb20gJy4vY29uc3RzJ1xuXG4vKiogQ3JlZGVudGlhbHMgKiovXG5leHBvcnQgaW50ZXJmYWNlIENyZWRlbnRpYWxzIHtcbiAgdG9rZW5fdHlwZT86IHN0cmluZyB8IG51bGw7XG4gIGFjY2Vzc190b2tlbj86IHN0cmluZyB8IG51bGw7XG4gIHJlZnJlc2hfdG9rZW4/OiBzdHJpbmcgfCBudWxsO1xuICBzY29wZT86IHN0cmluZyB8IG51bGw7XG4gIGV4cGlyZXNfaW4/OiBudW1iZXIgfCBudWxsO1xuICBleHBpcmVzX2F0PzogRGF0ZSB8IG51bGw7XG4gIHN1Yj86IHN0cmluZyB8IG51bGw7XG4gIGdyb3Vwcz86IHN0cmluZ1tdIHwgbnVsbDtcbn1cblxuLyoqIEFuIEVycm9yIEZvciBhbGwgY29uY2VybiAqKi9cbmV4cG9ydCBpbnRlcmZhY2UgUmVzcG9uc2VFcnJvciB7XG4gIGVycm9yOiBFcnJvclR5cGU7XG4gIGVycm9yX2Rlc2NyaXB0aW9uPzogc3RyaW5nIHwgbnVsbDtcbiAgZXJyb3JfdXJpPzogc3RyaW5nIHwgbnVsbDtcbiAgZGV0YWlscz86IGFueSB8IG51bGw7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUmVxdWVzdE9wdGlvbnMge1xuICBib2R5PzogYW55IHwgbnVsbDtcbiAgaGVhZGVycz86IGFueSB8IG51bGw7XG4gIG1ldGhvZD86IHN0cmluZztcblxuICBba2V5OiBzdHJpbmddOiBhbnk7XG59XG5cbmV4cG9ydCB0eXBlIFJlcXVlc3RGdW5jdGlvbiA9IDxUPihcbiAgICB1cmw6IHN0cmluZyxcbiAgICBvcHRpb25zPzogUmVxdWVzdE9wdGlvbnMsXG4pID0+IFByb21pc2U8VD47XG5cbmV4cG9ydCBpbnRlcmZhY2UgQXV0aENsaWVudFJlcXVlc3RPcHRpb25zIGV4dGVuZHMgUmVxdWVzdE9wdGlvbnMge1xuICBoZWFkZXJzPzoge1xuICAgICd4LXJlcXVlc3QtaWQnPzogc3RyaW5nO1xuICAgIFtrZXk6IHN0cmluZ106IGFueTtcbiAgfSB8IG51bGw7XG4gIHdpdGhDcmVkZW50aWFscz86IGJvb2xlYW47XG4gIHJldHJ5PzogbnVtYmVyO1xuXG4gIFtrZXk6IHN0cmluZ106IGFueTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBPQXV0aDJDbGllbnRPcHRpb25zIHtcbiAgZGV2TW9kZT86IGJvb2xlYW47XG4gIGFwaU9yaWdpbjogc3RyaW5nO1xuICBjbGllbnRJZDogc3RyaW5nO1xuICAvLyBkZWZhdWx0IHZhbHVlIGlzIDEsbWluIHZhbHVlIGlzIDAsIG1heCB2YWx1ZSBpcyA1XG4gIHJldHJ5PzogbnVtYmVyO1xuICBiYXNlUmVxdWVzdD86IDxUPih1cmw6IHN0cmluZywgb3B0aW9ucz86IFJlcXVlc3RPcHRpb25zKSA9PiBQcm9taXNlPFQ+O1xuICAvLyBTdG9yYWdlLCBkZWZhdWx0IGlzIGxvY2FsU3RvcmFnZSwgc2V0SXRlbShrLCB2KSwgZ2V0SXRlbShrKSxyZW1vdmVJdGVtKGspXG4gIHN0b3JhZ2U/OiBTaW1wbGVTdG9yYWdlO1xuICBjbGllbnRTZWNyZXQ/OiBzdHJpbmc7XG4gIHJlZnJlc2hUb2tlbkZ1bmM/OiAocmVmcmVzaFRva2VuPzogc3RyaW5nKSA9PiBQcm9taXNlPENyZWRlbnRpYWxzPjtcbiAgLy8gc2V0IHRoZSB0b2tlbiBpbiB1cmwgcXVlcnkgaW5zdGVhZCBvZiBoZWFkZXJcbiAgdG9rZW5JblVSTD86IGJvb2xlYW47XG4gIGhlYWRlcnM/OiB7IFtrZXk6IHN0cmluZ106IHN0cmluZyB9O1xufVxuIl19
|
|
@@ -24,49 +24,49 @@ interface LocalCredentialsOptions {
|
|
|
24
24
|
storage: SimpleStorage;
|
|
25
25
|
}
|
|
26
26
|
export declare class LocalCredentials {
|
|
27
|
-
private
|
|
28
|
-
private
|
|
29
|
-
private
|
|
30
|
-
private
|
|
27
|
+
private tokenSectionName;
|
|
28
|
+
private storage;
|
|
29
|
+
private credentials;
|
|
30
|
+
private singlePromise;
|
|
31
31
|
constructor(options: LocalCredentialsOptions);
|
|
32
|
+
getStorageCredentialsSync(): Credentials | null;
|
|
32
33
|
setCredentials(credentials?: Credentials): Promise<void>;
|
|
33
34
|
getCredentials(): Promise<Credentials | null>;
|
|
34
|
-
private
|
|
35
|
-
_getStorageCredentialsSync(): Credentials | null;
|
|
35
|
+
private getStorageCredentials;
|
|
36
36
|
}
|
|
37
37
|
export declare class OAuth2Client implements AuthClient {
|
|
38
|
-
private static
|
|
39
|
-
private static
|
|
40
|
-
private static
|
|
41
|
-
private static
|
|
42
|
-
private
|
|
43
|
-
private
|
|
44
|
-
private
|
|
45
|
-
private
|
|
46
|
-
private
|
|
47
|
-
private
|
|
48
|
-
private
|
|
49
|
-
private
|
|
50
|
-
private
|
|
51
|
-
private
|
|
52
|
-
private
|
|
53
|
-
private
|
|
38
|
+
private static defaultRetry;
|
|
39
|
+
private static minRetry;
|
|
40
|
+
private static maxRetry;
|
|
41
|
+
private static retryInterval;
|
|
42
|
+
private apiOrigin;
|
|
43
|
+
private clientId;
|
|
44
|
+
private retry;
|
|
45
|
+
private clientSecret?;
|
|
46
|
+
private baseRequest;
|
|
47
|
+
private localCredentials;
|
|
48
|
+
private storage;
|
|
49
|
+
private deviceID?;
|
|
50
|
+
private tokenInURL?;
|
|
51
|
+
private refreshTokenFunc;
|
|
52
|
+
private headers?;
|
|
53
|
+
private singlePromise;
|
|
54
54
|
constructor(options: OAuth2ClientOptions);
|
|
55
55
|
setCredentials(credentials?: Credentials): Promise<void>;
|
|
56
56
|
getAccessToken(): Promise<string>;
|
|
57
57
|
request<T>(url: string, options?: AuthClientRequestOptions): Promise<T>;
|
|
58
|
-
|
|
59
|
-
private _formatRetry;
|
|
60
|
-
private _sleep;
|
|
61
|
-
private _refreshToken;
|
|
62
|
-
private _anonymousSignIn;
|
|
63
|
-
private _defaultRefreshTokenFunc;
|
|
64
|
-
_getCredentials(): Promise<Credentials | null>;
|
|
58
|
+
getCredentials(): Promise<Credentials | null>;
|
|
65
59
|
getCredentialsSync(): Credentials | null;
|
|
66
60
|
getCredentialsAsync(): Promise<Credentials | null>;
|
|
67
61
|
getScope(): Promise<string>;
|
|
68
62
|
getGroups(): Promise<string[]>;
|
|
69
|
-
private
|
|
70
|
-
private
|
|
63
|
+
private checkRetry;
|
|
64
|
+
private formatRetry;
|
|
65
|
+
private sleep;
|
|
66
|
+
private refreshToken;
|
|
67
|
+
private anonymousSignIn;
|
|
68
|
+
private defaultRefreshTokenFunc;
|
|
69
|
+
private getDeviceId;
|
|
70
|
+
private unAuthenticatedError;
|
|
71
71
|
}
|
|
72
72
|
export {};
|