@esri/arcgis-rest-auth 3.4.2 → 4.0.0-beta.3
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/.ultra.cache.json +1 -0
- package/CHANGELOG.md +110 -0
- package/README.md +5 -5
- package/dist/bundled/auth.esm.js +7 -0
- package/dist/bundled/auth.esm.js.map +1 -0
- package/dist/bundled/auth.esm.min.js +7 -0
- package/dist/bundled/auth.esm.min.js.map +1 -0
- package/dist/bundled/auth.umd.js +112 -0
- package/dist/bundled/auth.umd.js.map +1 -0
- package/dist/bundled/auth.umd.min.js +7 -0
- package/dist/bundled/auth.umd.min.js.map +1 -0
- package/dist/cjs/index.js +20 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/cjs/package.json +3 -0
- package/dist/esm/index.d.ts +4 -9
- package/dist/esm/index.js +1 -8
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/package.json +3 -0
- package/package.json +44 -45
- package/src/index.ts +34 -0
- package/tsconfig.json +6 -0
- package/dist/esm/ApiKey.d.ts +0 -26
- package/dist/esm/ApiKey.js +0 -23
- package/dist/esm/ApiKey.js.map +0 -1
- package/dist/esm/ApplicationSession.d.ts +0 -60
- package/dist/esm/ApplicationSession.js +0 -59
- package/dist/esm/ApplicationSession.js.map +0 -1
- package/dist/esm/UserSession.d.ts +0 -496
- package/dist/esm/UserSession.js +0 -890
- package/dist/esm/UserSession.js.map +0 -1
- package/dist/esm/app-tokens.d.ts +0 -87
- package/dist/esm/app-tokens.js +0 -104
- package/dist/esm/app-tokens.js.map +0 -1
- package/dist/esm/authenticated-request-options.d.ts +0 -18
- package/dist/esm/authenticated-request-options.js +0 -3
- package/dist/esm/authenticated-request-options.js.map +0 -1
- package/dist/esm/federation-utils.d.ts +0 -5
- package/dist/esm/federation-utils.js +0 -59
- package/dist/esm/federation-utils.js.map +0 -1
- package/dist/esm/fetch-token.d.ts +0 -9
- package/dist/esm/fetch-token.js +0 -23
- package/dist/esm/fetch-token.js.map +0 -1
- package/dist/esm/generate-token.d.ts +0 -7
- package/dist/esm/generate-token.js +0 -17
- package/dist/esm/generate-token.js.map +0 -1
- package/dist/esm/validate-app-access.d.ts +0 -47
- package/dist/esm/validate-app-access.js +0 -52
- package/dist/esm/validate-app-access.js.map +0 -1
- package/dist/node/ApiKey.js +0 -26
- package/dist/node/ApiKey.js.map +0 -1
- package/dist/node/ApplicationSession.js +0 -62
- package/dist/node/ApplicationSession.js.map +0 -1
- package/dist/node/UserSession.js +0 -893
- package/dist/node/UserSession.js.map +0 -1
- package/dist/node/app-tokens.js +0 -109
- package/dist/node/app-tokens.js.map +0 -1
- package/dist/node/authenticated-request-options.js +0 -5
- package/dist/node/authenticated-request-options.js.map +0 -1
- package/dist/node/federation-utils.js +0 -67
- package/dist/node/federation-utils.js.map +0 -1
- package/dist/node/fetch-token.js +0 -27
- package/dist/node/fetch-token.js.map +0 -1
- package/dist/node/generate-token.js +0 -21
- package/dist/node/generate-token.js.map +0 -1
- package/dist/node/index.js +0 -14
- package/dist/node/index.js.map +0 -1
- package/dist/node/validate-app-access.js +0 -56
- package/dist/node/validate-app-access.js.map +0 -1
- package/dist/umd/auth.umd.js +0 -1253
- package/dist/umd/auth.umd.js.map +0 -1
- package/dist/umd/auth.umd.min.js +0 -7
- package/dist/umd/auth.umd.min.js.map +0 -1
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"UserSession.js","sourceRoot":"","sources":["../../src/UserSession.ts"],"names":[],"mappings":"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"}
|
package/dist/esm/app-tokens.d.ts
DELETED
|
@@ -1,87 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Request app-specific token, passing in the token for the current app.
|
|
3
|
-
*
|
|
4
|
-
* This call returns a token after performing the same checks made by validateAppAccess.
|
|
5
|
-
* It returns an app-specific token of the signed-in user only if the user has access
|
|
6
|
-
* to the app and the encrypted platform cookie is valid.
|
|
7
|
-
*
|
|
8
|
-
* A scenario where an app would use this is if it is iframed into another platform app
|
|
9
|
-
* and receives credentials via postMessage. Those credentials contain a token that is
|
|
10
|
-
* specific to the host app, so the embedded app would use `exchangeToken` to get one
|
|
11
|
-
* that is specific to itself.
|
|
12
|
-
*
|
|
13
|
-
* Note: This is only usable by Esri applications hosted on *arcgis.com, *esri.com or within
|
|
14
|
-
* an ArcGIS Enterprise installation. Custom applications can not use this.
|
|
15
|
-
*
|
|
16
|
-
* @param token
|
|
17
|
-
* @param clientId application
|
|
18
|
-
* @param portal
|
|
19
|
-
*/
|
|
20
|
-
export declare function exchangeToken(token: string, clientId: string, portal?: string): Promise<string>;
|
|
21
|
-
/**
|
|
22
|
-
* Response from the `platformSelf(...)` function.
|
|
23
|
-
*/
|
|
24
|
-
export interface IPlatformSelfResponse {
|
|
25
|
-
/**
|
|
26
|
-
* Username of the user the encrypted cookie was issued for
|
|
27
|
-
*/
|
|
28
|
-
username: string;
|
|
29
|
-
/**
|
|
30
|
-
* Token the consuming application can use, It is tied to the
|
|
31
|
-
* clientId used in the `platformSelf` call
|
|
32
|
-
*/
|
|
33
|
-
token: string;
|
|
34
|
-
/**
|
|
35
|
-
* Token expiration, in seconds-from-now
|
|
36
|
-
*/
|
|
37
|
-
expires_in: number;
|
|
38
|
-
}
|
|
39
|
-
/**
|
|
40
|
-
* Request a token for a specific application using the esri_aopc encrypted cookie
|
|
41
|
-
*
|
|
42
|
-
* When a client app boots up, it will know its clientId and the redirectUri for use
|
|
43
|
-
* in the normal /oauth/authorize pop-out oAuth flow.
|
|
44
|
-
*
|
|
45
|
-
* If the app sees an `esri_aopc` cookie (only set if the app is hosted on *.arcgis.com),
|
|
46
|
-
* it can call the /oauth2/platformSelf end-point passing in the clientId and redirectUri
|
|
47
|
-
* in headers, and it will receive back an app-specific token, assuming the user has
|
|
48
|
-
* access to the app.
|
|
49
|
-
*
|
|
50
|
-
* Since there are scenarios where an app can boot using credentials/token from localstorage
|
|
51
|
-
* but those credentials are not for the same user as the esri_aopc cookie, it is recommended that
|
|
52
|
-
* an app check the returned username against any existing identity they may have loaded.
|
|
53
|
-
*
|
|
54
|
-
* Note: This is only usable by Esri applications hosted on *arcgis.com, *esri.com or within
|
|
55
|
-
* an ArcGIS Enterprise installation. Custom applications can not use this.
|
|
56
|
-
*
|
|
57
|
-
* ```js
|
|
58
|
-
* // convert the encrypted platform cookie into a UserSession
|
|
59
|
-
* import { platformSelf, UserSession } from '@esri/arcgis-rest-auth';
|
|
60
|
-
*
|
|
61
|
-
* const portal = 'https://www.arcgis.com/sharing/rest';
|
|
62
|
-
* const clientId = 'YOURAPPCLIENTID';
|
|
63
|
-
*
|
|
64
|
-
* // exchange esri_aopc cookie
|
|
65
|
-
* return platformSelf(clientId, 'https://your-app-redirect-uri', portal)
|
|
66
|
-
* .then((response) => {
|
|
67
|
-
* const currentTimestamp = new Date().getTime();
|
|
68
|
-
* const tokenExpiresTimestamp = currentTimestamp + (response.expires_in * 1000);
|
|
69
|
-
* // Construct the session and return it
|
|
70
|
-
* return new UserSession({
|
|
71
|
-
* portal,
|
|
72
|
-
* clientId,
|
|
73
|
-
* username: response.username,
|
|
74
|
-
* token: response.token,
|
|
75
|
-
* tokenExpires: new Date(tokenExpiresTimestamp),
|
|
76
|
-
* ssl: true
|
|
77
|
-
* });
|
|
78
|
-
* })
|
|
79
|
-
*
|
|
80
|
-
* ```
|
|
81
|
-
*
|
|
82
|
-
*
|
|
83
|
-
* @param clientId
|
|
84
|
-
* @param redirectUri
|
|
85
|
-
* @param portal
|
|
86
|
-
*/
|
|
87
|
-
export declare function platformSelf(clientId: string, redirectUri: string, portal?: string): Promise<IPlatformSelfResponse>;
|
package/dist/esm/app-tokens.js
DELETED
|
@@ -1,104 +0,0 @@
|
|
|
1
|
-
/* Copyright (c) 2018-2020 Environmental Systems Research Institute, Inc.
|
|
2
|
-
* Apache-2.0 */
|
|
3
|
-
import { request } from "@esri/arcgis-rest-request";
|
|
4
|
-
/**
|
|
5
|
-
* Request app-specific token, passing in the token for the current app.
|
|
6
|
-
*
|
|
7
|
-
* This call returns a token after performing the same checks made by validateAppAccess.
|
|
8
|
-
* It returns an app-specific token of the signed-in user only if the user has access
|
|
9
|
-
* to the app and the encrypted platform cookie is valid.
|
|
10
|
-
*
|
|
11
|
-
* A scenario where an app would use this is if it is iframed into another platform app
|
|
12
|
-
* and receives credentials via postMessage. Those credentials contain a token that is
|
|
13
|
-
* specific to the host app, so the embedded app would use `exchangeToken` to get one
|
|
14
|
-
* that is specific to itself.
|
|
15
|
-
*
|
|
16
|
-
* Note: This is only usable by Esri applications hosted on *arcgis.com, *esri.com or within
|
|
17
|
-
* an ArcGIS Enterprise installation. Custom applications can not use this.
|
|
18
|
-
*
|
|
19
|
-
* @param token
|
|
20
|
-
* @param clientId application
|
|
21
|
-
* @param portal
|
|
22
|
-
*/
|
|
23
|
-
export function exchangeToken(token, clientId, portal) {
|
|
24
|
-
if (portal === void 0) { portal = "https://www.arcgis.com/sharing/rest"; }
|
|
25
|
-
var url = portal + "/oauth2/exchangeToken";
|
|
26
|
-
var ro = {
|
|
27
|
-
method: "POST",
|
|
28
|
-
params: {
|
|
29
|
-
f: "json",
|
|
30
|
-
client_id: clientId,
|
|
31
|
-
token: token,
|
|
32
|
-
},
|
|
33
|
-
};
|
|
34
|
-
// make the request and return the token
|
|
35
|
-
return request(url, ro).then(function (response) { return response.token; });
|
|
36
|
-
}
|
|
37
|
-
/**
|
|
38
|
-
* Request a token for a specific application using the esri_aopc encrypted cookie
|
|
39
|
-
*
|
|
40
|
-
* When a client app boots up, it will know its clientId and the redirectUri for use
|
|
41
|
-
* in the normal /oauth/authorize pop-out oAuth flow.
|
|
42
|
-
*
|
|
43
|
-
* If the app sees an `esri_aopc` cookie (only set if the app is hosted on *.arcgis.com),
|
|
44
|
-
* it can call the /oauth2/platformSelf end-point passing in the clientId and redirectUri
|
|
45
|
-
* in headers, and it will receive back an app-specific token, assuming the user has
|
|
46
|
-
* access to the app.
|
|
47
|
-
*
|
|
48
|
-
* Since there are scenarios where an app can boot using credentials/token from localstorage
|
|
49
|
-
* but those credentials are not for the same user as the esri_aopc cookie, it is recommended that
|
|
50
|
-
* an app check the returned username against any existing identity they may have loaded.
|
|
51
|
-
*
|
|
52
|
-
* Note: This is only usable by Esri applications hosted on *arcgis.com, *esri.com or within
|
|
53
|
-
* an ArcGIS Enterprise installation. Custom applications can not use this.
|
|
54
|
-
*
|
|
55
|
-
* ```js
|
|
56
|
-
* // convert the encrypted platform cookie into a UserSession
|
|
57
|
-
* import { platformSelf, UserSession } from '@esri/arcgis-rest-auth';
|
|
58
|
-
*
|
|
59
|
-
* const portal = 'https://www.arcgis.com/sharing/rest';
|
|
60
|
-
* const clientId = 'YOURAPPCLIENTID';
|
|
61
|
-
*
|
|
62
|
-
* // exchange esri_aopc cookie
|
|
63
|
-
* return platformSelf(clientId, 'https://your-app-redirect-uri', portal)
|
|
64
|
-
* .then((response) => {
|
|
65
|
-
* const currentTimestamp = new Date().getTime();
|
|
66
|
-
* const tokenExpiresTimestamp = currentTimestamp + (response.expires_in * 1000);
|
|
67
|
-
* // Construct the session and return it
|
|
68
|
-
* return new UserSession({
|
|
69
|
-
* portal,
|
|
70
|
-
* clientId,
|
|
71
|
-
* username: response.username,
|
|
72
|
-
* token: response.token,
|
|
73
|
-
* tokenExpires: new Date(tokenExpiresTimestamp),
|
|
74
|
-
* ssl: true
|
|
75
|
-
* });
|
|
76
|
-
* })
|
|
77
|
-
*
|
|
78
|
-
* ```
|
|
79
|
-
*
|
|
80
|
-
*
|
|
81
|
-
* @param clientId
|
|
82
|
-
* @param redirectUri
|
|
83
|
-
* @param portal
|
|
84
|
-
*/
|
|
85
|
-
export function platformSelf(clientId, redirectUri, portal) {
|
|
86
|
-
if (portal === void 0) { portal = "https://www.arcgis.com/sharing/rest"; }
|
|
87
|
-
// TEMPORARY: the f=json should not be needed, but currently is
|
|
88
|
-
var url = portal + "/oauth2/platformSelf?f=json";
|
|
89
|
-
var ro = {
|
|
90
|
-
method: "POST",
|
|
91
|
-
headers: {
|
|
92
|
-
"X-Esri-Auth-Client-Id": clientId,
|
|
93
|
-
"X-Esri-Auth-Redirect-Uri": redirectUri,
|
|
94
|
-
},
|
|
95
|
-
// Note: request has logic to include the cookie
|
|
96
|
-
// for platformSelf calls w/ the X-Esri-Auth-Client-Id header
|
|
97
|
-
params: {
|
|
98
|
-
f: "json",
|
|
99
|
-
},
|
|
100
|
-
};
|
|
101
|
-
// make the request and return the token
|
|
102
|
-
return request(url, ro);
|
|
103
|
-
}
|
|
104
|
-
//# sourceMappingURL=app-tokens.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"app-tokens.js","sourceRoot":"","sources":["../../src/app-tokens.ts"],"names":[],"mappings":"AAAA;gBACgB;AAEhB,OAAO,EAAmB,OAAO,EAAE,MAAM,2BAA2B,CAAC;AAErE;;;;;;;;;;;;;;;;;;GAkBG;AACH,MAAM,UAAU,aAAa,CAC3B,KAAa,EACb,QAAgB,EAChB,MAA8C;IAA9C,uBAAA,EAAA,8CAA8C;IAE9C,IAAM,GAAG,GAAM,MAAM,0BAAuB,CAAC;IAC7C,IAAM,EAAE,GAAG;QACT,MAAM,EAAE,MAAM;QACd,MAAM,EAAE;YACN,CAAC,EAAE,MAAM;YACT,SAAS,EAAE,QAAQ;YACnB,KAAK,OAAA;SACN;KACiB,CAAC;IACrB,wCAAwC;IACxC,OAAO,OAAO,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,UAAC,QAAQ,IAAK,OAAA,QAAQ,CAAC,KAAK,EAAd,CAAc,CAAC,CAAC;AAC7D,CAAC;AAqBD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA+CG;AACH,MAAM,UAAU,YAAY,CAC1B,QAAgB,EAChB,WAAmB,EACnB,MAA8C;IAA9C,uBAAA,EAAA,8CAA8C;IAE9C,+DAA+D;IAC/D,IAAM,GAAG,GAAM,MAAM,gCAA6B,CAAC;IACnD,IAAM,EAAE,GAAG;QACT,MAAM,EAAE,MAAM;QACd,OAAO,EAAE;YACP,uBAAuB,EAAE,QAAQ;YACjC,0BAA0B,EAAE,WAAW;SACxC;QACD,gDAAgD;QAChD,6DAA6D;QAC7D,MAAM,EAAE;YACN,CAAC,EAAE,MAAM;SACV;KACiB,CAAC;IACrB,wCAAwC;IACxC,OAAO,OAAO,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;AAC1B,CAAC"}
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import { ApplicationSession } from "./ApplicationSession";
|
|
2
|
-
import { UserSession } from "./UserSession";
|
|
3
|
-
import { IRequestOptions } from "@esri/arcgis-rest-request";
|
|
4
|
-
/**
|
|
5
|
-
* Used internally by packages for requests that require user authentication.
|
|
6
|
-
*/
|
|
7
|
-
export interface IAuthenticatedRequestOptions extends IRequestOptions {
|
|
8
|
-
authentication: UserSession | ApplicationSession;
|
|
9
|
-
}
|
|
10
|
-
/**
|
|
11
|
-
* Used internally by packages for requests that require authentication.
|
|
12
|
-
*/
|
|
13
|
-
export interface IUserRequestOptions extends IRequestOptions {
|
|
14
|
-
/**
|
|
15
|
-
* A session representing a logged in user.
|
|
16
|
-
*/
|
|
17
|
-
authentication: UserSession;
|
|
18
|
-
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"authenticated-request-options.js","sourceRoot":"","sources":["../../src/authenticated-request-options.ts"],"names":[],"mappings":"AAAA;gBACgB"}
|
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
export declare function isOnline(url: string): boolean;
|
|
2
|
-
export declare function normalizeOnlinePortalUrl(portalUrl: string): string;
|
|
3
|
-
export declare function getOnlineEnvironment(url: string): string;
|
|
4
|
-
export declare function isFederated(owningSystemUrl: string, portalUrl: string): boolean;
|
|
5
|
-
export declare function canUseOnlineToken(portalUrl: string, requestUrl: string): boolean;
|
|
@@ -1,59 +0,0 @@
|
|
|
1
|
-
import { cleanUrl } from "@esri/arcgis-rest-request";
|
|
2
|
-
/**
|
|
3
|
-
* Used to test if a URL is an ArcGIS Online URL
|
|
4
|
-
*/
|
|
5
|
-
var arcgisOnlineUrlRegex = /^https?:\/\/(\S+)\.arcgis\.com.+/;
|
|
6
|
-
/**
|
|
7
|
-
* Used to test if a URL is production ArcGIS Online Portal
|
|
8
|
-
*/
|
|
9
|
-
var arcgisOnlinePortalRegex = /^https?:\/\/(dev|devext|qa|qaext|www)\.arcgis\.com\/sharing\/rest+/;
|
|
10
|
-
/**
|
|
11
|
-
* Used to test if a URL is an ArcGIS Online Organization Portal
|
|
12
|
-
*/
|
|
13
|
-
var arcgisOnlineOrgPortalRegex = /^https?:\/\/(?:[a-z0-9-]+\.maps(dev|devext|qa|qaext)?)?.arcgis\.com\/sharing\/rest/;
|
|
14
|
-
export function isOnline(url) {
|
|
15
|
-
return arcgisOnlineUrlRegex.test(url);
|
|
16
|
-
}
|
|
17
|
-
export function normalizeOnlinePortalUrl(portalUrl) {
|
|
18
|
-
if (!arcgisOnlineUrlRegex.test(portalUrl)) {
|
|
19
|
-
return portalUrl;
|
|
20
|
-
}
|
|
21
|
-
switch (getOnlineEnvironment(portalUrl)) {
|
|
22
|
-
case "dev":
|
|
23
|
-
return "https://devext.arcgis.com/sharing/rest";
|
|
24
|
-
case "qa":
|
|
25
|
-
return "https://qaext.arcgis.com/sharing/rest";
|
|
26
|
-
default:
|
|
27
|
-
return "https://www.arcgis.com/sharing/rest";
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
export function getOnlineEnvironment(url) {
|
|
31
|
-
if (!arcgisOnlineUrlRegex.test(url)) {
|
|
32
|
-
return null;
|
|
33
|
-
}
|
|
34
|
-
var match = url.match(arcgisOnlineUrlRegex);
|
|
35
|
-
var subdomain = match[1].split(".").pop();
|
|
36
|
-
if (subdomain.includes("dev")) {
|
|
37
|
-
return "dev";
|
|
38
|
-
}
|
|
39
|
-
if (subdomain.includes("qa")) {
|
|
40
|
-
return "qa";
|
|
41
|
-
}
|
|
42
|
-
return "production";
|
|
43
|
-
}
|
|
44
|
-
export function isFederated(owningSystemUrl, portalUrl) {
|
|
45
|
-
var normalizedPortalUrl = cleanUrl(normalizeOnlinePortalUrl(portalUrl)).replace(/https?:\/\//, "");
|
|
46
|
-
var normalizedOwningSystemUrl = cleanUrl(owningSystemUrl).replace(/https?:\/\//, "");
|
|
47
|
-
return new RegExp(normalizedOwningSystemUrl, "i").test(normalizedPortalUrl);
|
|
48
|
-
}
|
|
49
|
-
export function canUseOnlineToken(portalUrl, requestUrl) {
|
|
50
|
-
var portalIsOnline = isOnline(portalUrl);
|
|
51
|
-
var requestIsOnline = isOnline(requestUrl);
|
|
52
|
-
var portalEnv = getOnlineEnvironment(portalUrl);
|
|
53
|
-
var requestEnv = getOnlineEnvironment(requestUrl);
|
|
54
|
-
if (portalIsOnline && requestIsOnline && portalEnv === requestEnv) {
|
|
55
|
-
return true;
|
|
56
|
-
}
|
|
57
|
-
return false;
|
|
58
|
-
}
|
|
59
|
-
//# sourceMappingURL=federation-utils.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"federation-utils.js","sourceRoot":"","sources":["../../src/federation-utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,2BAA2B,CAAC;AACrD;;GAEG;AACH,IAAM,oBAAoB,GAAG,kCAAkC,CAAC;AAEhE;;GAEG;AACH,IAAM,uBAAuB,GAAG,oEAAoE,CAAC;AAErG;;GAEG;AACH,IAAM,0BAA0B,GAAG,oFAAoF,CAAC;AAExH,MAAM,UAAU,QAAQ,CAAC,GAAW;IAClC,OAAO,oBAAoB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AACxC,CAAC;AAED,MAAM,UAAU,wBAAwB,CAAC,SAAiB;IACxD,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE;QACzC,OAAO,SAAS,CAAC;KAClB;IAED,QAAQ,oBAAoB,CAAC,SAAS,CAAC,EAAE;QACvC,KAAK,KAAK;YACR,OAAO,wCAAwC,CAAC;QAClD,KAAK,IAAI;YACP,OAAO,uCAAuC,CAAC;QACjD;YACE,OAAO,qCAAqC,CAAC;KAChD;AACH,CAAC;AAED,MAAM,UAAU,oBAAoB,CAAC,GAAW;IAC9C,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE;QACnC,OAAO,IAAI,CAAC;KACb;IAED,IAAM,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,oBAAoB,CAAC,CAAC;IAC9C,IAAM,SAAS,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC;IAE5C,IAAI,SAAS,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE;QAC7B,OAAO,KAAK,CAAC;KACd;IAED,IAAI,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE;QAC5B,OAAO,IAAI,CAAC;KACb;IAED,OAAO,YAAY,CAAC;AACtB,CAAC;AAED,MAAM,UAAU,WAAW,CACzB,eAAuB,EACvB,SAAiB;IAEjB,IAAM,mBAAmB,GAAG,QAAQ,CAClC,wBAAwB,CAAC,SAAS,CAAC,CACpC,CAAC,OAAO,CAAC,aAAa,EAAE,EAAE,CAAC,CAAC;IAE7B,IAAM,yBAAyB,GAAG,QAAQ,CAAC,eAAe,CAAC,CAAC,OAAO,CACjE,aAAa,EACb,EAAE,CACH,CAAC;IAEF,OAAO,IAAI,MAAM,CAAC,yBAAyB,EAAE,GAAG,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;AAC9E,CAAC;AAED,MAAM,UAAU,iBAAiB,CAC/B,SAAiB,EACjB,UAAkB;IAElB,IAAM,cAAc,GAAG,QAAQ,CAAC,SAAS,CAAC,CAAC;IAC3C,IAAM,eAAe,GAAG,QAAQ,CAAC,UAAU,CAAC,CAAC;IAC7C,IAAM,SAAS,GAAG,oBAAoB,CAAC,SAAS,CAAC,CAAC;IAClD,IAAM,UAAU,GAAG,oBAAoB,CAAC,UAAU,CAAC,CAAC;IAEpD,IAAI,cAAc,IAAI,eAAe,IAAI,SAAS,KAAK,UAAU,EAAE;QACjE,OAAO,IAAI,CAAC;KACb;IAED,OAAO,KAAK,CAAC;AACf,CAAC"}
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import { ITokenRequestOptions } from "@esri/arcgis-rest-request";
|
|
2
|
-
export interface IFetchTokenResponse {
|
|
3
|
-
token: string;
|
|
4
|
-
expires: Date;
|
|
5
|
-
username: string;
|
|
6
|
-
ssl: boolean;
|
|
7
|
-
refreshToken?: string;
|
|
8
|
-
}
|
|
9
|
-
export declare function fetchToken(url: string, requestOptions: ITokenRequestOptions): Promise<IFetchTokenResponse>;
|
package/dist/esm/fetch-token.js
DELETED
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
/* Copyright (c) 2017 Environmental Systems Research Institute, Inc.
|
|
2
|
-
* Apache-2.0 */
|
|
3
|
-
import { request } from "@esri/arcgis-rest-request";
|
|
4
|
-
export function fetchToken(url, requestOptions) {
|
|
5
|
-
var options = requestOptions;
|
|
6
|
-
// we generate a response, so we can't return the raw response
|
|
7
|
-
options.rawResponse = false;
|
|
8
|
-
return request(url, options).then(function (response) {
|
|
9
|
-
var r = {
|
|
10
|
-
token: response.access_token,
|
|
11
|
-
username: response.username,
|
|
12
|
-
expires: new Date(
|
|
13
|
-
// convert seconds in response to milliseconds and add the value to the current time to calculate a static expiration timestamp
|
|
14
|
-
Date.now() + (response.expires_in * 1000 - 1000)),
|
|
15
|
-
ssl: response.ssl === true
|
|
16
|
-
};
|
|
17
|
-
if (response.refresh_token) {
|
|
18
|
-
r.refreshToken = response.refresh_token;
|
|
19
|
-
}
|
|
20
|
-
return r;
|
|
21
|
-
});
|
|
22
|
-
}
|
|
23
|
-
//# sourceMappingURL=fetch-token.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"fetch-token.js","sourceRoot":"","sources":["../../src/fetch-token.ts"],"names":[],"mappings":"AAAA;gBACgB;AAEhB,OAAO,EACL,OAAO,EAGR,MAAM,2BAA2B,CAAC;AAkBnC,MAAM,UAAU,UAAU,CACxB,GAAW,EACX,cAAoC;IAEpC,IAAM,OAAO,GAAoB,cAAc,CAAC;IAChD,8DAA8D;IAC9D,OAAO,CAAC,WAAW,GAAG,KAAK,CAAC;IAE5B,OAAO,OAAO,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC,IAAI,CAAC,UAAC,QAAgC;QACjE,IAAM,CAAC,GAAwB;YAC7B,KAAK,EAAE,QAAQ,CAAC,YAAY;YAC5B,QAAQ,EAAE,QAAQ,CAAC,QAAQ;YAC3B,OAAO,EAAE,IAAI,IAAI;YACf,+HAA+H;YAC/H,IAAI,CAAC,GAAG,EAAE,GAAG,CAAC,QAAQ,CAAC,UAAU,GAAG,IAAI,GAAG,IAAI,CAAC,CACjD;YACD,GAAG,EAAE,QAAQ,CAAC,GAAG,KAAK,IAAI;SAC3B,CAAC;QACF,IAAI,QAAQ,CAAC,aAAa,EAAE;YAC1B,CAAC,CAAC,YAAY,GAAG,QAAQ,CAAC,aAAa,CAAC;SACzC;QAED,OAAO,CAAC,CAAC;IACX,CAAC,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import { ITokenRequestOptions } from "@esri/arcgis-rest-request";
|
|
2
|
-
export interface IGenerateTokenResponse {
|
|
3
|
-
token: string;
|
|
4
|
-
expires: number;
|
|
5
|
-
ssl: boolean;
|
|
6
|
-
}
|
|
7
|
-
export declare function generateToken(url: string, requestOptions: ITokenRequestOptions): Promise<IGenerateTokenResponse>;
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
/* Copyright (c) 2017-2018 Environmental Systems Research Institute, Inc.
|
|
2
|
-
* Apache-2.0 */
|
|
3
|
-
import { request, NODEJS_DEFAULT_REFERER_HEADER, } from "@esri/arcgis-rest-request";
|
|
4
|
-
export function generateToken(url, requestOptions) {
|
|
5
|
-
var options = requestOptions;
|
|
6
|
-
/* istanbul ignore else */
|
|
7
|
-
if (typeof window !== "undefined" &&
|
|
8
|
-
window.location &&
|
|
9
|
-
window.location.host) {
|
|
10
|
-
options.params.referer = window.location.host;
|
|
11
|
-
}
|
|
12
|
-
else {
|
|
13
|
-
options.params.referer = NODEJS_DEFAULT_REFERER_HEADER;
|
|
14
|
-
}
|
|
15
|
-
return request(url, options);
|
|
16
|
-
}
|
|
17
|
-
//# sourceMappingURL=generate-token.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"generate-token.js","sourceRoot":"","sources":["../../src/generate-token.ts"],"names":[],"mappings":"AAAA;gBACgB;AAEhB,OAAO,EACL,OAAO,EAGP,6BAA6B,GAC9B,MAAM,2BAA2B,CAAC;AAQnC,MAAM,UAAU,aAAa,CAC3B,GAAW,EACX,cAAoC;IAEpC,IAAM,OAAO,GAAoB,cAAc,CAAC;IAEhD,0BAA0B;IAC1B,IACE,OAAO,MAAM,KAAK,WAAW;QAC7B,MAAM,CAAC,QAAQ;QACf,MAAM,CAAC,QAAQ,CAAC,IAAI,EACpB;QACA,OAAO,CAAC,MAAM,CAAC,OAAO,GAAG,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC;KAC/C;SAAM;QACL,OAAO,CAAC,MAAM,CAAC,OAAO,GAAG,6BAA6B,CAAC;KACxD;IAED,OAAO,OAAO,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;AAC/B,CAAC"}
|
|
@@ -1,47 +0,0 @@
|
|
|
1
|
-
export interface IAppAccess {
|
|
2
|
-
/**
|
|
3
|
-
* Verifies that the token is valid and the user has access to
|
|
4
|
-
* the specified app (clientId)
|
|
5
|
-
*/
|
|
6
|
-
valid: boolean;
|
|
7
|
-
/**
|
|
8
|
-
* Should the app present the current user with a "View Only" mode
|
|
9
|
-
*/
|
|
10
|
-
viewOnlyUserTypeApp: boolean;
|
|
11
|
-
}
|
|
12
|
-
/**
|
|
13
|
-
* Validates that the user has access to the application
|
|
14
|
-
* and if they user should be presented a "View Only" mode
|
|
15
|
-
*
|
|
16
|
-
* This is only needed/valid for Esri applications that are "licensed"
|
|
17
|
-
* and shipped in ArcGIS Online or ArcGIS Enterprise. Most custom applications
|
|
18
|
-
* should not need or use this.
|
|
19
|
-
*
|
|
20
|
-
* ```js
|
|
21
|
-
* import { validateAppAccess } from '@esri/arcgis-rest-auth';
|
|
22
|
-
*
|
|
23
|
-
* return validateAppAccess('your-token', 'theClientId')
|
|
24
|
-
* .then((result) => {
|
|
25
|
-
* if (!result.value) {
|
|
26
|
-
* // redirect or show some other ui
|
|
27
|
-
* } else {
|
|
28
|
-
* if (result.viewOnlyUserTypeApp) {
|
|
29
|
-
* // use this to inform your app to show a "View Only" mode
|
|
30
|
-
* }
|
|
31
|
-
* }
|
|
32
|
-
* })
|
|
33
|
-
* .catch((err) => {
|
|
34
|
-
* // two possible errors
|
|
35
|
-
* // invalid clientId: {"error":{"code":400,"messageCode":"GWM_0007","message":"Invalid request","details":[]}}
|
|
36
|
-
* // invalid token: {"error":{"code":498,"message":"Invalid token.","details":[]}}
|
|
37
|
-
* })
|
|
38
|
-
* ```
|
|
39
|
-
*
|
|
40
|
-
* Note: This is only usable by Esri applications hosted on *arcgis.com, *esri.com or within
|
|
41
|
-
* an ArcGIS Enterprise installation. Custom applications can not use this.
|
|
42
|
-
*
|
|
43
|
-
* @param token platform token
|
|
44
|
-
* @param clientId application client id
|
|
45
|
-
* @param portal Optional
|
|
46
|
-
*/
|
|
47
|
-
export declare function validateAppAccess(token: string, clientId: string, portal?: string): Promise<IAppAccess>;
|
|
@@ -1,52 +0,0 @@
|
|
|
1
|
-
/* Copyright (c) 2018-2020 Environmental Systems Research Institute, Inc.
|
|
2
|
-
* Apache-2.0 */
|
|
3
|
-
import { request } from "@esri/arcgis-rest-request";
|
|
4
|
-
/**
|
|
5
|
-
* Validates that the user has access to the application
|
|
6
|
-
* and if they user should be presented a "View Only" mode
|
|
7
|
-
*
|
|
8
|
-
* This is only needed/valid for Esri applications that are "licensed"
|
|
9
|
-
* and shipped in ArcGIS Online or ArcGIS Enterprise. Most custom applications
|
|
10
|
-
* should not need or use this.
|
|
11
|
-
*
|
|
12
|
-
* ```js
|
|
13
|
-
* import { validateAppAccess } from '@esri/arcgis-rest-auth';
|
|
14
|
-
*
|
|
15
|
-
* return validateAppAccess('your-token', 'theClientId')
|
|
16
|
-
* .then((result) => {
|
|
17
|
-
* if (!result.value) {
|
|
18
|
-
* // redirect or show some other ui
|
|
19
|
-
* } else {
|
|
20
|
-
* if (result.viewOnlyUserTypeApp) {
|
|
21
|
-
* // use this to inform your app to show a "View Only" mode
|
|
22
|
-
* }
|
|
23
|
-
* }
|
|
24
|
-
* })
|
|
25
|
-
* .catch((err) => {
|
|
26
|
-
* // two possible errors
|
|
27
|
-
* // invalid clientId: {"error":{"code":400,"messageCode":"GWM_0007","message":"Invalid request","details":[]}}
|
|
28
|
-
* // invalid token: {"error":{"code":498,"message":"Invalid token.","details":[]}}
|
|
29
|
-
* })
|
|
30
|
-
* ```
|
|
31
|
-
*
|
|
32
|
-
* Note: This is only usable by Esri applications hosted on *arcgis.com, *esri.com or within
|
|
33
|
-
* an ArcGIS Enterprise installation. Custom applications can not use this.
|
|
34
|
-
*
|
|
35
|
-
* @param token platform token
|
|
36
|
-
* @param clientId application client id
|
|
37
|
-
* @param portal Optional
|
|
38
|
-
*/
|
|
39
|
-
export function validateAppAccess(token, clientId, portal) {
|
|
40
|
-
if (portal === void 0) { portal = "https://www.arcgis.com/sharing/rest"; }
|
|
41
|
-
var url = portal + "/oauth2/validateAppAccess";
|
|
42
|
-
var ro = {
|
|
43
|
-
method: "POST",
|
|
44
|
-
params: {
|
|
45
|
-
f: "json",
|
|
46
|
-
client_id: clientId,
|
|
47
|
-
token: token,
|
|
48
|
-
},
|
|
49
|
-
};
|
|
50
|
-
return request(url, ro);
|
|
51
|
-
}
|
|
52
|
-
//# sourceMappingURL=validate-app-access.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"validate-app-access.js","sourceRoot":"","sources":["../../src/validate-app-access.ts"],"names":[],"mappings":"AAAA;gBACgB;AAEhB,OAAO,EAAmB,OAAO,EAAE,MAAM,2BAA2B,CAAC;AAcrE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAkCG;AACH,MAAM,UAAU,iBAAiB,CAC/B,KAAa,EACb,QAAgB,EAChB,MAA8C;IAA9C,uBAAA,EAAA,8CAA8C;IAE9C,IAAM,GAAG,GAAM,MAAM,8BAA2B,CAAC;IACjD,IAAM,EAAE,GAAG;QACT,MAAM,EAAE,MAAM;QACd,MAAM,EAAE;YACN,CAAC,EAAE,MAAM;YACT,SAAS,EAAE,QAAQ;YACnB,KAAK,OAAA;SACN;KACiB,CAAC;IACrB,OAAO,OAAO,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;AAC1B,CAAC"}
|
package/dist/node/ApiKey.js
DELETED
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
/* Copyright (c) 2017-2019 Environmental Systems Research Institute, Inc.
|
|
3
|
-
* Apache-2.0 */
|
|
4
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
5
|
-
exports.ApiKey = void 0;
|
|
6
|
-
/**
|
|
7
|
-
* ```js
|
|
8
|
-
* import { ApiKey } from '@esri/arcgis-rest-auth';
|
|
9
|
-
* const apiKey = new ApiKey("...");
|
|
10
|
-
* ```
|
|
11
|
-
* Used to authenticate with API Keys.
|
|
12
|
-
*/
|
|
13
|
-
var ApiKey = /** @class */ (function () {
|
|
14
|
-
function ApiKey(options) {
|
|
15
|
-
this.key = options.key;
|
|
16
|
-
}
|
|
17
|
-
/**
|
|
18
|
-
* Gets a token (the API Key).
|
|
19
|
-
*/
|
|
20
|
-
ApiKey.prototype.getToken = function (url) {
|
|
21
|
-
return Promise.resolve(this.key);
|
|
22
|
-
};
|
|
23
|
-
return ApiKey;
|
|
24
|
-
}());
|
|
25
|
-
exports.ApiKey = ApiKey;
|
|
26
|
-
//# sourceMappingURL=ApiKey.js.map
|
package/dist/node/ApiKey.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ApiKey.js","sourceRoot":"","sources":["../../src/ApiKey.ts"],"names":[],"mappings":";AAAA;gBACgB;;;AAahB;;;;;;GAMG;AACH;IASE,gBAAY,OAAuB;QACjC,IAAI,CAAC,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC;IACzB,CAAC;IAED;;OAEG;IACI,yBAAQ,GAAf,UAAgB,GAAW;QACzB,OAAO,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACnC,CAAC;IACH,aAAC;AAAD,CAAC,AAnBD,IAmBC;AAnBY,wBAAM"}
|
|
@@ -1,62 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
/* Copyright (c) 2017-2018 Environmental Systems Research Institute, Inc.
|
|
3
|
-
* Apache-2.0 */
|
|
4
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
5
|
-
exports.ApplicationSession = void 0;
|
|
6
|
-
var tslib_1 = require("tslib");
|
|
7
|
-
var fetch_token_1 = require("./fetch-token");
|
|
8
|
-
/**
|
|
9
|
-
* ```js
|
|
10
|
-
* import { ApplicationSession } from '@esri/arcgis-rest-auth';
|
|
11
|
-
* const session = new ApplicationSession({
|
|
12
|
-
* clientId: "abc123",
|
|
13
|
-
* clientSecret: "sshhhhhh"
|
|
14
|
-
* })
|
|
15
|
-
* // visit https://developers.arcgis.com to generate your own clientid and secret
|
|
16
|
-
* ```
|
|
17
|
-
* You can use [App Login](/arcgis-rest-js/guides/node/) to access premium content and services in ArcGIS Online.
|
|
18
|
-
*
|
|
19
|
-
*/
|
|
20
|
-
var ApplicationSession = /** @class */ (function () {
|
|
21
|
-
function ApplicationSession(options) {
|
|
22
|
-
this.clientId = options.clientId;
|
|
23
|
-
this.clientSecret = options.clientSecret;
|
|
24
|
-
this.token = options.token;
|
|
25
|
-
this.expires = options.expires;
|
|
26
|
-
this.portal = options.portal || "https://www.arcgis.com/sharing/rest";
|
|
27
|
-
this.duration = options.duration || 7200;
|
|
28
|
-
}
|
|
29
|
-
// URL is not actually read or passed through.
|
|
30
|
-
ApplicationSession.prototype.getToken = function (url, requestOptions) {
|
|
31
|
-
if (this.token && this.expires && this.expires.getTime() > Date.now()) {
|
|
32
|
-
return Promise.resolve(this.token);
|
|
33
|
-
}
|
|
34
|
-
if (this._pendingTokenRequest) {
|
|
35
|
-
return this._pendingTokenRequest;
|
|
36
|
-
}
|
|
37
|
-
this._pendingTokenRequest = this.refreshToken(requestOptions);
|
|
38
|
-
return this._pendingTokenRequest;
|
|
39
|
-
};
|
|
40
|
-
ApplicationSession.prototype.refreshToken = function (requestOptions) {
|
|
41
|
-
var _this = this;
|
|
42
|
-
var options = tslib_1.__assign({ params: {
|
|
43
|
-
client_id: this.clientId,
|
|
44
|
-
client_secret: this.clientSecret,
|
|
45
|
-
grant_type: "client_credentials",
|
|
46
|
-
expiration: this.duration
|
|
47
|
-
} }, requestOptions);
|
|
48
|
-
return fetch_token_1.fetchToken(this.portal + "/oauth2/token/", options).then(function (response) {
|
|
49
|
-
_this._pendingTokenRequest = null;
|
|
50
|
-
_this.token = response.token;
|
|
51
|
-
_this.expires = response.expires;
|
|
52
|
-
return response.token;
|
|
53
|
-
});
|
|
54
|
-
};
|
|
55
|
-
ApplicationSession.prototype.refreshSession = function () {
|
|
56
|
-
var _this = this;
|
|
57
|
-
return this.refreshToken().then(function () { return _this; });
|
|
58
|
-
};
|
|
59
|
-
return ApplicationSession;
|
|
60
|
-
}());
|
|
61
|
-
exports.ApplicationSession = ApplicationSession;
|
|
62
|
-
//# sourceMappingURL=ApplicationSession.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ApplicationSession.js","sourceRoot":"","sources":["../../src/ApplicationSession.ts"],"names":[],"mappings":";AAAA;gBACgB;;;;AAMhB,6CAA2C;AAsC3C;;;;;;;;;;;GAWG;AACH;IAcE,4BAAY,OAAmC;QAC7C,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC;QACjC,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC,YAAY,CAAC;QACzC,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC;QAC3B,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC;QAC/B,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC,MAAM,IAAI,qCAAqC,CAAC;QACtE,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,QAAQ,IAAI,IAAI,CAAC;IAC3C,CAAC;IAED,8CAA8C;IACvC,qCAAQ,GAAf,UACE,GAAW,EACX,cAAqC;QAErC,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,GAAG,EAAE,EAAE;YACrE,OAAO,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SACpC;QAED,IAAI,IAAI,CAAC,oBAAoB,EAAE;YAC7B,OAAO,IAAI,CAAC,oBAAoB,CAAC;SAClC;QAED,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,CAAC;QAE9D,OAAO,IAAI,CAAC,oBAAoB,CAAC;IACnC,CAAC;IAEM,yCAAY,GAAnB,UAAoB,cAAqC;QAAzD,iBAkBC;QAjBC,IAAM,OAAO,sBACX,MAAM,EAAE;gBACN,SAAS,EAAE,IAAI,CAAC,QAAQ;gBACxB,aAAa,EAAE,IAAI,CAAC,YAAY;gBAChC,UAAU,EAAE,oBAAoB;gBAChC,UAAU,EAAE,IAAI,CAAC,QAAQ;aAC1B,IACE,cAAc,CAClB,CAAC;QACF,OAAO,wBAAU,CAAI,IAAI,CAAC,MAAM,mBAAgB,EAAE,OAAO,CAAC,CAAC,IAAI,CAC7D,UAAA,QAAQ;YACN,KAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC;YACjC,KAAI,CAAC,KAAK,GAAG,QAAQ,CAAC,KAAK,CAAC;YAC5B,KAAI,CAAC,OAAO,GAAG,QAAQ,CAAC,OAAO,CAAC;YAChC,OAAO,QAAQ,CAAC,KAAK,CAAC;QACxB,CAAC,CACF,CAAC;IACJ,CAAC;IAEM,2CAAc,GAArB;QAAA,iBAEC;QADC,OAAO,IAAI,CAAC,YAAY,EAAE,CAAC,IAAI,CAAC,cAAM,OAAA,KAAI,EAAJ,CAAI,CAAC,CAAC;IAC9C,CAAC;IACH,yBAAC;AAAD,CAAC,AAhED,IAgEC;AAhEY,gDAAkB"}
|