angular-auth-oidc-client
Version:
Angular Lib for OpenID Connect & OAuth2
405 lines • 69.9 kB
JavaScript
import { HttpParams } from '@angular/common/http';
import { Injectable } from '@angular/core';
import { of } from 'rxjs';
import { map } from 'rxjs/operators';
import { UriEncoder } from './uri-encoder';
import * as i0 from "@angular/core";
import * as i1 from "../../logging/logger.service";
import * as i2 from "../../flows/flows-data.service";
import * as i3 from "../flowHelper/flow-helper.service";
import * as i4 from "../../storage/storage-persistence.service";
import * as i5 from "../../validation/jwt-window-crypto.service";
const CALLBACK_PARAMS_TO_CHECK = ['code', 'state', 'token', 'id_token'];
const AUTH0_ENDPOINT = 'auth0.com';
export class UrlService {
constructor(loggerService, flowsDataService, flowHelper, storagePersistenceService, jwtWindowCryptoService) {
this.loggerService = loggerService;
this.flowsDataService = flowsDataService;
this.flowHelper = flowHelper;
this.storagePersistenceService = storagePersistenceService;
this.jwtWindowCryptoService = jwtWindowCryptoService;
}
getUrlParameter(urlToCheck, name) {
if (!urlToCheck) {
return '';
}
if (!name) {
return '';
}
name = name.replace(/[[]/, '\\[').replace(/[\]]/, '\\]');
const regex = new RegExp('[\\?&#]' + name + '=([^&#]*)');
const results = regex.exec(urlToCheck);
return results === null ? '' : decodeURIComponent(results[1]);
}
isCallbackFromSts(currentUrl) {
return CALLBACK_PARAMS_TO_CHECK.some((x) => !!this.getUrlParameter(currentUrl, x));
}
getRefreshSessionSilentRenewUrl(config, customParams) {
if (this.flowHelper.isCurrentFlowCodeFlow(config)) {
return this.createUrlCodeFlowWithSilentRenew(config, customParams);
}
return of(this.createUrlImplicitFlowWithSilentRenew(config, customParams) || '');
}
getAuthorizeParUrl(requestUri, configuration) {
const authWellKnownEndPoints = this.storagePersistenceService.read('authWellKnownEndPoints', configuration);
if (!authWellKnownEndPoints) {
this.loggerService.logError(configuration, 'authWellKnownEndpoints is undefined');
return null;
}
const authorizationEndpoint = authWellKnownEndPoints.authorizationEndpoint;
if (!authorizationEndpoint) {
this.loggerService.logError(configuration, `Can not create an authorize URL when authorizationEndpoint is '${authorizationEndpoint}'`);
return null;
}
const { clientId } = configuration;
if (!clientId) {
this.loggerService.logError(configuration, `getAuthorizeParUrl could not add clientId because it was: `, clientId);
return null;
}
const urlParts = authorizationEndpoint.split('?');
const authorizationUrl = urlParts[0];
const existingParams = urlParts[1];
let params = this.createHttpParams(existingParams);
params = params.set('request_uri', requestUri);
params = params.append('client_id', clientId);
return `${authorizationUrl}?${params}`;
}
getAuthorizeUrl(config, authOptions) {
if (this.flowHelper.isCurrentFlowCodeFlow(config)) {
return this.createUrlCodeFlowAuthorize(config, authOptions);
}
return of(this.createUrlImplicitFlowAuthorize(config, authOptions) || '');
}
createEndSessionUrl(idTokenHint, configuration, customParamsEndSession) {
// Auth0 needs a special logout url
// See https://auth0.com/docs/api/authentication#logout
if (this.isAuth0Endpoint(configuration)) {
return this.composeAuth0Endpoint(configuration);
}
const authWellKnownEndPoints = this.storagePersistenceService.read('authWellKnownEndPoints', configuration);
const endSessionEndpoint = authWellKnownEndPoints?.endSessionEndpoint;
if (!endSessionEndpoint) {
return null;
}
const urlParts = endSessionEndpoint.split('?');
const authorizationEndSessionUrl = urlParts[0];
const existingParams = urlParts[1];
let params = this.createHttpParams(existingParams);
if (!!idTokenHint) {
params = params.set('id_token_hint', idTokenHint);
}
const postLogoutRedirectUri = this.getPostLogoutRedirectUrl(configuration);
if (postLogoutRedirectUri) {
params = params.append('post_logout_redirect_uri', postLogoutRedirectUri);
}
if (customParamsEndSession) {
params = this.appendCustomParams({ ...customParamsEndSession }, params);
}
return `${authorizationEndSessionUrl}?${params}`;
}
createRevocationEndpointBodyAccessToken(token, configuration) {
const clientId = this.getClientId(configuration);
if (!clientId) {
return null;
}
let params = this.createHttpParams();
params = params.set('client_id', clientId);
params = params.set('token', token);
params = params.set('token_type_hint', 'access_token');
return params.toString();
}
createRevocationEndpointBodyRefreshToken(token, configuration) {
const clientId = this.getClientId(configuration);
if (!clientId) {
return null;
}
let params = this.createHttpParams();
params = params.set('client_id', clientId);
params = params.set('token', token);
params = params.set('token_type_hint', 'refresh_token');
return params.toString();
}
getRevocationEndpointUrl(configuration) {
const authWellKnownEndPoints = this.storagePersistenceService.read('authWellKnownEndPoints', configuration);
const revocationEndpoint = authWellKnownEndPoints?.revocationEndpoint;
if (!revocationEndpoint) {
return null;
}
const urlParts = revocationEndpoint.split('?');
const revocationEndpointUrl = urlParts[0];
return revocationEndpointUrl;
}
createBodyForCodeFlowCodeRequest(code, configuration, customTokenParams) {
const clientId = this.getClientId(configuration);
if (!clientId) {
return null;
}
let params = this.createHttpParams();
params = params.set('grant_type', 'authorization_code');
params = params.set('client_id', clientId);
if (!configuration.disablePkce) {
const codeVerifier = this.flowsDataService.getCodeVerifier(configuration);
if (!codeVerifier) {
this.loggerService.logError(configuration, `CodeVerifier is not set `, codeVerifier);
return null;
}
params = params.set('code_verifier', codeVerifier);
}
params = params.set('code', code);
if (customTokenParams) {
params = this.appendCustomParams({ ...customTokenParams }, params);
}
const silentRenewUrl = this.getSilentRenewUrl(configuration);
if (this.flowsDataService.isSilentRenewRunning(configuration) && silentRenewUrl) {
params = params.set('redirect_uri', silentRenewUrl);
return params.toString();
}
const redirectUrl = this.getRedirectUrl(configuration);
if (!redirectUrl) {
return null;
}
params = params.set('redirect_uri', redirectUrl);
return params.toString();
}
createBodyForCodeFlowRefreshTokensRequest(refreshToken, configuration, customParamsRefresh) {
const clientId = this.getClientId(configuration);
if (!clientId) {
return null;
}
let params = this.createHttpParams();
params = params.set('grant_type', 'refresh_token');
params = params.set('client_id', clientId);
params = params.set('refresh_token', refreshToken);
if (customParamsRefresh) {
params = this.appendCustomParams({ ...customParamsRefresh }, params);
}
return params.toString();
}
createBodyForParCodeFlowRequest(configuration, customParamsRequest) {
const redirectUrl = this.getRedirectUrl(configuration);
if (!redirectUrl) {
return of(null);
}
const state = this.flowsDataService.getExistingOrCreateAuthStateControl(configuration);
const nonce = this.flowsDataService.createNonce(configuration);
this.loggerService.logDebug(configuration, 'Authorize created. adding myautostate: ' + state);
// code_challenge with "S256"
const codeVerifier = this.flowsDataService.createCodeVerifier(configuration);
return this.jwtWindowCryptoService.generateCodeChallenge(codeVerifier).pipe(map((codeChallenge) => {
const { clientId, responseType, scope, hdParam, customParamsAuthRequest } = configuration;
let params = this.createHttpParams('');
params = params.set('client_id', clientId);
params = params.append('redirect_uri', redirectUrl);
params = params.append('response_type', responseType);
params = params.append('scope', scope);
params = params.append('nonce', nonce);
params = params.append('state', state);
params = params.append('code_challenge', codeChallenge);
params = params.append('code_challenge_method', 'S256');
if (hdParam) {
params = params.append('hd', hdParam);
}
if (customParamsAuthRequest) {
params = this.appendCustomParams({ ...customParamsAuthRequest }, params);
}
if (customParamsRequest) {
params = this.appendCustomParams({ ...customParamsRequest }, params);
}
return params.toString();
}));
}
createAuthorizeUrl(codeChallenge, redirectUrl, nonce, state, configuration, prompt, customRequestParams) {
const authWellKnownEndPoints = this.storagePersistenceService.read('authWellKnownEndPoints', configuration);
const authorizationEndpoint = authWellKnownEndPoints?.authorizationEndpoint;
if (!authorizationEndpoint) {
this.loggerService.logError(configuration, `Can not create an authorize URL when authorizationEndpoint is '${authorizationEndpoint}'`);
return null;
}
const { clientId, responseType, scope, hdParam, customParamsAuthRequest } = configuration;
if (!clientId) {
this.loggerService.logError(configuration, `createAuthorizeUrl could not add clientId because it was: `, clientId);
return null;
}
if (!responseType) {
this.loggerService.logError(configuration, `createAuthorizeUrl could not add responseType because it was: `, responseType);
return null;
}
if (!scope) {
this.loggerService.logError(configuration, `createAuthorizeUrl could not add scope because it was: `, scope);
return null;
}
const urlParts = authorizationEndpoint.split('?');
const authorizationUrl = urlParts[0];
const existingParams = urlParts[1];
let params = this.createHttpParams(existingParams);
params = params.set('client_id', clientId);
params = params.append('redirect_uri', redirectUrl);
params = params.append('response_type', responseType);
params = params.append('scope', scope);
params = params.append('nonce', nonce);
params = params.append('state', state);
if (this.flowHelper.isCurrentFlowCodeFlow(configuration) && codeChallenge !== null) {
params = params.append('code_challenge', codeChallenge);
params = params.append('code_challenge_method', 'S256');
}
const mergedParams = { ...customParamsAuthRequest, ...customRequestParams };
if (Object.keys(mergedParams).length > 0) {
params = this.appendCustomParams({ ...mergedParams }, params);
}
if (prompt) {
params = this.overWriteParam(params, 'prompt', prompt);
}
if (hdParam) {
params = params.append('hd', hdParam);
}
return `${authorizationUrl}?${params}`;
}
createUrlImplicitFlowWithSilentRenew(configuration, customParams) {
const state = this.flowsDataService.getExistingOrCreateAuthStateControl(configuration);
const nonce = this.flowsDataService.createNonce(configuration);
const silentRenewUrl = this.getSilentRenewUrl(configuration);
if (!silentRenewUrl) {
return null;
}
this.loggerService.logDebug(configuration, 'RefreshSession created. adding myautostate: ', state);
const authWellKnownEndPoints = this.storagePersistenceService.read('authWellKnownEndPoints', configuration);
if (authWellKnownEndPoints) {
return this.createAuthorizeUrl('', silentRenewUrl, nonce, state, configuration, 'none', customParams);
}
this.loggerService.logError(configuration, 'authWellKnownEndpoints is undefined');
return null;
}
createUrlCodeFlowWithSilentRenew(configuration, customParams) {
const state = this.flowsDataService.getExistingOrCreateAuthStateControl(configuration);
const nonce = this.flowsDataService.createNonce(configuration);
this.loggerService.logDebug(configuration, 'RefreshSession created. adding myautostate: ' + state);
// code_challenge with "S256"
const codeVerifier = this.flowsDataService.createCodeVerifier(configuration);
return this.jwtWindowCryptoService.generateCodeChallenge(codeVerifier).pipe(map((codeChallenge) => {
const silentRenewUrl = this.getSilentRenewUrl(configuration);
if (!silentRenewUrl) {
return '';
}
const authWellKnownEndPoints = this.storagePersistenceService.read('authWellKnownEndPoints', configuration);
if (authWellKnownEndPoints) {
return this.createAuthorizeUrl(codeChallenge, silentRenewUrl, nonce, state, configuration, 'none', customParams);
}
this.loggerService.logWarning(configuration, 'authWellKnownEndpoints is undefined');
return null;
}));
}
createUrlImplicitFlowAuthorize(configuration, authOptions) {
const state = this.flowsDataService.getExistingOrCreateAuthStateControl(configuration);
const nonce = this.flowsDataService.createNonce(configuration);
this.loggerService.logDebug(configuration, 'Authorize created. adding myautostate: ' + state);
const redirectUrl = this.getRedirectUrl(configuration, authOptions);
if (!redirectUrl) {
return null;
}
const authWellKnownEndPoints = this.storagePersistenceService.read('authWellKnownEndPoints', configuration);
if (authWellKnownEndPoints) {
const { customParams } = authOptions || {};
return this.createAuthorizeUrl('', redirectUrl, nonce, state, configuration, null, customParams);
}
this.loggerService.logError(configuration, 'authWellKnownEndpoints is undefined');
return null;
}
createUrlCodeFlowAuthorize(config, authOptions) {
const state = this.flowsDataService.getExistingOrCreateAuthStateControl(config);
const nonce = this.flowsDataService.createNonce(config);
this.loggerService.logDebug(config, 'Authorize created. adding myautostate: ' + state);
const redirectUrl = this.getRedirectUrl(config, authOptions);
if (!redirectUrl) {
return of(null);
}
return this.getCodeChallenge(config).pipe(map((codeChallenge) => {
const authWellKnownEndPoints = this.storagePersistenceService.read('authWellKnownEndPoints', config);
if (authWellKnownEndPoints) {
const { customParams } = authOptions || {};
return this.createAuthorizeUrl(codeChallenge, redirectUrl, nonce, state, config, null, customParams);
}
this.loggerService.logError(config, 'authWellKnownEndpoints is undefined');
return '';
}));
}
getCodeChallenge(config) {
if (config.disablePkce) {
return of(null);
}
// code_challenge with "S256"
const codeVerifier = this.flowsDataService.createCodeVerifier(config);
return this.jwtWindowCryptoService.generateCodeChallenge(codeVerifier);
}
getRedirectUrl(configuration, authOptions) {
let { redirectUrl } = configuration;
if (authOptions?.redirectUrl) {
// override by redirectUrl from authOptions
redirectUrl = authOptions.redirectUrl;
}
if (!redirectUrl) {
this.loggerService.logError(configuration, `could not get redirectUrl, was: `, redirectUrl);
return null;
}
return redirectUrl;
}
getSilentRenewUrl(configuration) {
const { silentRenewUrl } = configuration;
if (!silentRenewUrl) {
this.loggerService.logError(configuration, `could not get silentRenewUrl, was: `, silentRenewUrl);
return null;
}
return silentRenewUrl;
}
getPostLogoutRedirectUrl(configuration) {
const { postLogoutRedirectUri } = configuration;
if (!postLogoutRedirectUri) {
this.loggerService.logError(configuration, `could not get postLogoutRedirectUri, was: `, postLogoutRedirectUri);
return null;
}
return postLogoutRedirectUri;
}
getClientId(configuration) {
const { clientId } = configuration;
if (!clientId) {
this.loggerService.logError(configuration, `could not get clientId, was: `, clientId);
return null;
}
return clientId;
}
appendCustomParams(customParams, params) {
for (const [key, value] of Object.entries({ ...customParams })) {
params = params.append(key, value.toString());
}
return params;
}
overWriteParam(params, key, value) {
return params.set(key, value);
}
createHttpParams(existingParams) {
existingParams = existingParams ?? '';
const params = new HttpParams({
fromString: existingParams,
encoder: new UriEncoder(),
});
return params;
}
isAuth0Endpoint(configuration) {
const { authority } = configuration;
if (!authority) {
return false;
}
return authority.endsWith(AUTH0_ENDPOINT);
}
composeAuth0Endpoint(configuration) {
// format: https://YOUR_DOMAIN/v2/logout?client_id=YOUR_CLIENT_ID&returnTo=LOGOUT_URL
const { authority, clientId } = configuration;
const postLogoutRedirectUrl = this.getPostLogoutRedirectUrl(configuration);
return `${authority}/v2/logout?client_id=${clientId}&returnTo=${postLogoutRedirectUrl}`;
}
}
UrlService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: UrlService, deps: [{ token: i1.LoggerService }, { token: i2.FlowsDataService }, { token: i3.FlowHelper }, { token: i4.StoragePersistenceService }, { token: i5.JwtWindowCryptoService }], target: i0.ɵɵFactoryTarget.Injectable });
UrlService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: UrlService });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: UrlService, decorators: [{
type: Injectable
}], ctorParameters: function () { return [{ type: i1.LoggerService }, { type: i2.FlowsDataService }, { type: i3.FlowHelper }, { type: i4.StoragePersistenceService }, { type: i5.JwtWindowCryptoService }]; } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"url.service.js","sourceRoot":"","sources":["../../../../../../projects/angular-auth-oidc-client/src/lib/utils/url/url.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAClD,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAC3C,OAAO,EAAc,EAAE,EAAE,MAAM,MAAM,CAAC;AACtC,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AAQrC,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;;;;;;;AAE3C,MAAM,wBAAwB,GAAG,CAAC,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,UAAU,CAAC,CAAC;AACxE,MAAM,cAAc,GAAG,WAAW,CAAC;AAGnC,MAAM,OAAO,UAAU;IACrB,YACmB,aAA4B,EAC5B,gBAAkC,EAClC,UAAsB,EACtB,yBAAoD,EACpD,sBAA8C;QAJ9C,kBAAa,GAAb,aAAa,CAAe;QAC5B,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,eAAU,GAAV,UAAU,CAAY;QACtB,8BAAyB,GAAzB,yBAAyB,CAA2B;QACpD,2BAAsB,GAAtB,sBAAsB,CAAwB;IAC9D,CAAC;IAEJ,eAAe,CAAC,UAAe,EAAE,IAAS;QACxC,IAAI,CAAC,UAAU,EAAE;YACf,OAAO,EAAE,CAAC;SACX;QAED,IAAI,CAAC,IAAI,EAAE;YACT,OAAO,EAAE,CAAC;SACX;QAED,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,OAAO,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;QACzD,MAAM,KAAK,GAAG,IAAI,MAAM,CAAC,SAAS,GAAG,IAAI,GAAG,WAAW,CAAC,CAAC;QACzD,MAAM,OAAO,GAAG,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAEvC,OAAO,OAAO,KAAK,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;IAChE,CAAC;IAED,iBAAiB,CAAC,UAAkB;QAClC,OAAO,wBAAwB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC,CAAC;IACrF,CAAC;IAED,+BAA+B,CAC7B,MAA2B,EAC3B,YAA2D;QAE3D,IAAI,IAAI,CAAC,UAAU,CAAC,qBAAqB,CAAC,MAAM,CAAC,EAAE;YACjD,OAAO,IAAI,CAAC,gCAAgC,CAAC,MAAM,EAAE,YAAY,CAAC,CAAC;SACpE;QAED,OAAO,EAAE,CAAC,IAAI,CAAC,oCAAoC,CAAC,MAAM,EAAE,YAAY,CAAC,IAAI,EAAE,CAAC,CAAC;IACnF,CAAC;IAED,kBAAkB,CAAC,UAAkB,EAAE,aAAkC;QACvE,MAAM,sBAAsB,GAAG,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,wBAAwB,EAAE,aAAa,CAAC,CAAC;QAE5G,IAAI,CAAC,sBAAsB,EAAE;YAC3B,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,aAAa,EAAE,qCAAqC,CAAC,CAAC;YAElF,OAAO,IAAI,CAAC;SACb;QAED,MAAM,qBAAqB,GAAG,sBAAsB,CAAC,qBAAqB,CAAC;QAE3E,IAAI,CAAC,qBAAqB,EAAE;YAC1B,IAAI,CAAC,aAAa,CAAC,QAAQ,CACzB,aAAa,EACb,kEAAkE,qBAAqB,GAAG,CAC3F,CAAC;YAEF,OAAO,IAAI,CAAC;SACb;QAED,MAAM,EAAE,QAAQ,EAAE,GAAG,aAAa,CAAC;QAEnC,IAAI,CAAC,QAAQ,EAAE;YACb,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,aAAa,EAAE,4DAA4D,EAAE,QAAQ,CAAC,CAAC;YAEnH,OAAO,IAAI,CAAC;SACb;QAED,MAAM,QAAQ,GAAG,qBAAqB,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAClD,MAAM,gBAAgB,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;QACrC,MAAM,cAAc,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;QACnC,IAAI,MAAM,GAAG,IAAI,CAAC,gBAAgB,CAAC,cAAc,CAAC,CAAC;QAEnD,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,aAAa,EAAE,UAAU,CAAC,CAAC;QAC/C,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;QAE9C,OAAO,GAAG,gBAAgB,IAAI,MAAM,EAAE,CAAC;IACzC,CAAC;IAED,eAAe,CAAC,MAA2B,EAAE,WAAyB;QACpE,IAAI,IAAI,CAAC,UAAU,CAAC,qBAAqB,CAAC,MAAM,CAAC,EAAE;YACjD,OAAO,IAAI,CAAC,0BAA0B,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;SAC7D;QAED,OAAO,EAAE,CAAC,IAAI,CAAC,8BAA8B,CAAC,MAAM,EAAE,WAAW,CAAC,IAAI,EAAE,CAAC,CAAC;IAC5E,CAAC;IAED,mBAAmB,CACjB,WAAmB,EACnB,aAAkC,EAClC,sBAAmE;QAEnE,mCAAmC;QACnC,uDAAuD;QAEvD,IAAI,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,EAAE;YACvC,OAAO,IAAI,CAAC,oBAAoB,CAAC,aAAa,CAAC,CAAC;SACjD;QAED,MAAM,sBAAsB,GAAG,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,wBAAwB,EAAE,aAAa,CAAC,CAAC;QAC5G,MAAM,kBAAkB,GAAG,sBAAsB,EAAE,kBAAkB,CAAC;QAEtE,IAAI,CAAC,kBAAkB,EAAE;YACvB,OAAO,IAAI,CAAC;SACb;QAED,MAAM,QAAQ,GAAG,kBAAkB,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAC/C,MAAM,0BAA0B,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;QAC/C,MAAM,cAAc,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;QACnC,IAAI,MAAM,GAAG,IAAI,CAAC,gBAAgB,CAAC,cAAc,CAAC,CAAC;QAEnD,IAAI,CAAC,CAAC,WAAW,EAAE;YACjB,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,eAAe,EAAE,WAAW,CAAC,CAAC;SACnD;QAED,MAAM,qBAAqB,GAAG,IAAI,CAAC,wBAAwB,CAAC,aAAa,CAAC,CAAC;QAE3E,IAAI,qBAAqB,EAAE;YACzB,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,0BAA0B,EAAE,qBAAqB,CAAC,CAAC;SAC3E;QAED,IAAI,sBAAsB,EAAE;YAC1B,MAAM,GAAG,IAAI,CAAC,kBAAkB,CAAC,EAAE,GAAG,sBAAsB,EAAE,EAAE,MAAM,CAAC,CAAC;SACzE;QAED,OAAO,GAAG,0BAA0B,IAAI,MAAM,EAAE,CAAC;IACnD,CAAC;IAED,uCAAuC,CAAC,KAAU,EAAE,aAAkC;QACpF,MAAM,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC;QAEjD,IAAI,CAAC,QAAQ,EAAE;YACb,OAAO,IAAI,CAAC;SACb;QAED,IAAI,MAAM,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAErC,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;QAC3C,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;QACpC,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,iBAAiB,EAAE,cAAc,CAAC,CAAC;QAEvD,OAAO,MAAM,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;IAED,wCAAwC,CAAC,KAAU,EAAE,aAAkC;QACrF,MAAM,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC;QAEjD,IAAI,CAAC,QAAQ,EAAE;YACb,OAAO,IAAI,CAAC;SACb;QAED,IAAI,MAAM,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAErC,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;QAC3C,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;QACpC,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,iBAAiB,EAAE,eAAe,CAAC,CAAC;QAExD,OAAO,MAAM,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;IAED,wBAAwB,CAAC,aAAkC;QACzD,MAAM,sBAAsB,GAAG,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,wBAAwB,EAAE,aAAa,CAAC,CAAC;QAC5G,MAAM,kBAAkB,GAAG,sBAAsB,EAAE,kBAAkB,CAAC;QAEtE,IAAI,CAAC,kBAAkB,EAAE;YACvB,OAAO,IAAI,CAAC;SACb;QAED,MAAM,QAAQ,GAAG,kBAAkB,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAE/C,MAAM,qBAAqB,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;QAE1C,OAAO,qBAAqB,CAAC;IAC/B,CAAC;IAED,gCAAgC,CAC9B,IAAY,EACZ,aAAkC,EAClC,iBAA8D;QAE9D,MAAM,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC;QAEjD,IAAI,CAAC,QAAQ,EAAE;YACb,OAAO,IAAI,CAAC;SACb;QAED,IAAI,MAAM,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAErC,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,YAAY,EAAE,oBAAoB,CAAC,CAAC;QACxD,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;QAE3C,IAAG,CAAC,aAAa,CAAC,WAAW,EAAE;YAC7B,MAAM,YAAY,GAAG,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC;YAE1E,IAAI,CAAC,YAAY,EAAE;gBACjB,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,aAAa,EAAE,0BAA0B,EAAE,YAAY,CAAC,CAAC;gBAErF,OAAO,IAAI,CAAC;aACb;YAED,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,eAAe,EAAE,YAAY,CAAC,CAAC;SACpD;QAED,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;QAElC,IAAI,iBAAiB,EAAE;YACrB,MAAM,GAAG,IAAI,CAAC,kBAAkB,CAAC,EAAE,GAAG,iBAAiB,EAAE,EAAE,MAAM,CAAC,CAAC;SACpE;QAED,MAAM,cAAc,GAAG,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAC,CAAC;QAE7D,IAAI,IAAI,CAAC,gBAAgB,CAAC,oBAAoB,CAAC,aAAa,CAAC,IAAI,cAAc,EAAE;YAC/E,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,cAAc,EAAE,cAAc,CAAC,CAAC;YAEpD,OAAO,MAAM,CAAC,QAAQ,EAAE,CAAC;SAC1B;QAED,MAAM,WAAW,GAAG,IAAI,CAAC,cAAc,CAAC,aAAa,CAAC,CAAC;QAEvD,IAAI,CAAC,WAAW,EAAE;YAChB,OAAO,IAAI,CAAC;SACb;QAED,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,cAAc,EAAE,WAAW,CAAC,CAAC;QAEjD,OAAO,MAAM,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;IAED,yCAAyC,CACvC,YAAoB,EACpB,aAAkC,EAClC,mBAAkE;QAElE,MAAM,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC;QAEjD,IAAI,CAAC,QAAQ,EAAE;YACb,OAAO,IAAI,CAAC;SACb;QAED,IAAI,MAAM,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAErC,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,YAAY,EAAE,eAAe,CAAC,CAAC;QACnD,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;QAC3C,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,eAAe,EAAE,YAAY,CAAC,CAAC;QAEnD,IAAI,mBAAmB,EAAE;YACvB,MAAM,GAAG,IAAI,CAAC,kBAAkB,CAAC,EAAE,GAAG,mBAAmB,EAAE,EAAE,MAAM,CAAC,CAAC;SACtE;QAED,OAAO,MAAM,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;IAED,+BAA+B,CAC7B,aAAkC,EAClC,mBAAkE;QAElE,MAAM,WAAW,GAAG,IAAI,CAAC,cAAc,CAAC,aAAa,CAAC,CAAC;QAEvD,IAAI,CAAC,WAAW,EAAE;YAChB,OAAO,EAAE,CAAC,IAAI,CAAC,CAAC;SACjB;QAED,MAAM,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,mCAAmC,CAAC,aAAa,CAAC,CAAC;QACvF,MAAM,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC;QAE/D,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,aAAa,EAAE,yCAAyC,GAAG,KAAK,CAAC,CAAC;QAE9F,6BAA6B;QAC7B,MAAM,YAAY,GAAG,IAAI,CAAC,gBAAgB,CAAC,kBAAkB,CAAC,aAAa,CAAC,CAAC;QAE7E,OAAO,IAAI,CAAC,sBAAsB,CAAC,qBAAqB,CAAC,YAAY,CAAC,CAAC,IAAI,CACzE,GAAG,CAAC,CAAC,aAAqB,EAAE,EAAE;YAC5B,MAAM,EAAE,QAAQ,EAAE,YAAY,EAAE,KAAK,EAAE,OAAO,EAAE,uBAAuB,EAAE,GAAG,aAAa,CAAC;YAC1F,IAAI,MAAM,GAAG,IAAI,CAAC,gBAAgB,CAAC,EAAE,CAAC,CAAC;YAEvC,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;YAC3C,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,cAAc,EAAE,WAAW,CAAC,CAAC;YACpD,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,eAAe,EAAE,YAAY,CAAC,CAAC;YACtD,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;YACvC,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;YACvC,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;YACvC,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,gBAAgB,EAAE,aAAa,CAAC,CAAC;YACxD,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,uBAAuB,EAAE,MAAM,CAAC,CAAC;YAExD,IAAI,OAAO,EAAE;gBACX,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;aACvC;YAED,IAAI,uBAAuB,EAAE;gBAC3B,MAAM,GAAG,IAAI,CAAC,kBAAkB,CAAC,EAAE,GAAG,uBAAuB,EAAE,EAAE,MAAM,CAAC,CAAC;aAC1E;YAED,IAAI,mBAAmB,EAAE;gBACvB,MAAM,GAAG,IAAI,CAAC,kBAAkB,CAAC,EAAE,GAAG,mBAAmB,EAAE,EAAE,MAAM,CAAC,CAAC;aACtE;YAED,OAAO,MAAM,CAAC,QAAQ,EAAE,CAAC;QAC3B,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAEO,kBAAkB,CACxB,aAAqB,EACrB,WAAmB,EACnB,KAAa,EACb,KAAa,EACb,aAAkC,EAClC,MAAe,EACf,mBAAkE;QAElE,MAAM,sBAAsB,GAAG,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,wBAAwB,EAAE,aAAa,CAAC,CAAC;QAC5G,MAAM,qBAAqB,GAAG,sBAAsB,EAAE,qBAAqB,CAAC;QAE5E,IAAI,CAAC,qBAAqB,EAAE;YAC1B,IAAI,CAAC,aAAa,CAAC,QAAQ,CACzB,aAAa,EACb,kEAAkE,qBAAqB,GAAG,CAC3F,CAAC;YAEF,OAAO,IAAI,CAAC;SACb;QAED,MAAM,EAAE,QAAQ,EAAE,YAAY,EAAE,KAAK,EAAE,OAAO,EAAE,uBAAuB,EAAE,GAAG,aAAa,CAAC;QAE1F,IAAI,CAAC,QAAQ,EAAE;YACb,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,aAAa,EAAE,4DAA4D,EAAE,QAAQ,CAAC,CAAC;YAEnH,OAAO,IAAI,CAAC;SACb;QAED,IAAI,CAAC,YAAY,EAAE;YACjB,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,aAAa,EAAE,gEAAgE,EAAE,YAAY,CAAC,CAAC;YAE3H,OAAO,IAAI,CAAC;SACb;QAED,IAAI,CAAC,KAAK,EAAE;YACV,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,aAAa,EAAE,yDAAyD,EAAE,KAAK,CAAC,CAAC;YAE7G,OAAO,IAAI,CAAC;SACb;QAED,MAAM,QAAQ,GAAG,qBAAqB,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAClD,MAAM,gBAAgB,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;QACrC,MAAM,cAAc,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;QACnC,IAAI,MAAM,GAAG,IAAI,CAAC,gBAAgB,CAAC,cAAc,CAAC,CAAC;QAEnD,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;QAC3C,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,cAAc,EAAE,WAAW,CAAC,CAAC;QACpD,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,eAAe,EAAE,YAAY,CAAC,CAAC;QACtD,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;QACvC,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;QACvC,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;QAEvC,IAAI,IAAI,CAAC,UAAU,CAAC,qBAAqB,CAAC,aAAa,CAAC,IAAI,aAAa,KAAK,IAAI,EAAE;YAClF,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,gBAAgB,EAAE,aAAa,CAAC,CAAC;YACxD,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,uBAAuB,EAAE,MAAM,CAAC,CAAC;SACzD;QAED,MAAM,YAAY,GAAG,EAAE,GAAG,uBAAuB,EAAE,GAAG,mBAAmB,EAAE,CAAC;QAE5E,IAAI,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE;YACxC,MAAM,GAAG,IAAI,CAAC,kBAAkB,CAAC,EAAE,GAAG,YAAY,EAAE,EAAE,MAAM,CAAC,CAAC;SAC/D;QAED,IAAI,MAAM,EAAE;YACV,MAAM,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAC;SACxD;QAED,IAAI,OAAO,EAAE;YACX,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;SACvC;QAED,OAAO,GAAG,gBAAgB,IAAI,MAAM,EAAE,CAAC;IACzC,CAAC;IAEO,oCAAoC,CAC1C,aAAkC,EAClC,YAA2D;QAE3D,MAAM,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,mCAAmC,CAAC,aAAa,CAAC,CAAC;QACvF,MAAM,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC;QAC/D,MAAM,cAAc,GAAG,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAC,CAAC;QAE7D,IAAI,CAAC,cAAc,EAAE;YACnB,OAAO,IAAI,CAAC;SACb;QAED,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,aAAa,EAAE,8CAA8C,EAAE,KAAK,CAAC,CAAC;QAElG,MAAM,sBAAsB,GAAG,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,wBAAwB,EAAE,aAAa,CAAC,CAAC;QAE5G,IAAI,sBAAsB,EAAE;YAC1B,OAAO,IAAI,CAAC,kBAAkB,CAAC,EAAE,EAAE,cAAc,EAAE,KAAK,EAAE,KAAK,EAAE,aAAa,EAAE,MAAM,EAAE,YAAY,CAAC,CAAC;SACvG;QAED,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,aAAa,EAAE,qCAAqC,CAAC,CAAC;QAElF,OAAO,IAAI,CAAC;IACd,CAAC;IAEO,gCAAgC,CACtC,aAAkC,EAClC,YAA2D;QAE3D,MAAM,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,mCAAmC,CAAC,aAAa,CAAC,CAAC;QACvF,MAAM,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC;QAE/D,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,aAAa,EAAE,8CAA8C,GAAG,KAAK,CAAC,CAAC;QAEnG,6BAA6B;QAC7B,MAAM,YAAY,GAAG,IAAI,CAAC,gBAAgB,CAAC,kBAAkB,CAAC,aAAa,CAAC,CAAC;QAE7E,OAAO,IAAI,CAAC,sBAAsB,CAAC,qBAAqB,CAAC,YAAY,CAAC,CAAC,IAAI,CACzE,GAAG,CAAC,CAAC,aAAqB,EAAE,EAAE;YAC5B,MAAM,cAAc,GAAG,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAC,CAAC;YAE7D,IAAI,CAAC,cAAc,EAAE;gBACnB,OAAO,EAAE,CAAC;aACX;YAED,MAAM,sBAAsB,GAAG,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,wBAAwB,EAAE,aAAa,CAAC,CAAC;YAE5G,IAAI,sBAAsB,EAAE;gBAC1B,OAAO,IAAI,CAAC,kBAAkB,CAAC,aAAa,EAAE,cAAc,EAAE,KAAK,EAAE,KAAK,EAAE,aAAa,EAAE,MAAM,EAAE,YAAY,CAAC,CAAC;aAClH;YAED,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,aAAa,EAAE,qCAAqC,CAAC,CAAC;YAEpF,OAAO,IAAI,CAAC;QACd,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAEO,8BAA8B,CAAC,aAAkC,EAAE,WAAyB;QAClG,MAAM,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,mCAAmC,CAAC,aAAa,CAAC,CAAC;QACvF,MAAM,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC;QAE/D,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,aAAa,EAAE,yCAAyC,GAAG,KAAK,CAAC,CAAC;QAE9F,MAAM,WAAW,GAAG,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,WAAW,CAAC,CAAC;QAEpE,IAAI,CAAC,WAAW,EAAE;YAChB,OAAO,IAAI,CAAC;SACb;QAED,MAAM,sBAAsB,GAAG,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,wBAAwB,EAAE,aAAa,CAAC,CAAC;QAE5G,IAAI,sBAAsB,EAAE;YAC1B,MAAM,EAAE,YAAY,EAAE,GAAG,WAAW,IAAI,EAAE,CAAC;YAE3C,OAAO,IAAI,CAAC,kBAAkB,CAAC,EAAE,EAAE,WAAW,EAAE,KAAK,EAAE,KAAK,EAAE,aAAa,EAAE,IAAI,EAAE,YAAY,CAAC,CAAC;SAClG;QAED,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,aAAa,EAAE,qCAAqC,CAAC,CAAC;QAElF,OAAO,IAAI,CAAC;IACd,CAAC;IAEO,0BAA0B,CAAC,MAA2B,EAAE,WAAyB;QACvF,MAAM,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,mCAAmC,CAAC,MAAM,CAAC,CAAC;QAChF,MAAM,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;QAExD,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,MAAM,EAAE,yCAAyC,GAAG,KAAK,CAAC,CAAC;QAEvF,MAAM,WAAW,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;QAE7D,IAAI,CAAC,WAAW,EAAE;YAChB,OAAO,EAAE,CAAC,IAAI,CAAC,CAAC;SACjB;QAED,OAAO,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC,IAAI,CACvC,GAAG,CAAC,CAAC,aAAqB,EAAE,EAAE;YAC5B,MAAM,sBAAsB,GAAG,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,wBAAwB,EAAE,MAAM,CAAC,CAAC;YAErG,IAAI,sBAAsB,EAAE;gBAC1B,MAAM,EAAE,YAAY,EAAE,GAAG,WAAW,IAAI,EAAE,CAAC;gBAE3C,OAAO,IAAI,CAAC,kBAAkB,CAAC,aAAa,EAAE,WAAW,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,YAAY,CAAC,CAAC;aACtG;YAED,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,MAAM,EAAE,qCAAqC,CAAC,CAAC;YAE3E,OAAO,EAAE,CAAC;QACZ,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAEO,gBAAgB,CAAC,MAA2B;QAClD,IAAI,MAAM,CAAC,WAAW,EAAE;YACtB,OAAO,EAAE,CAAC,IAAI,CAAC,CAAC;SACjB;QAED,6BAA6B;QAC7B,MAAM,YAAY,GAAG,IAAI,CAAC,gBAAgB,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC;QAEtE,OAAO,IAAI,CAAC,sBAAsB,CAAC,qBAAqB,CAAC,YAAY,CAAC,CAAC;IACzE,CAAC;IAEO,cAAc,CAAC,aAAkC,EAAE,WAAyB;QAClF,IAAI,EAAE,WAAW,EAAE,GAAG,aAAa,CAAC;QAEpC,IAAI,WAAW,EAAE,WAAW,EAAE;YAC5B,2CAA2C;YAC3C,WAAW,GAAG,WAAW,CAAC,WAAW,CAAC;SACvC;QAED,IAAI,CAAC,WAAW,EAAE;YAChB,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,aAAa,EAAE,kCAAkC,EAAE,WAAW,CAAC,CAAC;YAE5F,OAAO,IAAI,CAAC;SACb;QAED,OAAO,WAAW,CAAC;IACrB,CAAC;IAEO,iBAAiB,CAAC,aAAkC;QAC1D,MAAM,EAAE,cAAc,EAAE,GAAG,aAAa,CAAC;QAEzC,IAAI,CAAC,cAAc,EAAE;YACnB,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,aAAa,EAAE,qCAAqC,EAAE,cAAc,CAAC,CAAC;YAElG,OAAO,IAAI,CAAC;SACb;QAED,OAAO,cAAc,CAAC;IACxB,CAAC;IAEO,wBAAwB,CAAC,aAAkC;QACjE,MAAM,EAAE,qBAAqB,EAAE,GAAG,aAAa,CAAC;QAEhD,IAAI,CAAC,qBAAqB,EAAE;YAC1B,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,aAAa,EAAE,4CAA4C,EAAE,qBAAqB,CAAC,CAAC;YAEhH,OAAO,IAAI,CAAC;SACb;QAED,OAAO,qBAAqB,CAAC;IAC/B,CAAC;IAEO,WAAW,CAAC,aAAkC;QACpD,MAAM,EAAE,QAAQ,EAAE,GAAG,aAAa,CAAC;QAEnC,IAAI,CAAC,QAAQ,EAAE;YACb,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,aAAa,EAAE,+BAA+B,EAAE,QAAQ,CAAC,CAAC;YAEtF,OAAO,IAAI,CAAC;SACb;QAED,OAAO,QAAQ,CAAC;IAClB,CAAC;IAEO,kBAAkB,CAAC,YAA0D,EAAE,MAAkB;QACvG,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,EAAE,GAAG,YAAY,EAAE,CAAC,EAAE;YAC9D,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,QAAQ,EAAE,CAAC,CAAC;SAC/C;QAED,OAAO,MAAM,CAAC;IAChB,CAAC;IAEO,cAAc,CAAC,MAAkB,EAAE,GAAW,EAAE,KAAgC;QACtF,OAAO,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;IAChC,CAAC;IAEO,gBAAgB,CAAC,cAAuB;QAC9C,cAAc,GAAG,cAAc,IAAI,EAAE,CAAC;QAEtC,MAAM,MAAM,GAAG,IAAI,UAAU,CAAC;YAC5B,UAAU,EAAE,cAAc;YAC1B,OAAO,EAAE,IAAI,UAAU,EAAE;SAC1B,CAAC,CAAC;QAEH,OAAO,MAAM,CAAC;IAChB,CAAC;IAEO,eAAe,CAAC,aAAkC;QACxD,MAAM,EAAE,SAAS,EAAE,GAAG,aAAa,CAAC;QAEpC,IAAI,CAAC,SAAS,EAAE;YACd,OAAO,KAAK,CAAC;SACd;QAED,OAAO,SAAS,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAC;IAC5C,CAAC;IAEO,oBAAoB,CAAC,aAAkC;QAC7D,qFAAqF;QACrF,MAAM,EAAE,SAAS,EAAE,QAAQ,EAAE,GAAG,aAAa,CAAC;QAC9C,MAAM,qBAAqB,GAAG,IAAI,CAAC,wBAAwB,CAAC,aAAa,CAAC,CAAC;QAE3E,OAAO,GAAG,SAAS,wBAAwB,QAAQ,aAAa,qBAAqB,EAAE,CAAC;IAC1F,CAAC;;uGA/kBU,UAAU;2GAAV,UAAU;2FAAV,UAAU;kBADtB,UAAU","sourcesContent":["import { HttpParams } from '@angular/common/http';\r\nimport { Injectable } from '@angular/core';\r\nimport { Observable, of } from 'rxjs';\r\nimport { map } from 'rxjs/operators';\r\nimport { AuthOptions } from '../../auth-options';\r\nimport { OpenIdConfiguration } from '../../config/openid-configuration';\r\nimport { FlowsDataService } from '../../flows/flows-data.service';\r\nimport { LoggerService } from '../../logging/logger.service';\r\nimport { StoragePersistenceService } from '../../storage/storage-persistence.service';\r\nimport { JwtWindowCryptoService } from '../../validation/jwt-window-crypto.service';\r\nimport { FlowHelper } from '../flowHelper/flow-helper.service';\r\nimport { UriEncoder } from './uri-encoder';\r\n\r\nconst CALLBACK_PARAMS_TO_CHECK = ['code', 'state', 'token', 'id_token'];\r\nconst AUTH0_ENDPOINT = 'auth0.com';\r\n\r\n@Injectable()\r\nexport class UrlService {\r\n  constructor(\r\n    private readonly loggerService: LoggerService,\r\n    private readonly flowsDataService: FlowsDataService,\r\n    private readonly flowHelper: FlowHelper,\r\n    private readonly storagePersistenceService: StoragePersistenceService,\r\n    private readonly jwtWindowCryptoService: JwtWindowCryptoService\r\n  ) {}\r\n\r\n  getUrlParameter(urlToCheck: any, name: any): string {\r\n    if (!urlToCheck) {\r\n      return '';\r\n    }\r\n\r\n    if (!name) {\r\n      return '';\r\n    }\r\n\r\n    name = name.replace(/[[]/, '\\\\[').replace(/[\\]]/, '\\\\]');\r\n    const regex = new RegExp('[\\\\?&#]' + name + '=([^&#]*)');\r\n    const results = regex.exec(urlToCheck);\r\n\r\n    return results === null ? '' : decodeURIComponent(results[1]);\r\n  }\r\n\r\n  isCallbackFromSts(currentUrl: string): boolean {\r\n    return CALLBACK_PARAMS_TO_CHECK.some((x) => !!this.getUrlParameter(currentUrl, x));\r\n  }\r\n\r\n  getRefreshSessionSilentRenewUrl(\r\n    config: OpenIdConfiguration,\r\n    customParams?: { [key: string]: string | number | boolean }\r\n  ): Observable<string> {\r\n    if (this.flowHelper.isCurrentFlowCodeFlow(config)) {\r\n      return this.createUrlCodeFlowWithSilentRenew(config, customParams);\r\n    }\r\n\r\n    return of(this.createUrlImplicitFlowWithSilentRenew(config, customParams) || '');\r\n  }\r\n\r\n  getAuthorizeParUrl(requestUri: string, configuration: OpenIdConfiguration): string {\r\n    const authWellKnownEndPoints = this.storagePersistenceService.read('authWellKnownEndPoints', configuration);\r\n\r\n    if (!authWellKnownEndPoints) {\r\n      this.loggerService.logError(configuration, 'authWellKnownEndpoints is undefined');\r\n\r\n      return null;\r\n    }\r\n\r\n    const authorizationEndpoint = authWellKnownEndPoints.authorizationEndpoint;\r\n\r\n    if (!authorizationEndpoint) {\r\n      this.loggerService.logError(\r\n        configuration,\r\n        `Can not create an authorize URL when authorizationEndpoint is '${authorizationEndpoint}'`\r\n      );\r\n\r\n      return null;\r\n    }\r\n\r\n    const { clientId } = configuration;\r\n\r\n    if (!clientId) {\r\n      this.loggerService.logError(configuration, `getAuthorizeParUrl could not add clientId because it was: `, clientId);\r\n\r\n      return null;\r\n    }\r\n\r\n    const urlParts = authorizationEndpoint.split('?');\r\n    const authorizationUrl = urlParts[0];\r\n    const existingParams = urlParts[1];\r\n    let params = this.createHttpParams(existingParams);\r\n\r\n    params = params.set('request_uri', requestUri);\r\n    params = params.append('client_id', clientId);\r\n\r\n    return `${authorizationUrl}?${params}`;\r\n  }\r\n\r\n  getAuthorizeUrl(config: OpenIdConfiguration, authOptions?: AuthOptions): Observable<string> {\r\n    if (this.flowHelper.isCurrentFlowCodeFlow(config)) {\r\n      return this.createUrlCodeFlowAuthorize(config, authOptions);\r\n    }\r\n\r\n    return of(this.createUrlImplicitFlowAuthorize(config, authOptions) || '');\r\n  }\r\n\r\n  createEndSessionUrl(\r\n    idTokenHint: string,\r\n    configuration: OpenIdConfiguration,\r\n    customParamsEndSession?: { [p: string]: string | number | boolean }\r\n  ): string {\r\n    // Auth0 needs a special logout url\r\n    // See https://auth0.com/docs/api/authentication#logout\r\n\r\n    if (this.isAuth0Endpoint(configuration)) {\r\n      return this.composeAuth0Endpoint(configuration);\r\n    }\r\n\r\n    const authWellKnownEndPoints = this.storagePersistenceService.read('authWellKnownEndPoints', configuration);\r\n    const endSessionEndpoint = authWellKnownEndPoints?.endSessionEndpoint;\r\n\r\n    if (!endSessionEndpoint) {\r\n      return null;\r\n    }\r\n\r\n    const urlParts = endSessionEndpoint.split('?');\r\n    const authorizationEndSessionUrl = urlParts[0];\r\n    const existingParams = urlParts[1];\r\n    let params = this.createHttpParams(existingParams);\r\n\r\n    if (!!idTokenHint) {\r\n      params = params.set('id_token_hint', idTokenHint);\r\n    }\r\n\r\n    const postLogoutRedirectUri = this.getPostLogoutRedirectUrl(configuration);\r\n\r\n    if (postLogoutRedirectUri) {\r\n      params = params.append('post_logout_redirect_uri', postLogoutRedirectUri);\r\n    }\r\n\r\n    if (customParamsEndSession) {\r\n      params = this.appendCustomParams({ ...customParamsEndSession }, params);\r\n    }\r\n\r\n    return `${authorizationEndSessionUrl}?${params}`;\r\n  }\r\n\r\n  createRevocationEndpointBodyAccessToken(token: any, configuration: OpenIdConfiguration): string {\r\n    const clientId = this.getClientId(configuration);\r\n\r\n    if (!clientId) {\r\n      return null;\r\n    }\r\n\r\n    let params = this.createHttpParams();\r\n\r\n    params = params.set('client_id', clientId);\r\n    params = params.set('token', token);\r\n    params = params.set('token_type_hint', 'access_token');\r\n\r\n    return params.toString();\r\n  }\r\n\r\n  createRevocationEndpointBodyRefreshToken(token: any, configuration: OpenIdConfiguration): string {\r\n    const clientId = this.getClientId(configuration);\r\n\r\n    if (!clientId) {\r\n      return null;\r\n    }\r\n\r\n    let params = this.createHttpParams();\r\n\r\n    params = params.set('client_id', clientId);\r\n    params = params.set('token', token);\r\n    params = params.set('token_type_hint', 'refresh_token');\r\n\r\n    return params.toString();\r\n  }\r\n\r\n  getRevocationEndpointUrl(configuration: OpenIdConfiguration): string {\r\n    const authWellKnownEndPoints = this.storagePersistenceService.read('authWellKnownEndPoints', configuration);\r\n    const revocat