@cloudbase/oauth 1.2.1-beta → 2.0.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/.eslintignore +2 -0
- package/.eslintrc +26 -0
- package/CHANGELOG.md +30 -0
- package/Dockerfile +15 -0
- package/README.md +183 -0
- package/_exmaple/assets/scripts/function/function.ts +99 -0
- package/_exmaple/assets/scripts/index.ts +101 -0
- package/_exmaple/assets/scripts/request.ts +11 -0
- package/_exmaple/index.html +15 -0
- package/_exmaple/package.json +33 -0
- package/_exmaple/tsconfig.json +71 -0
- package/_exmaple/typings.d.ts +0 -0
- package/_exmaple/webpack.config.js +42 -0
- package/dist/cjs/auth/apis.d.ts +55 -0
- package/dist/cjs/auth/apis.js +568 -0
- package/{auth → dist/cjs/auth}/consts.d.ts +9 -21
- package/dist/cjs/auth/consts.js +61 -0
- package/dist/cjs/auth/models.d.ts +354 -0
- package/dist/cjs/auth/models.js +3 -0
- package/dist/cjs/captcha/captcha.d.ts +35 -0
- package/dist/cjs/captcha/captcha.js +267 -0
- package/dist/cjs/index.d.ts +14 -0
- package/dist/cjs/index.js +63 -0
- package/{oauthclient → dist/cjs/oauth2client}/consts.d.ts +22 -1
- package/dist/cjs/oauth2client/consts.js +73 -0
- package/dist/cjs/oauth2client/interface.d.ts +15 -0
- package/dist/cjs/oauth2client/interface.js +10 -0
- package/dist/cjs/oauth2client/models.d.ts +47 -0
- package/dist/cjs/oauth2client/models.js +3 -0
- package/dist/cjs/oauth2client/oauth2client.d.ts +71 -0
- package/dist/cjs/oauth2client/oauth2client.js +640 -0
- package/dist/cjs/utils/function/single-promise.d.ts +5 -0
- package/dist/cjs/utils/function/single-promise.js +89 -0
- package/dist/cjs/utils/uuid.d.ts +1 -0
- package/dist/cjs/utils/uuid.js +12 -0
- package/dist/esm/auth/apis.d.ts +55 -0
- package/dist/esm/auth/apis.js +566 -0
- package/dist/esm/auth/consts.d.ts +54 -0
- package/dist/esm/auth/consts.js +58 -0
- package/dist/esm/auth/models.d.ts +354 -0
- package/dist/esm/auth/models.js +1 -0
- package/dist/esm/captcha/captcha.d.ts +35 -0
- package/dist/esm/captcha/captcha.js +264 -0
- package/dist/esm/index.d.ts +14 -0
- package/dist/esm/index.js +32 -0
- package/dist/esm/oauth2client/consts.d.ts +67 -0
- package/dist/esm/oauth2client/consts.js +70 -0
- package/dist/esm/oauth2client/interface.d.ts +15 -0
- package/dist/esm/oauth2client/interface.js +7 -0
- package/dist/esm/oauth2client/models.d.ts +47 -0
- package/dist/esm/oauth2client/models.js +1 -0
- package/dist/esm/oauth2client/oauth2client.d.ts +71 -0
- package/dist/esm/oauth2client/oauth2client.js +636 -0
- package/dist/esm/utils/function/single-promise.d.ts +5 -0
- package/dist/esm/utils/function/single-promise.js +86 -0
- package/dist/esm/utils/uuid.d.ts +1 -0
- package/dist/esm/utils/uuid.js +8 -0
- package/package.json +27 -14
- package/publish.sh +2 -0
- package/src/auth/apis.ts +642 -0
- package/src/auth/consts.ts +57 -0
- package/src/auth/models.ts +444 -0
- package/src/captcha/captcha.ts +222 -0
- package/src/index.ts +49 -0
- package/src/oauth2client/consts.ts +69 -0
- package/src/oauth2client/interface.ts +57 -0
- package/src/oauth2client/models.ts +61 -0
- package/src/oauth2client/oauth2client.ts +620 -0
- package/src/utils/function/single-promise.ts +40 -0
- package/src/utils/uuid.ts +11 -0
- package/tsconfig.esm.json +44 -0
- package/tsconfig.json +44 -0
- package/wiki/README.md +75 -0
- package/app/index.d.ts +0 -29
- package/app/index.js +0 -50
- package/app/index.js.map +0 -1
- package/app/internal.d.ts +0 -12
- package/app/internal.js +0 -25
- package/app/internal.js.map +0 -1
- package/app/openuri.d.ts +0 -20
- package/app/openuri.js +0 -106
- package/app/openuri.js.map +0 -1
- package/app/request.d.ts +0 -19
- package/app/request.js +0 -52
- package/app/request.js.map +0 -1
- package/app/storage.d.ts +0 -41
- package/app/storage.js +0 -35
- package/app/storage.js.map +0 -1
- package/auth/consts.js +0 -79
- package/auth/consts.js.map +0 -1
- package/auth/index.d.ts +0 -242
- package/auth/index.js +0 -550
- package/auth/index.js.map +0 -1
- package/auth/models.d.ts +0 -284
- package/auth/models.js +0 -4
- package/auth/models.js.map +0 -1
- package/captcha/index.d.ts +0 -45
- package/captcha/index.js +0 -135
- package/captcha/index.js.map +0 -1
- package/function/index.d.ts +0 -38
- package/function/index.js +0 -80
- package/function/index.js.map +0 -1
- package/index.d.ts +0 -8
- package/index.js +0 -17
- package/index.js.map +0 -1
- package/oauthclient/consts.js +0 -53
- package/oauthclient/consts.js.map +0 -1
- package/oauthclient/index.d.ts +0 -18
- package/oauthclient/index.js +0 -21
- package/oauthclient/index.js.map +0 -1
- package/oauthclient/interface.d.ts +0 -29
- package/oauthclient/interface.js +0 -10
- package/oauthclient/interface.js.map +0 -1
- package/oauthclient/models.d.ts +0 -40
- package/oauthclient/models.js +0 -3
- package/oauthclient/models.js.map +0 -1
- package/oauthclient/oauthclient.d.ts +0 -146
- package/oauthclient/oauthclient.js +0 -414
- package/oauthclient/oauthclient.js.map +0 -1
- package/utils/promise.d.ts +0 -18
- package/utils/promise.js +0 -48
- package/utils/promise.js.map +0 -1
- package/utils/uuid.d.ts +0 -5
- package/utils/uuid.js +0 -16
- package/utils/uuid.js.map +0 -1
|
@@ -0,0 +1,264 @@
|
|
|
1
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
2
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
3
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
4
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
5
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
6
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
7
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
8
|
+
});
|
|
9
|
+
};
|
|
10
|
+
var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
11
|
+
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
|
|
12
|
+
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
13
|
+
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
14
|
+
function step(op) {
|
|
15
|
+
if (f) throw new TypeError("Generator is already executing.");
|
|
16
|
+
while (_) try {
|
|
17
|
+
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
18
|
+
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
19
|
+
switch (op[0]) {
|
|
20
|
+
case 0: case 1: t = op; break;
|
|
21
|
+
case 4: _.label++; return { value: op[1], done: false };
|
|
22
|
+
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
23
|
+
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
24
|
+
default:
|
|
25
|
+
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
26
|
+
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
27
|
+
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
28
|
+
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
29
|
+
if (t[2]) _.ops.pop();
|
|
30
|
+
_.trys.pop(); continue;
|
|
31
|
+
}
|
|
32
|
+
op = body.call(thisArg, _);
|
|
33
|
+
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
34
|
+
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
35
|
+
}
|
|
36
|
+
};
|
|
37
|
+
import { defaultStorage } from "../oauth2client/oauth2client";
|
|
38
|
+
var GET_CAPTCHA_URL = '/auth/v1/captcha/init';
|
|
39
|
+
var Captcha = (function () {
|
|
40
|
+
function Captcha(opts) {
|
|
41
|
+
if (!opts.openURIWithCallback) {
|
|
42
|
+
opts.openURIWithCallback = this._getDefaultOpenURIWithCallback();
|
|
43
|
+
}
|
|
44
|
+
if (!opts.storage) {
|
|
45
|
+
opts.storage = defaultStorage;
|
|
46
|
+
}
|
|
47
|
+
this._config = opts;
|
|
48
|
+
this._tokenSectionName = 'captcha_' + opts.clientId;
|
|
49
|
+
}
|
|
50
|
+
Captcha.prototype.request = function (url, options) {
|
|
51
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
52
|
+
var state, reqURL, resp, err_1;
|
|
53
|
+
return __generator(this, function (_a) {
|
|
54
|
+
switch (_a.label) {
|
|
55
|
+
case 0:
|
|
56
|
+
if (!options) {
|
|
57
|
+
options = {};
|
|
58
|
+
}
|
|
59
|
+
if (!options.method) {
|
|
60
|
+
options.method = 'GET';
|
|
61
|
+
}
|
|
62
|
+
state = options.method + ":" + url;
|
|
63
|
+
reqURL = url;
|
|
64
|
+
if (!options.withCaptcha) return [3, 2];
|
|
65
|
+
return [4, this._appendCaptchaTokenToURL(url, state, false)];
|
|
66
|
+
case 1:
|
|
67
|
+
reqURL = _a.sent();
|
|
68
|
+
_a.label = 2;
|
|
69
|
+
case 2:
|
|
70
|
+
_a.trys.push([2, 4, , 8]);
|
|
71
|
+
return [4, this._config.request(reqURL, options)];
|
|
72
|
+
case 3:
|
|
73
|
+
resp = _a.sent();
|
|
74
|
+
return [3, 8];
|
|
75
|
+
case 4:
|
|
76
|
+
err_1 = _a.sent();
|
|
77
|
+
if (!(err_1.error === 'captcha_required' || err_1.error === 'captcha_invalid')) return [3, 6];
|
|
78
|
+
return [4, this._appendCaptchaTokenToURL(url, state, err_1.error === 'captcha_invalid')];
|
|
79
|
+
case 5:
|
|
80
|
+
url = _a.sent();
|
|
81
|
+
return [2, this._config.request(url, options)];
|
|
82
|
+
case 6: return [2, Promise.reject(err_1)];
|
|
83
|
+
case 7: return [3, 8];
|
|
84
|
+
case 8: return [2, resp];
|
|
85
|
+
}
|
|
86
|
+
});
|
|
87
|
+
});
|
|
88
|
+
};
|
|
89
|
+
Captcha.prototype._getDefaultOpenURIWithCallback = function () {
|
|
90
|
+
if (window.location.search.indexOf('__captcha') > 0) {
|
|
91
|
+
document.body.style.display = 'none';
|
|
92
|
+
}
|
|
93
|
+
if (document.getElementById('captcha_panel_wrap') === null) {
|
|
94
|
+
var elementDiv = document.createElement('div');
|
|
95
|
+
elementDiv.style.cssText =
|
|
96
|
+
'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;';
|
|
97
|
+
elementDiv.setAttribute('id', 'captcha_panel_wrap');
|
|
98
|
+
setTimeout(function () {
|
|
99
|
+
document.body.appendChild(elementDiv);
|
|
100
|
+
}, 0);
|
|
101
|
+
}
|
|
102
|
+
return this._defaultOpenURIWithCallback;
|
|
103
|
+
};
|
|
104
|
+
Captcha.prototype._defaultOpenURIWithCallback = function (url) {
|
|
105
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
106
|
+
var target, iframe;
|
|
107
|
+
return __generator(this, function (_a) {
|
|
108
|
+
target = document.getElementById('captcha_panel_wrap'), iframe = document.createElement('iframe');
|
|
109
|
+
target.innerHTML = '';
|
|
110
|
+
iframe.setAttribute('src', url);
|
|
111
|
+
iframe.setAttribute('id', 'review-panel-iframe');
|
|
112
|
+
iframe.style.cssText = 'min-width:355px;display:block;height:355px;margin:0 auto;background-color: rgb(255, 255, 255);border: none;';
|
|
113
|
+
target.appendChild(iframe);
|
|
114
|
+
target.style.display = 'block';
|
|
115
|
+
return [2, new Promise(function (resolve, reject) {
|
|
116
|
+
iframe.onload = function () {
|
|
117
|
+
try {
|
|
118
|
+
var windowLocation = window.location;
|
|
119
|
+
var iframeLocation = iframe.contentWindow.location;
|
|
120
|
+
if (iframeLocation.host +
|
|
121
|
+
iframeLocation.pathname ===
|
|
122
|
+
windowLocation.host +
|
|
123
|
+
windowLocation.pathname) {
|
|
124
|
+
target.style.display = 'none';
|
|
125
|
+
var iframeUrlParams = new URLSearchParams(iframeLocation.search);
|
|
126
|
+
var captchToken = iframeUrlParams.get('captcha_token');
|
|
127
|
+
if (captchToken) {
|
|
128
|
+
return resolve({
|
|
129
|
+
captcha_token: captchToken,
|
|
130
|
+
expires_in: Number(iframeUrlParams.get('expires_in'))
|
|
131
|
+
});
|
|
132
|
+
}
|
|
133
|
+
return reject({
|
|
134
|
+
error: iframeUrlParams.get('error'),
|
|
135
|
+
error_description: iframeUrlParams.get('error_description')
|
|
136
|
+
});
|
|
137
|
+
}
|
|
138
|
+
else {
|
|
139
|
+
target.style.display = 'block';
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
catch (error) {
|
|
143
|
+
target.style.display = 'block';
|
|
144
|
+
}
|
|
145
|
+
};
|
|
146
|
+
})];
|
|
147
|
+
});
|
|
148
|
+
});
|
|
149
|
+
};
|
|
150
|
+
Captcha.prototype._getCaptchaToken = function (forceNewToken, state) {
|
|
151
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
152
|
+
var captchaToken_1, redirectURL, captchaTokenResp, captchaToken_2, captchaToken;
|
|
153
|
+
return __generator(this, function (_a) {
|
|
154
|
+
switch (_a.label) {
|
|
155
|
+
case 0:
|
|
156
|
+
if (!!forceNewToken) return [3, 2];
|
|
157
|
+
return [4, this._findCaptchaToken()];
|
|
158
|
+
case 1:
|
|
159
|
+
captchaToken_1 = _a.sent();
|
|
160
|
+
if (captchaToken_1) {
|
|
161
|
+
return [2, captchaToken_1];
|
|
162
|
+
}
|
|
163
|
+
_a.label = 2;
|
|
164
|
+
case 2:
|
|
165
|
+
redirectURL = window.location.origin + window.location.pathname + "?__captcha=on";
|
|
166
|
+
return [4, this._config.request(GET_CAPTCHA_URL, {
|
|
167
|
+
method: 'POST',
|
|
168
|
+
body: {
|
|
169
|
+
client_id: this._config.clientId,
|
|
170
|
+
redirect_uri: redirectURL,
|
|
171
|
+
state: state
|
|
172
|
+
},
|
|
173
|
+
withCredentials: false,
|
|
174
|
+
})];
|
|
175
|
+
case 3:
|
|
176
|
+
captchaTokenResp = _a.sent();
|
|
177
|
+
if (captchaTokenResp.captcha_token) {
|
|
178
|
+
captchaToken_2 = {
|
|
179
|
+
captcha_token: captchaTokenResp.captcha_token,
|
|
180
|
+
expires_in: captchaTokenResp.expires_in,
|
|
181
|
+
};
|
|
182
|
+
this._saveCaptchaToken(captchaToken_2);
|
|
183
|
+
return [2, captchaTokenResp.captcha_token];
|
|
184
|
+
}
|
|
185
|
+
return [4, this._config.openURIWithCallback(captchaTokenResp.url)];
|
|
186
|
+
case 4:
|
|
187
|
+
captchaToken = _a.sent();
|
|
188
|
+
this._saveCaptchaToken(captchaToken);
|
|
189
|
+
return [2, captchaToken.captcha_token];
|
|
190
|
+
}
|
|
191
|
+
});
|
|
192
|
+
});
|
|
193
|
+
};
|
|
194
|
+
Captcha.prototype._appendCaptchaTokenToURL = function (url, state, forceNewToken) {
|
|
195
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
196
|
+
var captchaToken;
|
|
197
|
+
return __generator(this, function (_a) {
|
|
198
|
+
switch (_a.label) {
|
|
199
|
+
case 0: return [4, this._getCaptchaToken(forceNewToken, state)];
|
|
200
|
+
case 1:
|
|
201
|
+
captchaToken = _a.sent();
|
|
202
|
+
if (url.indexOf("?") > 0) {
|
|
203
|
+
url += "&captcha_token=" + captchaToken;
|
|
204
|
+
}
|
|
205
|
+
else {
|
|
206
|
+
url += "?captcha_token=" + captchaToken;
|
|
207
|
+
}
|
|
208
|
+
return [2, url];
|
|
209
|
+
}
|
|
210
|
+
});
|
|
211
|
+
});
|
|
212
|
+
};
|
|
213
|
+
Captcha.prototype._saveCaptchaToken = function (token) {
|
|
214
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
215
|
+
var tokenStr;
|
|
216
|
+
return __generator(this, function (_a) {
|
|
217
|
+
switch (_a.label) {
|
|
218
|
+
case 0:
|
|
219
|
+
token.expires_at = new Date(Date.now() + (token.expires_in - 10) * 1000);
|
|
220
|
+
tokenStr = JSON.stringify(token);
|
|
221
|
+
return [4, this._config.storage.setItem(this._tokenSectionName, tokenStr)];
|
|
222
|
+
case 1:
|
|
223
|
+
_a.sent();
|
|
224
|
+
return [2];
|
|
225
|
+
}
|
|
226
|
+
});
|
|
227
|
+
});
|
|
228
|
+
};
|
|
229
|
+
Captcha.prototype._findCaptchaToken = function () {
|
|
230
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
231
|
+
var tokenStr, captchaToken, isExpired, error_1;
|
|
232
|
+
return __generator(this, function (_a) {
|
|
233
|
+
switch (_a.label) {
|
|
234
|
+
case 0: return [4, this._config.storage.getItem(this._tokenSectionName)];
|
|
235
|
+
case 1:
|
|
236
|
+
tokenStr = _a.sent();
|
|
237
|
+
if (!(tokenStr !== undefined && tokenStr !== null)) return [3, 5];
|
|
238
|
+
_a.label = 2;
|
|
239
|
+
case 2:
|
|
240
|
+
_a.trys.push([2, 3, , 5]);
|
|
241
|
+
captchaToken = JSON.parse(tokenStr);
|
|
242
|
+
if (captchaToken === null || captchaToken === void 0 ? void 0 : captchaToken.expires_at) {
|
|
243
|
+
captchaToken.expires_at = new Date(captchaToken.expires_at);
|
|
244
|
+
}
|
|
245
|
+
isExpired = captchaToken.expires_at < new Date();
|
|
246
|
+
if (isExpired) {
|
|
247
|
+
return [2, null];
|
|
248
|
+
}
|
|
249
|
+
return [2, captchaToken.captcha_token];
|
|
250
|
+
case 3:
|
|
251
|
+
error_1 = _a.sent();
|
|
252
|
+
return [4, this._config.storage.removeItem(this._tokenSectionName)];
|
|
253
|
+
case 4:
|
|
254
|
+
_a.sent();
|
|
255
|
+
return [2, null];
|
|
256
|
+
case 5: return [2, null];
|
|
257
|
+
}
|
|
258
|
+
});
|
|
259
|
+
});
|
|
260
|
+
};
|
|
261
|
+
return Captcha;
|
|
262
|
+
}());
|
|
263
|
+
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}"]}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export { Syntax, ErrorType } from './oauth2client/consts';
|
|
2
|
+
import { OAuth2Client } from './oauth2client/oauth2client';
|
|
3
|
+
export { defaultStorage, defaultRequest, ToResponseErrorOptions, toResponseError, generateRequestId, OAuth2Client, } from './oauth2client/oauth2client';
|
|
4
|
+
export { AuthClient, SimpleStorage } from './oauth2client/interface';
|
|
5
|
+
export { Credentials, ResponseError, OAuth2ClientOptions, AuthClientRequestOptions, } from './oauth2client/models';
|
|
6
|
+
import { AuthOptions, Auth } from './auth/apis';
|
|
7
|
+
export { AuthOptions, Auth } from './auth/apis';
|
|
8
|
+
import * as authModels from './auth/models';
|
|
9
|
+
export { authModels };
|
|
10
|
+
export declare class CloudbaseOAuth {
|
|
11
|
+
oauth2client: OAuth2Client;
|
|
12
|
+
authApi: Auth;
|
|
13
|
+
constructor(authOptions: AuthOptions);
|
|
14
|
+
}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
var __assign = (this && this.__assign) || function () {
|
|
2
|
+
__assign = Object.assign || function(t) {
|
|
3
|
+
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
4
|
+
s = arguments[i];
|
|
5
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
|
6
|
+
t[p] = s[p];
|
|
7
|
+
}
|
|
8
|
+
return t;
|
|
9
|
+
};
|
|
10
|
+
return __assign.apply(this, arguments);
|
|
11
|
+
};
|
|
12
|
+
export { Syntax, ErrorType } from './oauth2client/consts';
|
|
13
|
+
import { OAuth2Client } from './oauth2client/oauth2client';
|
|
14
|
+
export { defaultStorage, defaultRequest, toResponseError, generateRequestId, OAuth2Client, } from './oauth2client/oauth2client';
|
|
15
|
+
export { AuthClient } from './oauth2client/interface';
|
|
16
|
+
import { Auth } from './auth/apis';
|
|
17
|
+
export { Auth } from './auth/apis';
|
|
18
|
+
import * as authModels from './auth/models';
|
|
19
|
+
export { authModels };
|
|
20
|
+
var CloudbaseOAuth = (function () {
|
|
21
|
+
function CloudbaseOAuth(authOptions) {
|
|
22
|
+
var apiOrigin = authOptions.apiOrigin, clientId = authOptions.clientId;
|
|
23
|
+
this.oauth2client = new OAuth2Client({
|
|
24
|
+
apiOrigin: apiOrigin,
|
|
25
|
+
clientId: clientId
|
|
26
|
+
});
|
|
27
|
+
this.authApi = new Auth(__assign({ credentialsClient: this.oauth2client }, authOptions));
|
|
28
|
+
}
|
|
29
|
+
return CloudbaseOAuth;
|
|
30
|
+
}());
|
|
31
|
+
export { CloudbaseOAuth };
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7QUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBRTFELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQTtBQUUxRCxPQUFPLEVBQ0wsY0FBYyxFQUNkLGNBQWMsRUFFZCxlQUFlLEVBQ2YsaUJBQWlCLEVBQ2pCLFlBQVksR0FDYixNQUFNLDZCQUE2QixDQUFDO0FBRXJDLE9BQU8sRUFBRSxVQUFVLEVBQWlCLE1BQU0sMEJBQTBCLENBQUM7QUFVckUsT0FBTyxFQUFlLElBQUksRUFBRSxNQUFNLGFBQWEsQ0FBQTtBQUUvQyxPQUFPLEVBQWUsSUFBSSxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBRWhELE9BQU8sS0FBSyxVQUFVLE1BQU0sZUFBZSxDQUFDO0FBQzVDLE9BQU8sRUFBRSxVQUFVLEVBQUUsQ0FBQztBQUd0QjtJQUlFLHdCQUFZLFdBQXdCO1FBQzFCLElBQUEsU0FBUyxHQUFlLFdBQVcsVUFBMUIsRUFBRSxRQUFRLEdBQUssV0FBVyxTQUFoQixDQUFnQjtRQUMzQyxJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksWUFBWSxDQUFDO1lBQ25DLFNBQVMsV0FBQTtZQUNULFFBQVEsVUFBQTtTQUNULENBQUMsQ0FBQTtRQUVGLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxJQUFJLFlBQ3JCLGlCQUFpQixFQUFFLElBQUksQ0FBQyxZQUFZLElBQ2pDLFdBQVcsRUFDZCxDQUFBO0lBQ0osQ0FBQztJQUNILHFCQUFDO0FBQUQsQ0FBQyxBQWhCRCxJQWdCQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IFN5bnRheCwgRXJyb3JUeXBlIH0gZnJvbSAnLi9vYXV0aDJjbGllbnQvY29uc3RzJztcblxuaW1wb3J0IHsgT0F1dGgyQ2xpZW50IH0gZnJvbSAnLi9vYXV0aDJjbGllbnQvb2F1dGgyY2xpZW50J1xuXG5leHBvcnQge1xuICBkZWZhdWx0U3RvcmFnZSxcbiAgZGVmYXVsdFJlcXVlc3QsXG4gIFRvUmVzcG9uc2VFcnJvck9wdGlvbnMsXG4gIHRvUmVzcG9uc2VFcnJvcixcbiAgZ2VuZXJhdGVSZXF1ZXN0SWQsXG4gIE9BdXRoMkNsaWVudCxcbn0gZnJvbSAnLi9vYXV0aDJjbGllbnQvb2F1dGgyY2xpZW50JztcblxuZXhwb3J0IHsgQXV0aENsaWVudCwgU2ltcGxlU3RvcmFnZSB9IGZyb20gJy4vb2F1dGgyY2xpZW50L2ludGVyZmFjZSc7XG5cbi8vIGltcG9ydCB7IENyZWRlbnRpYWxzIH0gZnJvbSAnLi9vYXV0aDJjbGllbnQvbW9kZWxzJ1xuZXhwb3J0IHtcbiAgQ3JlZGVudGlhbHMsXG4gIFJlc3BvbnNlRXJyb3IsXG4gIE9BdXRoMkNsaWVudE9wdGlvbnMsXG4gIEF1dGhDbGllbnRSZXF1ZXN0T3B0aW9ucyxcbn0gZnJvbSAnLi9vYXV0aDJjbGllbnQvbW9kZWxzJztcblxuaW1wb3J0IHsgQXV0aE9wdGlvbnMsIEF1dGggfSBmcm9tICcuL2F1dGgvYXBpcydcblxuZXhwb3J0IHsgQXV0aE9wdGlvbnMsIEF1dGggfSBmcm9tICcuL2F1dGgvYXBpcyc7XG5cbmltcG9ydCAqIGFzIGF1dGhNb2RlbHMgZnJvbSAnLi9hdXRoL21vZGVscyc7XG5leHBvcnQgeyBhdXRoTW9kZWxzIH07XG5cblxuZXhwb3J0IGNsYXNzIENsb3VkYmFzZU9BdXRoIHtcbiAgcHVibGljIG9hdXRoMmNsaWVudDogT0F1dGgyQ2xpZW50XG4gIHB1YmxpYyBhdXRoQXBpOiBBdXRoXG5cbiAgY29uc3RydWN0b3IoYXV0aE9wdGlvbnM6IEF1dGhPcHRpb25zKSB7XG4gICAgY29uc3QgeyBhcGlPcmlnaW4sIGNsaWVudElkIH0gPSBhdXRoT3B0aW9uc1xuICAgIHRoaXMub2F1dGgyY2xpZW50ID0gbmV3IE9BdXRoMkNsaWVudCh7XG4gICAgICBhcGlPcmlnaW4sXG4gICAgICBjbGllbnRJZFxuICAgIH0pXG5cbiAgICB0aGlzLmF1dGhBcGkgPSBuZXcgQXV0aCh7XG4gICAgICBjcmVkZW50aWFsc0NsaWVudDogdGhpcy5vYXV0aDJjbGllbnQsXG4gICAgICAuLi5hdXRoT3B0aW9uc1xuICAgIH0pXG4gIH1cbn1cblxuIl19
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
export declare enum Syntax {
|
|
2
|
+
CLIENT_ID = "client_id",
|
|
3
|
+
CLIENT_SECRET = "client_secret",
|
|
4
|
+
RESPONSE_TYPE = "response_type",
|
|
5
|
+
SCOPE = "scope",
|
|
6
|
+
STATE = "state",
|
|
7
|
+
REDIRECT_URI = "redirect_uri",
|
|
8
|
+
ERROR = "error",
|
|
9
|
+
ERROR_DESCRIPTION = "error_description",
|
|
10
|
+
ERROR_URI = "error_uri",
|
|
11
|
+
GRANT_TYPE = "grant_type",
|
|
12
|
+
CODE = "code",
|
|
13
|
+
ACCESS_TOKEN = "access_token",
|
|
14
|
+
TOKEN_TYPE = "token_type",
|
|
15
|
+
EXPIRES_IN = "expires_in",
|
|
16
|
+
USERNAME = "username",
|
|
17
|
+
PASSWORD = "password",
|
|
18
|
+
REFRESH_TOKEN = "refresh_token"
|
|
19
|
+
}
|
|
20
|
+
export declare enum ErrorType {
|
|
21
|
+
UNREACHABLE = "unreachable",
|
|
22
|
+
LOCAL = "local",
|
|
23
|
+
CANCELLED = "cancelled",
|
|
24
|
+
UNKNOWN = "unknown",
|
|
25
|
+
INVALID_ARGUMENT = "invalid_argument",
|
|
26
|
+
DEADLINE_EXCEEDED = "deadline_exceeded",
|
|
27
|
+
NOT_FOUND = "not_found",
|
|
28
|
+
ALREADY_EXISTS = "already_exists",
|
|
29
|
+
PERMISSION_DENIED = "permission_denied",
|
|
30
|
+
UNAUTHENTICATED = "unauthenticated",
|
|
31
|
+
RESOURCE_EXHAUSTED = "resource_exhausted",
|
|
32
|
+
FAILED_PRECONDITION = "failed_precondition",
|
|
33
|
+
ABORTED = "aborted",
|
|
34
|
+
OUT_OF_RANGE = "out_of_range",
|
|
35
|
+
UNIMPLEMENTED = "unimplemented",
|
|
36
|
+
INTERNAL = "internal",
|
|
37
|
+
UNAVAILABLE = "unavailable",
|
|
38
|
+
DATA_LOSS = "data_loss",
|
|
39
|
+
CAPTCHA_REQUIRED = "captcha_required",
|
|
40
|
+
CAPTCHA_INVALID = "captcha_invalid",
|
|
41
|
+
INVALID_PASSWORD = "invalid_password",
|
|
42
|
+
INVALID_STATUS = "invalid_status",
|
|
43
|
+
USER_PENDING = "user_pending",
|
|
44
|
+
USER_BLOCKED = "user_blocked",
|
|
45
|
+
INVALID_VERIFICATION_CODE = "invalid_verification_code",
|
|
46
|
+
TWO_FACTOR_REQUIRED = "two_factor_required",
|
|
47
|
+
INVALID_TWO_FACTOR = "invalid_two_factor",
|
|
48
|
+
INVALID_TWO_FACTOR_RECOVERY = "invalid_two_factor_recovery",
|
|
49
|
+
UNDER_REVIEW = "under_review",
|
|
50
|
+
INVALID_REQUEST = "invalid_request",
|
|
51
|
+
UNAUTHORIZED_CLIENT = "unauthorized_client",
|
|
52
|
+
ACCESS_DENIED = "access_denied",
|
|
53
|
+
UNSUPPORTED_RESPONSE_TYPE = "unsupported_response_type",
|
|
54
|
+
INVALID_SCOPE = "invalid_scope",
|
|
55
|
+
INVALID_GRANT = "invalid_grant",
|
|
56
|
+
SERVER_ERROR = "server_error",
|
|
57
|
+
TEMPORARILY_UNAVAILABLE = "temporarily_unavailable",
|
|
58
|
+
INTERACTION_REQUIRED = "interaction_required",
|
|
59
|
+
LOGIN_REQUIRED = "login_required",
|
|
60
|
+
ACCOUNT_SELECTION_REQUIRED = "account_selection_required",
|
|
61
|
+
CONSENT_REQUIRED = "consent_required",
|
|
62
|
+
INVALID_REQUEST_URI = "invalid_request_uri",
|
|
63
|
+
INVALID_REQUEST_OBJECT = "invalid_request_object",
|
|
64
|
+
REQUEST_NOT_SUPPORTED = "request_not_supported",
|
|
65
|
+
REQUEST_URI_NOT_SUPPORTED = "request_uri_not_supported",
|
|
66
|
+
REGISTRATION_NOT_SUPPORTED = "registration_not_supported"
|
|
67
|
+
}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
export var Syntax;
|
|
2
|
+
(function (Syntax) {
|
|
3
|
+
Syntax["CLIENT_ID"] = "client_id";
|
|
4
|
+
Syntax["CLIENT_SECRET"] = "client_secret";
|
|
5
|
+
Syntax["RESPONSE_TYPE"] = "response_type";
|
|
6
|
+
Syntax["SCOPE"] = "scope";
|
|
7
|
+
Syntax["STATE"] = "state";
|
|
8
|
+
Syntax["REDIRECT_URI"] = "redirect_uri";
|
|
9
|
+
Syntax["ERROR"] = "error";
|
|
10
|
+
Syntax["ERROR_DESCRIPTION"] = "error_description";
|
|
11
|
+
Syntax["ERROR_URI"] = "error_uri";
|
|
12
|
+
Syntax["GRANT_TYPE"] = "grant_type";
|
|
13
|
+
Syntax["CODE"] = "code";
|
|
14
|
+
Syntax["ACCESS_TOKEN"] = "access_token";
|
|
15
|
+
Syntax["TOKEN_TYPE"] = "token_type";
|
|
16
|
+
Syntax["EXPIRES_IN"] = "expires_in";
|
|
17
|
+
Syntax["USERNAME"] = "username";
|
|
18
|
+
Syntax["PASSWORD"] = "password";
|
|
19
|
+
Syntax["REFRESH_TOKEN"] = "refresh_token";
|
|
20
|
+
})(Syntax || (Syntax = {}));
|
|
21
|
+
export var ErrorType;
|
|
22
|
+
(function (ErrorType) {
|
|
23
|
+
ErrorType["UNREACHABLE"] = "unreachable";
|
|
24
|
+
ErrorType["LOCAL"] = "local";
|
|
25
|
+
ErrorType["CANCELLED"] = "cancelled";
|
|
26
|
+
ErrorType["UNKNOWN"] = "unknown";
|
|
27
|
+
ErrorType["INVALID_ARGUMENT"] = "invalid_argument";
|
|
28
|
+
ErrorType["DEADLINE_EXCEEDED"] = "deadline_exceeded";
|
|
29
|
+
ErrorType["NOT_FOUND"] = "not_found";
|
|
30
|
+
ErrorType["ALREADY_EXISTS"] = "already_exists";
|
|
31
|
+
ErrorType["PERMISSION_DENIED"] = "permission_denied";
|
|
32
|
+
ErrorType["UNAUTHENTICATED"] = "unauthenticated";
|
|
33
|
+
ErrorType["RESOURCE_EXHAUSTED"] = "resource_exhausted";
|
|
34
|
+
ErrorType["FAILED_PRECONDITION"] = "failed_precondition";
|
|
35
|
+
ErrorType["ABORTED"] = "aborted";
|
|
36
|
+
ErrorType["OUT_OF_RANGE"] = "out_of_range";
|
|
37
|
+
ErrorType["UNIMPLEMENTED"] = "unimplemented";
|
|
38
|
+
ErrorType["INTERNAL"] = "internal";
|
|
39
|
+
ErrorType["UNAVAILABLE"] = "unavailable";
|
|
40
|
+
ErrorType["DATA_LOSS"] = "data_loss";
|
|
41
|
+
ErrorType["CAPTCHA_REQUIRED"] = "captcha_required";
|
|
42
|
+
ErrorType["CAPTCHA_INVALID"] = "captcha_invalid";
|
|
43
|
+
ErrorType["INVALID_PASSWORD"] = "invalid_password";
|
|
44
|
+
ErrorType["INVALID_STATUS"] = "invalid_status";
|
|
45
|
+
ErrorType["USER_PENDING"] = "user_pending";
|
|
46
|
+
ErrorType["USER_BLOCKED"] = "user_blocked";
|
|
47
|
+
ErrorType["INVALID_VERIFICATION_CODE"] = "invalid_verification_code";
|
|
48
|
+
ErrorType["TWO_FACTOR_REQUIRED"] = "two_factor_required";
|
|
49
|
+
ErrorType["INVALID_TWO_FACTOR"] = "invalid_two_factor";
|
|
50
|
+
ErrorType["INVALID_TWO_FACTOR_RECOVERY"] = "invalid_two_factor_recovery";
|
|
51
|
+
ErrorType["UNDER_REVIEW"] = "under_review";
|
|
52
|
+
ErrorType["INVALID_REQUEST"] = "invalid_request";
|
|
53
|
+
ErrorType["UNAUTHORIZED_CLIENT"] = "unauthorized_client";
|
|
54
|
+
ErrorType["ACCESS_DENIED"] = "access_denied";
|
|
55
|
+
ErrorType["UNSUPPORTED_RESPONSE_TYPE"] = "unsupported_response_type";
|
|
56
|
+
ErrorType["INVALID_SCOPE"] = "invalid_scope";
|
|
57
|
+
ErrorType["INVALID_GRANT"] = "invalid_grant";
|
|
58
|
+
ErrorType["SERVER_ERROR"] = "server_error";
|
|
59
|
+
ErrorType["TEMPORARILY_UNAVAILABLE"] = "temporarily_unavailable";
|
|
60
|
+
ErrorType["INTERACTION_REQUIRED"] = "interaction_required";
|
|
61
|
+
ErrorType["LOGIN_REQUIRED"] = "login_required";
|
|
62
|
+
ErrorType["ACCOUNT_SELECTION_REQUIRED"] = "account_selection_required";
|
|
63
|
+
ErrorType["CONSENT_REQUIRED"] = "consent_required";
|
|
64
|
+
ErrorType["INVALID_REQUEST_URI"] = "invalid_request_uri";
|
|
65
|
+
ErrorType["INVALID_REQUEST_OBJECT"] = "invalid_request_object";
|
|
66
|
+
ErrorType["REQUEST_NOT_SUPPORTED"] = "request_not_supported";
|
|
67
|
+
ErrorType["REQUEST_URI_NOT_SUPPORTED"] = "request_uri_not_supported";
|
|
68
|
+
ErrorType["REGISTRATION_NOT_SUPPORTED"] = "registration_not_supported";
|
|
69
|
+
})(ErrorType || (ErrorType = {}));
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL29hdXRoMmNsaWVudC9jb25zdHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFOLElBQVksTUFrQlg7QUFsQkQsV0FBWSxNQUFNO0lBQ2hCLGlDQUF1QixDQUFBO0lBQ3ZCLHlDQUErQixDQUFBO0lBQy9CLHlDQUErQixDQUFBO0lBQy9CLHlCQUFlLENBQUE7SUFDZix5QkFBZSxDQUFBO0lBQ2YsdUNBQTZCLENBQUE7SUFDN0IseUJBQWUsQ0FBQTtJQUNmLGlEQUF1QyxDQUFBO0lBQ3ZDLGlDQUF1QixDQUFBO0lBQ3ZCLG1DQUF5QixDQUFBO0lBQ3pCLHVCQUFhLENBQUE7SUFDYix1Q0FBNkIsQ0FBQTtJQUM3QixtQ0FBeUIsQ0FBQTtJQUN6QixtQ0FBeUIsQ0FBQTtJQUN6QiwrQkFBcUIsQ0FBQTtJQUNyQiwrQkFBcUIsQ0FBQTtJQUNyQix5Q0FBK0IsQ0FBQTtBQUNqQyxDQUFDLEVBbEJXLE1BQU0sS0FBTixNQUFNLFFBa0JqQjtBQUVELE1BQU0sQ0FBTixJQUFZLFNBZ0RYO0FBaERELFdBQVksU0FBUztJQUNuQix3Q0FBMkIsQ0FBQTtJQUMzQiw0QkFBZSxDQUFBO0lBQ2Ysb0NBQXVCLENBQUE7SUFDdkIsZ0NBQW1CLENBQUE7SUFDbkIsa0RBQXFDLENBQUE7SUFDckMsb0RBQXVDLENBQUE7SUFDdkMsb0NBQXVCLENBQUE7SUFDdkIsOENBQWlDLENBQUE7SUFDakMsb0RBQXVDLENBQUE7SUFDdkMsZ0RBQW1DLENBQUE7SUFDbkMsc0RBQXlDLENBQUE7SUFDekMsd0RBQTJDLENBQUE7SUFDM0MsZ0NBQW1CLENBQUE7SUFDbkIsMENBQTZCLENBQUE7SUFDN0IsNENBQStCLENBQUE7SUFDL0Isa0NBQXFCLENBQUE7SUFDckIsd0NBQTJCLENBQUE7SUFDM0Isb0NBQXVCLENBQUE7SUFFdkIsa0RBQXFDLENBQUE7SUFDckMsZ0RBQW1DLENBQUE7SUFDbkMsa0RBQXFDLENBQUE7SUFDckMsOENBQWlDLENBQUE7SUFDakMsMENBQTZCLENBQUE7SUFDN0IsMENBQTZCLENBQUE7SUFDN0Isb0VBQXVELENBQUE7SUFDdkQsd0RBQTJDLENBQUE7SUFDM0Msc0RBQXlDLENBQUE7SUFDekMsd0VBQTJELENBQUE7SUFDM0QsMENBQTZCLENBQUE7SUFDN0IsZ0RBQW1DLENBQUE7SUFDbkMsd0RBQTJDLENBQUE7SUFDM0MsNENBQStCLENBQUE7SUFDL0Isb0VBQXVELENBQUE7SUFDdkQsNENBQStCLENBQUE7SUFDL0IsNENBQStCLENBQUE7SUFDL0IsMENBQTZCLENBQUE7SUFDN0IsZ0VBQW1ELENBQUE7SUFDbkQsMERBQTZDLENBQUE7SUFDN0MsOENBQWlDLENBQUE7SUFDakMsc0VBQXlELENBQUE7SUFDekQsa0RBQXFDLENBQUE7SUFDckMsd0RBQTJDLENBQUE7SUFDM0MsOERBQWlELENBQUE7SUFDakQsNERBQStDLENBQUE7SUFDL0Msb0VBQXVELENBQUE7SUFDdkQsc0VBQXlELENBQUE7QUFDM0QsQ0FBQyxFQWhEVyxTQUFTLEtBQVQsU0FBUyxRQWdEcEIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZW51bSBTeW50YXgge1xuICBDTElFTlRfSUQgPSAnY2xpZW50X2lkJyxcbiAgQ0xJRU5UX1NFQ1JFVCA9ICdjbGllbnRfc2VjcmV0JyxcbiAgUkVTUE9OU0VfVFlQRSA9ICdyZXNwb25zZV90eXBlJyxcbiAgU0NPUEUgPSAnc2NvcGUnLFxuICBTVEFURSA9ICdzdGF0ZScsXG4gIFJFRElSRUNUX1VSSSA9ICdyZWRpcmVjdF91cmknLFxuICBFUlJPUiA9ICdlcnJvcicsXG4gIEVSUk9SX0RFU0NSSVBUSU9OID0gJ2Vycm9yX2Rlc2NyaXB0aW9uJyxcbiAgRVJST1JfVVJJID0gJ2Vycm9yX3VyaScsXG4gIEdSQU5UX1RZUEUgPSAnZ3JhbnRfdHlwZScsXG4gIENPREUgPSAnY29kZScsXG4gIEFDQ0VTU19UT0tFTiA9ICdhY2Nlc3NfdG9rZW4nLFxuICBUT0tFTl9UWVBFID0gJ3Rva2VuX3R5cGUnLFxuICBFWFBJUkVTX0lOID0gJ2V4cGlyZXNfaW4nLFxuICBVU0VSTkFNRSA9ICd1c2VybmFtZScsXG4gIFBBU1NXT1JEID0gJ3Bhc3N3b3JkJyxcbiAgUkVGUkVTSF9UT0tFTiA9ICdyZWZyZXNoX3Rva2VuJyxcbn1cblxuZXhwb3J0IGVudW0gRXJyb3JUeXBlIHtcbiAgVU5SRUFDSEFCTEUgPSAndW5yZWFjaGFibGUnLFxuICBMT0NBTCA9ICdsb2NhbCcsXG4gIENBTkNFTExFRCA9ICdjYW5jZWxsZWQnLFxuICBVTktOT1dOID0gJ3Vua25vd24nLFxuICBJTlZBTElEX0FSR1VNRU5UID0gJ2ludmFsaWRfYXJndW1lbnQnLFxuICBERUFETElORV9FWENFRURFRCA9ICdkZWFkbGluZV9leGNlZWRlZCcsXG4gIE5PVF9GT1VORCA9ICdub3RfZm91bmQnLFxuICBBTFJFQURZX0VYSVNUUyA9ICdhbHJlYWR5X2V4aXN0cycsXG4gIFBFUk1JU1NJT05fREVOSUVEID0gJ3Blcm1pc3Npb25fZGVuaWVkJyxcbiAgVU5BVVRIRU5USUNBVEVEID0gJ3VuYXV0aGVudGljYXRlZCcsXG4gIFJFU09VUkNFX0VYSEFVU1RFRCA9ICdyZXNvdXJjZV9leGhhdXN0ZWQnLFxuICBGQUlMRURfUFJFQ09ORElUSU9OID0gJ2ZhaWxlZF9wcmVjb25kaXRpb24nLFxuICBBQk9SVEVEID0gJ2Fib3J0ZWQnLFxuICBPVVRfT0ZfUkFOR0UgPSAnb3V0X29mX3JhbmdlJyxcbiAgVU5JTVBMRU1FTlRFRCA9ICd1bmltcGxlbWVudGVkJyxcbiAgSU5URVJOQUwgPSAnaW50ZXJuYWwnLFxuICBVTkFWQUlMQUJMRSA9ICd1bmF2YWlsYWJsZScsXG4gIERBVEFfTE9TUyA9ICdkYXRhX2xvc3MnLFxuICAvLyBDb21tb25FcnJvclxuICBDQVBUQ0hBX1JFUVVJUkVEID0gJ2NhcHRjaGFfcmVxdWlyZWQnLFxuICBDQVBUQ0hBX0lOVkFMSUQgPSAnY2FwdGNoYV9pbnZhbGlkJyxcbiAgSU5WQUxJRF9QQVNTV09SRCA9ICdpbnZhbGlkX3Bhc3N3b3JkJyxcbiAgSU5WQUxJRF9TVEFUVVMgPSAnaW52YWxpZF9zdGF0dXMnLFxuICBVU0VSX1BFTkRJTkcgPSAndXNlcl9wZW5kaW5nJyxcbiAgVVNFUl9CTE9DS0VEID0gJ3VzZXJfYmxvY2tlZCcsXG4gIElOVkFMSURfVkVSSUZJQ0FUSU9OX0NPREUgPSAnaW52YWxpZF92ZXJpZmljYXRpb25fY29kZScsXG4gIFRXT19GQUNUT1JfUkVRVUlSRUQgPSAndHdvX2ZhY3Rvcl9yZXF1aXJlZCcsXG4gIElOVkFMSURfVFdPX0ZBQ1RPUiA9ICdpbnZhbGlkX3R3b19mYWN0b3InLFxuICBJTlZBTElEX1RXT19GQUNUT1JfUkVDT1ZFUlkgPSAnaW52YWxpZF90d29fZmFjdG9yX3JlY292ZXJ5JyxcbiAgVU5ERVJfUkVWSUVXID0gJ3VuZGVyX3JldmlldycsXG4gIElOVkFMSURfUkVRVUVTVCA9ICdpbnZhbGlkX3JlcXVlc3QnLFxuICBVTkFVVEhPUklaRURfQ0xJRU5UID0gJ3VuYXV0aG9yaXplZF9jbGllbnQnLFxuICBBQ0NFU1NfREVOSUVEID0gJ2FjY2Vzc19kZW5pZWQnLFxuICBVTlNVUFBPUlRFRF9SRVNQT05TRV9UWVBFID0gJ3Vuc3VwcG9ydGVkX3Jlc3BvbnNlX3R5cGUnLFxuICBJTlZBTElEX1NDT1BFID0gJ2ludmFsaWRfc2NvcGUnLFxuICBJTlZBTElEX0dSQU5UID0gJ2ludmFsaWRfZ3JhbnQnLFxuICBTRVJWRVJfRVJST1IgPSAnc2VydmVyX2Vycm9yJyxcbiAgVEVNUE9SQVJJTFlfVU5BVkFJTEFCTEUgPSAndGVtcG9yYXJpbHlfdW5hdmFpbGFibGUnLFxuICBJTlRFUkFDVElPTl9SRVFVSVJFRCA9ICdpbnRlcmFjdGlvbl9yZXF1aXJlZCcsXG4gIExPR0lOX1JFUVVJUkVEID0gJ2xvZ2luX3JlcXVpcmVkJyxcbiAgQUNDT1VOVF9TRUxFQ1RJT05fUkVRVUlSRUQgPSAnYWNjb3VudF9zZWxlY3Rpb25fcmVxdWlyZWQnLFxuICBDT05TRU5UX1JFUVVJUkVEID0gJ2NvbnNlbnRfcmVxdWlyZWQnLFxuICBJTlZBTElEX1JFUVVFU1RfVVJJID0gJ2ludmFsaWRfcmVxdWVzdF91cmknLFxuICBJTlZBTElEX1JFUVVFU1RfT0JKRUNUID0gJ2ludmFsaWRfcmVxdWVzdF9vYmplY3QnLFxuICBSRVFVRVNUX05PVF9TVVBQT1JURUQgPSAncmVxdWVzdF9ub3Rfc3VwcG9ydGVkJyxcbiAgUkVRVUVTVF9VUklfTk9UX1NVUFBPUlRFRCA9ICdyZXF1ZXN0X3VyaV9ub3Rfc3VwcG9ydGVkJyxcbiAgUkVHSVNUUkFUSU9OX05PVF9TVVBQT1JURUQgPSAncmVnaXN0cmF0aW9uX25vdF9zdXBwb3J0ZWQnLFxufVxuIl19
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { Credentials, AuthClientRequestOptions } from './models';
|
|
2
|
+
export declare abstract class AuthClient {
|
|
3
|
+
abstract setCredentials(credentials?: Credentials): void;
|
|
4
|
+
abstract request: RequestFunction;
|
|
5
|
+
abstract getAccessToken(): Promise<string>;
|
|
6
|
+
}
|
|
7
|
+
export declare type RequestFunction = <T>(url: string, options?: AuthClientRequestOptions) => Promise<T>;
|
|
8
|
+
export interface SimpleStorage {
|
|
9
|
+
getItem: (key: string) => Promise<string | null>;
|
|
10
|
+
removeItem: (key: string) => Promise<void>;
|
|
11
|
+
setItem: (key: string, value: string) => Promise<void>;
|
|
12
|
+
getItemSync: (key: string) => string | null;
|
|
13
|
+
removeItemSync: (key: string) => void;
|
|
14
|
+
setItemSync: (key: string, value: string) => void;
|
|
15
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
var AuthClient = (function () {
|
|
2
|
+
function AuthClient() {
|
|
3
|
+
}
|
|
4
|
+
return AuthClient;
|
|
5
|
+
}());
|
|
6
|
+
export { AuthClient };
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL29hdXRoMmNsaWVudC9pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBS0E7SUFBQTtJQW9CQSxDQUFDO0lBQUQsaUJBQUM7QUFBRCxDQUFDLEFBcEJELElBb0JDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ3JlZGVudGlhbHMsIEF1dGhDbGllbnRSZXF1ZXN0T3B0aW9ucyB9IGZyb20gJy4vbW9kZWxzJztcblxuLyoqXG4gKiB0aGUgaW50ZXJmYWNlIGZvciB0aGUgT2F1dGgyQ2xpZW50XG4gKi9cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBBdXRoQ2xpZW50IHtcbiAgLyoqXG4gICAqIFNldHMgdGhlIGF1dGggY3JlZGVudGlhbHMuXG4gICAqL1xuICBhYnN0cmFjdCBzZXRDcmVkZW50aWFscyhjcmVkZW50aWFscz86IENyZWRlbnRpYWxzKTogdm9pZDtcbiAgLyoqXG4gICAqIFByb3ZpZGVzIGFuIGFsdGVybmF0aXZlIGZldGNoIGFwaSByZXF1ZXN0IGltcGxlbWVudGF0aW9uIHdpdGggYXV0aCBjcmVkZW50aWFsc1xuICAgKiBpZiBvcHRpb25zLndpdGhDcmVkZW50aWFsczp0cnVlLCB0aGUgcmVxdWVzdCB3aWxsIGF1dG8gYWRkIEF1dGhvcml6YXRpb246IEJlYXJlciA8QWNjZXNzVG9rZW4+IGluIHRoZSByZXF1ZXN0XG4gICAqIGVycm9yOlxuICAgKiAgICAgLSB1bnJlYWNoYWJsZSwgdGhlIG5ldHdvcmsgZXJyb3Igb3IgcmVzcG9uc2UgaXMgbm90IGpzb25cbiAgICogICAgIC0gdW5hdXRoZW50aWNhdGVkOiBoYXMgbm8gdmFsaWRhdGUgYWNjZXNzIHRva2VuXG4gICAqL1xuICBhYnN0cmFjdCByZXF1ZXN0OiBSZXF1ZXN0RnVuY3Rpb247XG5cbiAgLyoqXG4gICAqIGdldCB0aGUgY3VycmVudCBhY2Nlc3NUb2tlbiBmcm9tIEF1dGhDbGllbnQsIHlvdSBjYW4gdXNlIHRoaXMgdG8gZGV0ZWN0IGxvZ2luIHN0YXR1c1xuICAgKiBlcnJvcjpcbiAgICogICAgLSAgdW5hdXRoZW50aWNhdGVkOiBoYXMgbm8gdmFsaWRhdGUgYWNjZXNzIHRva2VuXG4gICAqL1xuICBhYnN0cmFjdCBnZXRBY2Nlc3NUb2tlbigpOiBQcm9taXNlPHN0cmluZz47XG59XG5cbmV4cG9ydCB0eXBlIFJlcXVlc3RGdW5jdGlvbiA9IDxUPih1cmw6IHN0cmluZywgb3B0aW9ucz86IEF1dGhDbGllbnRSZXF1ZXN0T3B0aW9ucykgPT4gUHJvbWlzZTxUPjtcblxuLyoqIEFuIGludGVyZmFjZSBvZiB0aGUgU2ltcGxlICBXZWIgU3RvcmFnZSBBUEkgICovXG5leHBvcnQgaW50ZXJmYWNlIFNpbXBsZVN0b3JhZ2Uge1xuICAvKipcbiAgICogdmFsdWUgPSBzdG9yYWdlW2tleV1cbiAgICovXG4gIGdldEl0ZW06IChrZXk6IHN0cmluZykgPT4gUHJvbWlzZTxzdHJpbmcgfCBudWxsPjtcbiAgLyoqXG4gICAqIGRlbGV0ZSBzdG9yYWdlW2tleV1cbiAgICovXG4gIHJlbW92ZUl0ZW06IChrZXk6IHN0cmluZykgPT4gUHJvbWlzZTx2b2lkPjtcbiAgLyoqXG4gICAqIHN0b3JhZ2Vba2V5XSA9IHZhbHVlXG4gICAqL1xuICBzZXRJdGVtOiAoa2V5OiBzdHJpbmcsIHZhbHVlOiBzdHJpbmcpID0+IFByb21pc2U8dm9pZD47XG5cbiAgLyoqXG4gICAqIHZhbHVlID0gc3RvcmFnZVtrZXldXG4gICAqL1xuICBnZXRJdGVtU3luYzogKGtleTogc3RyaW5nKSA9PiBzdHJpbmcgfCBudWxsO1xuICAvKipcbiAgICogZGVsZXRlIHN0b3JhZ2Vba2V5XVxuICAgKi9cbiAgcmVtb3ZlSXRlbVN5bmM6IChrZXk6IHN0cmluZykgPT4gdm9pZDtcbiAgLyoqXG4gICAqIHN0b3JhZ2Vba2V5XSA9IHZhbHVlXG4gICAqL1xuICBzZXRJdGVtU3luYzogKGtleTogc3RyaW5nLCB2YWx1ZTogc3RyaW5nKSA9PiB2b2lkO1xufVxuIl19
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { SimpleStorage } from './interface';
|
|
2
|
+
import { ErrorType } from './consts';
|
|
3
|
+
export interface Credentials {
|
|
4
|
+
token_type?: string | null;
|
|
5
|
+
access_token?: string | null;
|
|
6
|
+
refresh_token?: string | null;
|
|
7
|
+
scope?: string | null;
|
|
8
|
+
expires_in?: number | null;
|
|
9
|
+
expires_at?: Date | null;
|
|
10
|
+
sub?: string | null;
|
|
11
|
+
}
|
|
12
|
+
export interface ResponseError {
|
|
13
|
+
error: ErrorType;
|
|
14
|
+
error_description?: string | null;
|
|
15
|
+
error_uri?: string | null;
|
|
16
|
+
details?: any | null;
|
|
17
|
+
}
|
|
18
|
+
export interface RequestOptions {
|
|
19
|
+
body?: any | null;
|
|
20
|
+
headers?: any | null;
|
|
21
|
+
method?: string;
|
|
22
|
+
[key: string]: any;
|
|
23
|
+
}
|
|
24
|
+
export declare type RequestFunction = <T>(url: string, options?: RequestOptions) => Promise<T>;
|
|
25
|
+
export interface AuthClientRequestOptions extends RequestOptions {
|
|
26
|
+
headers?: {
|
|
27
|
+
'x-request-id'?: string;
|
|
28
|
+
[key: string]: any;
|
|
29
|
+
} | null;
|
|
30
|
+
withCredentials?: boolean;
|
|
31
|
+
retry?: number;
|
|
32
|
+
[key: string]: any;
|
|
33
|
+
}
|
|
34
|
+
export interface OAuth2ClientOptions {
|
|
35
|
+
devMode?: boolean;
|
|
36
|
+
apiOrigin: string;
|
|
37
|
+
clientId: string;
|
|
38
|
+
retry?: number;
|
|
39
|
+
baseRequest?: <T>(url: string, options?: RequestOptions) => Promise<T>;
|
|
40
|
+
storage?: SimpleStorage;
|
|
41
|
+
clientSecret?: string;
|
|
42
|
+
refreshTokenFunc?: (refreshToken?: string) => Promise<Credentials>;
|
|
43
|
+
tokenInURL?: boolean;
|
|
44
|
+
headers?: {
|
|
45
|
+
[key: string]: string;
|
|
46
|
+
};
|
|
47
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kZWxzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL29hdXRoMmNsaWVudC9tb2RlbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7U2ltcGxlU3RvcmFnZX0gZnJvbSAnLi9pbnRlcmZhY2UnO1xuaW1wb3J0IHtFcnJvclR5cGV9IGZyb20gJy4vY29uc3RzJztcblxuLyoqIENyZWRlbnRpYWxzICoqL1xuZXhwb3J0IGludGVyZmFjZSBDcmVkZW50aWFscyB7XG4gICAgdG9rZW5fdHlwZT86IHN0cmluZyB8IG51bGw7XG4gICAgYWNjZXNzX3Rva2VuPzogc3RyaW5nIHwgbnVsbDtcbiAgICByZWZyZXNoX3Rva2VuPzogc3RyaW5nIHwgbnVsbDtcbiAgICBzY29wZT86IHN0cmluZyB8IG51bGw7XG4gICAgZXhwaXJlc19pbj86IG51bWJlciB8IG51bGw7XG4gICAgZXhwaXJlc19hdD86IERhdGUgfCBudWxsO1xuICAgIHN1Yj86IHN0cmluZyB8IG51bGw7XG59XG5cbi8qKiBBbiBFcnJvciBGb3IgYWxsIGNvbmNlcm4gKiovXG5leHBvcnQgaW50ZXJmYWNlIFJlc3BvbnNlRXJyb3Ige1xuICAgIGVycm9yOiBFcnJvclR5cGU7XG4gICAgZXJyb3JfZGVzY3JpcHRpb24/OiBzdHJpbmcgfCBudWxsO1xuICAgIGVycm9yX3VyaT86IHN0cmluZyB8IG51bGw7XG4gICAgZGV0YWlscz86IGFueSB8IG51bGw7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUmVxdWVzdE9wdGlvbnMge1xuICAgIGJvZHk/OiBhbnkgfCBudWxsO1xuICAgIGhlYWRlcnM/OiBhbnkgfCBudWxsO1xuICAgIG1ldGhvZD86IHN0cmluZztcblxuICAgIFtrZXk6IHN0cmluZ106IGFueTtcbn1cblxuZXhwb3J0IHR5cGUgUmVxdWVzdEZ1bmN0aW9uID0gPFQ+KFxuICAgIHVybDogc3RyaW5nLFxuICAgIG9wdGlvbnM/OiBSZXF1ZXN0T3B0aW9ucyxcbikgPT4gUHJvbWlzZTxUPjtcblxuZXhwb3J0IGludGVyZmFjZSBBdXRoQ2xpZW50UmVxdWVzdE9wdGlvbnMgZXh0ZW5kcyBSZXF1ZXN0T3B0aW9ucyB7XG4gICAgaGVhZGVycz86IHtcbiAgICAgICAgJ3gtcmVxdWVzdC1pZCc/OiBzdHJpbmc7XG4gICAgICAgIFtrZXk6IHN0cmluZ106IGFueTtcbiAgICB9IHwgbnVsbDtcbiAgICB3aXRoQ3JlZGVudGlhbHM/OiBib29sZWFuO1xuICAgIHJldHJ5PzogbnVtYmVyO1xuXG4gICAgW2tleTogc3RyaW5nXTogYW55O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIE9BdXRoMkNsaWVudE9wdGlvbnMge1xuICAgIGRldk1vZGU/OiBib29sZWFuO1xuICAgIGFwaU9yaWdpbjogc3RyaW5nO1xuICAgIGNsaWVudElkOiBzdHJpbmc7XG4gICAgLy8gZGVmYXVsdCB2YWx1ZSBpcyAxLG1pbiB2YWx1ZSBpcyAwLCBtYXggdmFsdWUgaXMgNVxuICAgIHJldHJ5PzogbnVtYmVyO1xuICAgIGJhc2VSZXF1ZXN0PzogPFQ+KHVybDogc3RyaW5nLCBvcHRpb25zPzogUmVxdWVzdE9wdGlvbnMpID0+IFByb21pc2U8VD47XG4gICAgLy8gU3RvcmFnZSwgZGVmYXVsdCBpcyBsb2NhbFN0b3JhZ2UsIHNldEl0ZW0oaywgdiksIGdldEl0ZW0oaykscmVtb3ZlSXRlbShrKVxuICAgIHN0b3JhZ2U/OiBTaW1wbGVTdG9yYWdlO1xuICAgIGNsaWVudFNlY3JldD86IHN0cmluZztcbiAgICByZWZyZXNoVG9rZW5GdW5jPzogKHJlZnJlc2hUb2tlbj86IHN0cmluZykgPT4gUHJvbWlzZTxDcmVkZW50aWFscz47XG4gICAgLy8gc2V0IHRoZSB0b2tlbiBpbiB1cmwgcXVlcnkgaW5zdGVhZCBvZiBoZWFkZXJcbiAgICB0b2tlbkluVVJMPzogYm9vbGVhbjtcbiAgICBoZWFkZXJzPzogeyBba2V5OiBzdHJpbmddOiBzdHJpbmcgfTtcbn1cbiJdfQ==
|