UNPKG

22.8 kBJavaScriptView Raw
1export class AuthConfig {
2 constructor(json) {
3 /**
4 * The client's id as registered with the auth server
5 */
6 this.clientId = '';
7 /**
8 * The client's redirectUri as registered with the auth server
9 */
10 this.redirectUri = '';
11 /**
12 * An optional second redirectUri where the auth server
13 * redirects the user to after logging out.
14 */
15 this.postLogoutRedirectUri = '';
16 /**
17 * Defines whether to use 'redirectUri' as a replacement
18 * of 'postLogoutRedirectUri' if the latter is not set.
19 */
20 this.redirectUriAsPostLogoutRedirectUriFallback = true;
21 /**
22 * The auth server's endpoint that allows to log
23 * the user in when using implicit flow.
24 */
25 this.loginUrl = '';
26 /**
27 * The requested scopes
28 */
29 this.scope = 'openid profile';
30 this.resource = '';
31 this.rngUrl = '';
32 /**
33 * Defines whether to use OpenId Connect during
34 * implicit flow.
35 */
36 this.oidc = true;
37 /**
38 * Defines whether to request an access token during
39 * implicit flow.
40 */
41 this.requestAccessToken = true;
42 this.options = null;
43 /**
44 * The issuer's uri.
45 */
46 this.issuer = '';
47 /**
48 * The logout url.
49 */
50 this.logoutUrl = '';
51 /**
52 * Defines whether to clear the hash fragment after logging in.
53 */
54 this.clearHashAfterLogin = true;
55 /**
56 * Url of the token endpoint as defined by OpenId Connect and OAuth 2.
57 */
58 this.tokenEndpoint = null;
59 /**
60 * Url of the revocation endpoint as defined by OpenId Connect and OAuth 2.
61 */
62 this.revocationEndpoint = null;
63 /**
64 * Names of known parameters sent out in the TokenResponse. https://tools.ietf.org/html/rfc6749#section-5.1
65 */
66 this.customTokenParameters = [];
67 /**
68 * Url of the userinfo endpoint as defined by OpenId Connect.
69 */
70 this.userinfoEndpoint = null;
71 this.responseType = '';
72 /**
73 * Defines whether additional debug information should
74 * be shown at the console. Note that in certain browsers
75 * the verbosity of the console needs to be explicitly set
76 * to include Debug level messages.
77 */
78 this.showDebugInformation = false;
79 /**
80 * The redirect uri used when doing silent refresh.
81 */
82 this.silentRefreshRedirectUri = '';
83 this.silentRefreshMessagePrefix = '';
84 /**
85 * Set this to true to display the iframe used for
86 * silent refresh for debugging.
87 */
88 this.silentRefreshShowIFrame = false;
89 /**
90 * Timeout for silent refresh.
91 * @internal
92 * @deprecated use silentRefreshTimeout
93 */
94 this.siletRefreshTimeout = 1000 * 20;
95 /**
96 * Timeout for silent refresh.
97 */
98 this.silentRefreshTimeout = 1000 * 20;
99 /**
100 * Some auth servers don't allow using password flow
101 * w/o a client secret while the standards do not
102 * demand for it. In this case, you can set a password
103 * here. As this password is exposed to the public
104 * it does not bring additional security and is therefore
105 * as good as using no password.
106 */
107 this.dummyClientSecret = '';
108 /**
109 * Defines whether https is required.
110 * The default value is remoteOnly which only allows
111 * http for localhost, while every other domains need
112 * to be used with https.
113 */
114 this.requireHttps = 'remoteOnly';
115 /**
116 * Defines whether every url provided by the discovery
117 * document has to start with the issuer's url.
118 */
119 this.strictDiscoveryDocumentValidation = true;
120 /**
121 * JSON Web Key Set (https://tools.ietf.org/html/rfc7517)
122 * with keys used to validate received id_tokens.
123 * This is taken out of the disovery document. Can be set manually too.
124 */
125 this.jwks = null;
126 /**
127 * Map with additional query parameter that are appended to
128 * the request when initializing implicit flow.
129 */
130 this.customQueryParams = null;
131 this.silentRefreshIFrameName = 'angular-oauth-oidc-silent-refresh-iframe';
132 /**
133 * Defines when the token_timeout event should be raised.
134 * If you set this to the default value 0.75, the event
135 * is triggered after 75% of the token's life time.
136 */
137 this.timeoutFactor = 0.75;
138 /**
139 * If true, the lib will try to check whether the user
140 * is still logged in on a regular basis as described
141 * in http://openid.net/specs/openid-connect-session-1_0.html#ChangeNotification
142 */
143 this.sessionChecksEnabled = false;
144 /**
145 * Interval in msec for checking the session
146 * according to http://openid.net/specs/openid-connect-session-1_0.html#ChangeNotification
147 */
148 this.sessionCheckIntervall = 3 * 1000;
149 /**
150 * Url for the iframe used for session checks
151 */
152 this.sessionCheckIFrameUrl = null;
153 /**
154 * Name of the iframe to use for session checks
155 */
156 this.sessionCheckIFrameName = 'angular-oauth-oidc-check-session-iframe';
157 /**
158 * This property has been introduced to disable at_hash checks
159 * and is indented for Identity Provider that does not deliver
160 * an at_hash EVEN THOUGH its recommended by the OIDC specs.
161 * Of course, when disabling these checks then we are bypassing
162 * a security check which means we are more vulnerable.
163 */
164 this.disableAtHashCheck = false;
165 /**
166 * Defines wether to check the subject of a refreshed token after silent refresh.
167 * Normally, it should be the same as before.
168 */
169 this.skipSubjectCheck = false;
170 this.useIdTokenHintForSilentRefresh = false;
171 /**
172 * Defined whether to skip the validation of the issuer in the discovery document.
173 * Normally, the discovey document's url starts with the url of the issuer.
174 */
175 this.skipIssuerCheck = false;
176 /**
177 * final state sent to issuer is built as follows:
178 * state = nonce + nonceStateSeparator + additional state
179 * Default separator is ';' (encoded %3B).
180 * In rare cases, this character might be forbidden or inconvenient to use by the issuer so it can be customized.
181 */
182 this.nonceStateSeparator = ';';
183 /**
184 * Set this to true to use HTTP BASIC auth for AJAX calls
185 */
186 this.useHttpBasicAuth = false;
187 /**
188 * Decreases the Expiration time of tokens by this number of seconds
189 */
190 this.decreaseExpirationBySec = 0;
191 /**
192 * The interceptors waits this time span if there is no token
193 */
194 this.waitForTokenInMsec = 0;
195 /**
196 * Code Flow is by defauld used together with PKCI which is also higly recommented.
197 * You can disbale it here by setting this flag to true.
198 * https://tools.ietf.org/html/rfc7636#section-1.1
199 */
200 this.disablePKCE = false;
201 /**
202 * Set this to true to preserve the requested route including query parameters after code flow login.
203 * This setting enables deep linking for the code flow.
204 */
205 this.preserveRequestedRoute = false;
206 /**
207 * Allows to disable the timer for the id_token used
208 * for token refresh
209 */
210 this.disableIdTokenTimer = false;
211 /**
212 * Blocks other origins requesting a silent refresh
213 */
214 this.checkOrigin = false;
215 /**
216 * This property allows you to override the method that is used to open the login url,
217 * allowing a way for implementations to specify their own method of routing to new
218 * urls.
219 */
220 this.openUri = (uri) => {
221 location.href = uri;
222 };
223 if (json) {
224 Object.assign(this, json);
225 }
226 }
227}
228//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth.config.js","sourceRoot":"","sources":["../../../projects/lib/src/auth.config.ts"],"names":[],"mappings":"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","sourcesContent":["export class AuthConfig {\n  /**\n   * The client's id as registered with the auth server\n   */\n  public clientId? = '';\n\n  /**\n   * The client's redirectUri as registered with the auth server\n   */\n  public redirectUri? = '';\n\n  /**\n   * An optional second redirectUri where the auth server\n   * redirects the user to after logging out.\n   */\n  public postLogoutRedirectUri? = '';\n\n  /**\n   * Defines whether to use 'redirectUri' as a replacement\n   * of 'postLogoutRedirectUri' if the latter is not set.\n   */\n  public redirectUriAsPostLogoutRedirectUriFallback? = true;\n\n  /**\n   * The auth server's endpoint that allows to log\n   * the user in when using implicit flow.\n   */\n  public loginUrl? = '';\n\n  /**\n   * The requested scopes\n   */\n  public scope? = 'openid profile';\n\n  public resource? = '';\n\n  public rngUrl? = '';\n\n  /**\n   * Defines whether to use OpenId Connect during\n   * implicit flow.\n   */\n  public oidc? = true;\n\n  /**\n   * Defines whether to request an access token during\n   * implicit flow.\n   */\n  public requestAccessToken? = true;\n\n  public options?: any = null;\n\n  /**\n   * The issuer's uri.\n   */\n  public issuer? = '';\n\n  /**\n   * The logout url.\n   */\n  public logoutUrl? = '';\n\n  /**\n   * Defines whether to clear the hash fragment after logging in.\n   */\n  public clearHashAfterLogin? = true;\n\n  /**\n   * Url of the token endpoint as defined by OpenId Connect and OAuth 2.\n   */\n  public tokenEndpoint?: string = null;\n\n  /**\n   * Url of the revocation endpoint as defined by OpenId Connect and OAuth 2.\n   */\n  public revocationEndpoint?: string = null;\n\n  /**\n   * Names of known parameters sent out in the TokenResponse. https://tools.ietf.org/html/rfc6749#section-5.1\n   */\n  public customTokenParameters?: string[] = [];\n\n  /**\n   * Url of the userinfo endpoint as defined by OpenId Connect.\n   */\n  public userinfoEndpoint?: string = null;\n\n  public responseType? = '';\n\n  /**\n   * Defines whether additional debug information should\n   * be shown at the console. Note that in certain browsers\n   * the verbosity of the console needs to be explicitly set\n   * to include Debug level messages.\n   */\n  public showDebugInformation? = false;\n\n  /**\n   * The redirect uri used when doing silent refresh.\n   */\n  public silentRefreshRedirectUri? = '';\n\n  public silentRefreshMessagePrefix? = '';\n\n  /**\n   * Set this to true to display the iframe used for\n   * silent refresh for debugging.\n   */\n  public silentRefreshShowIFrame? = false;\n\n  /**\n   * Timeout for silent refresh.\n   * @internal\n   * @deprecated use silentRefreshTimeout\n   */\n  public siletRefreshTimeout?: number = 1000 * 20;\n\n  /**\n   * Timeout for silent refresh.\n   */\n  public silentRefreshTimeout?: number = 1000 * 20;\n\n  /**\n   * Some auth servers don't allow using password flow\n   * w/o a client secret while the standards do not\n   * demand for it. In this case, you can set a password\n   * here. As this password is exposed to the public\n   * it does not bring additional security and is therefore\n   * as good as using no password.\n   */\n  public dummyClientSecret?: string = '';\n\n  /**\n   * Defines whether https is required.\n   * The default value is remoteOnly which only allows\n   * http for localhost, while every other domains need\n   * to be used with https.\n   */\n  public requireHttps?: boolean | 'remoteOnly' = 'remoteOnly';\n\n  /**\n   * Defines whether every url provided by the discovery\n   * document has to start with the issuer's url.\n   */\n  public strictDiscoveryDocumentValidation? = true;\n\n  /**\n   * JSON Web Key Set (https://tools.ietf.org/html/rfc7517)\n   * with keys used to validate received id_tokens.\n   * This is taken out of the disovery document. Can be set manually too.\n   */\n  public jwks?: object = null;\n\n  /**\n   * Map with additional query parameter that are appended to\n   * the request when initializing implicit flow.\n   */\n  public customQueryParams?: object = null;\n\n  public silentRefreshIFrameName? = 'angular-oauth-oidc-silent-refresh-iframe';\n\n  /**\n   * Defines when the token_timeout event should be raised.\n   * If you set this to the default value 0.75, the event\n   * is triggered after 75% of the token's life time.\n   */\n  public timeoutFactor? = 0.75;\n\n  /**\n   * If true, the lib will try to check whether the user\n   * is still logged in on a regular basis as described\n   * in http://openid.net/specs/openid-connect-session-1_0.html#ChangeNotification\n   */\n  public sessionChecksEnabled? = false;\n\n  /**\n   * Interval in msec for checking the session\n   * according to http://openid.net/specs/openid-connect-session-1_0.html#ChangeNotification\n   */\n  public sessionCheckIntervall? = 3 * 1000;\n\n  /**\n   * Url for the iframe used for session checks\n   */\n  public sessionCheckIFrameUrl?: string = null;\n\n  /**\n   * Name of the iframe to use for session checks\n   */\n  public sessionCheckIFrameName? = 'angular-oauth-oidc-check-session-iframe';\n\n  /**\n   * This property has been introduced to disable at_hash checks\n   * and is indented for Identity Provider that does not deliver\n   * an at_hash EVEN THOUGH its recommended by the OIDC specs.\n   * Of course, when disabling these checks then we are bypassing\n   * a security check which means we are more vulnerable.\n   */\n  public disableAtHashCheck? = false;\n\n  /**\n   * Defines wether to check the subject of a refreshed token after silent refresh.\n   * Normally, it should be the same as before.\n   */\n  public skipSubjectCheck? = false;\n\n  public useIdTokenHintForSilentRefresh? = false;\n\n  /**\n   * Defined whether to skip the validation of the issuer in the discovery document.\n   * Normally, the discovey document's url starts with the url of the issuer.\n   */\n  public skipIssuerCheck? = false;\n\n  /**\n   * According to rfc6749 it is recommended (but not required) that the auth\n   * server exposes the access_token's life time in seconds.\n   * This is a fallback value for the case this value is not exposed.\n   */\n  public fallbackAccessTokenExpirationTimeInSec?: number;\n\n  /**\n   * final state sent to issuer is built as follows:\n   * state = nonce + nonceStateSeparator + additional state\n   * Default separator is ';' (encoded %3B).\n   * In rare cases, this character might be forbidden or inconvenient to use by the issuer so it can be customized.\n   */\n  public nonceStateSeparator? = ';';\n\n  /**\n   * Set this to true to use HTTP BASIC auth for AJAX calls\n   */\n  public useHttpBasicAuth? = false;\n\n  /**\n   * The window of time (in seconds) to allow the current time to deviate when validating id_token's iat and exp values.\n   */\n  public clockSkewInSec?: number;\n\n  /**\n   * Decreases the Expiration time of tokens by this number of seconds\n   */\n  public decreaseExpirationBySec? = 0;\n\n  /**\n   * The interceptors waits this time span if there is no token\n   */\n  public waitForTokenInMsec? = 0;\n\n  /**\n   * Set this to true if you want to use silent refresh together with\n   * code flow. As silent refresh is the only option for refreshing\n   * with implicit flow, you don't need to explicitly turn it on in\n   * this case.\n   */\n  public useSilentRefresh?;\n\n  /**\n   * Code Flow is by defauld used together with PKCI which is also higly recommented.\n   * You can disbale it here by setting this flag to true.\n   * https://tools.ietf.org/html/rfc7636#section-1.1\n   */\n  public disablePKCE? = false;\n\n  /**\n   * Set this to true to preserve the requested route including query parameters after code flow login.\n   * This setting enables deep linking for the code flow.\n   */\n  public preserveRequestedRoute? = false;\n\n  /**\n   * Allows to disable the timer for the id_token used\n   * for token refresh\n   */\n  public disableIdTokenTimer? = false;\n\n  /**\n   * Blocks other origins requesting a silent refresh\n   */\n  public checkOrigin? = false;\n\n  constructor(json?: Partial<AuthConfig>) {\n    if (json) {\n      Object.assign(this, json);\n    }\n  }\n\n  /**\n   * This property allows you to override the method that is used to open the login url,\n   * allowing a way for implementations to specify their own method of routing to new\n   * urls.\n   */\n  public openUri?: (uri: string) => void = (uri) => {\n    location.href = uri;\n  };\n}\n"]}
\No newline at end of file