@recursyve/nice-auth0-kit 17.0.0-beta.20 → 20.0.0-beta.21
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/fesm2022/recursyve-nice-auth0-kit.mjs +109 -86
- package/fesm2022/recursyve-nice-auth0-kit.mjs.map +1 -1
- package/index.d.ts +170 -5
- package/package.json +3 -5
- package/esm2022/lib/api/auth0.api.mjs +0 -13
- package/esm2022/lib/api/authorization/authorization.api.mjs +0 -40
- package/esm2022/lib/api/authorization/models/authorization-flow-request.model.mjs +0 -2
- package/esm2022/lib/api/exceptions/base.exception.mjs +0 -6
- package/esm2022/lib/api/index.mjs +0 -3
- package/esm2022/lib/api/interceptors/auth.interceptor.mjs +0 -37
- package/esm2022/lib/api/mfa/exceptions/association-required.exception.mjs +0 -4
- package/esm2022/lib/api/mfa/exceptions/mfa.exception.mjs +0 -5
- package/esm2022/lib/api/mfa/mfa.api.mjs +0 -59
- package/esm2022/lib/api/mfa/model/mfa-request.model.mjs +0 -2
- package/esm2022/lib/api/mfa/model/mfa-response.model.mjs +0 -2
- package/esm2022/lib/api/nice-auth0.service.mjs +0 -24
- package/esm2022/lib/api/token/exceptions/mfa-required.exception.mjs +0 -7
- package/esm2022/lib/api/token/exceptions/token.exception.mjs +0 -5
- package/esm2022/lib/api/token/models/token-response.model.mjs +0 -2
- package/esm2022/lib/api/token/token.api.mjs +0 -93
- package/esm2022/lib/nice-auht0-kit.module.mjs +0 -52
- package/esm2022/lib/nice-auth0-kit.constant.mjs +0 -3
- package/esm2022/lib/nice-auth0-kit.options.mjs +0 -2
- package/esm2022/lib/providers/authentication.service.mjs +0 -226
- package/esm2022/lib/providers/exceptions/no-authenticator.exception.mjs +0 -3
- package/esm2022/lib/providers/index.mjs +0 -3
- package/esm2022/public-api.mjs +0 -8
- package/esm2022/recursyve-nice-auth0-kit.mjs +0 -5
- package/lib/api/auth0.api.d.ts +0 -6
- package/lib/api/authorization/authorization.api.d.ts +0 -12
- package/lib/api/authorization/models/authorization-flow-request.model.d.ts +0 -4
- package/lib/api/exceptions/base.exception.d.ts +0 -5
- package/lib/api/index.d.ts +0 -2
- package/lib/api/interceptors/auth.interceptor.d.ts +0 -13
- package/lib/api/mfa/exceptions/association-required.exception.d.ts +0 -3
- package/lib/api/mfa/exceptions/mfa.exception.d.ts +0 -3
- package/lib/api/mfa/mfa.api.d.ts +0 -16
- package/lib/api/mfa/model/mfa-request.model.d.ts +0 -10
- package/lib/api/mfa/model/mfa-response.model.d.ts +0 -6
- package/lib/api/nice-auth0.service.d.ts +0 -12
- package/lib/api/token/exceptions/mfa-required.exception.d.ts +0 -5
- package/lib/api/token/exceptions/token.exception.d.ts +0 -3
- package/lib/api/token/models/token-response.model.d.ts +0 -7
- package/lib/api/token/token.api.d.ts +0 -18
- package/lib/nice-auht0-kit.module.d.ts +0 -10
- package/lib/nice-auth0-kit.constant.d.ts +0 -2
- package/lib/nice-auth0-kit.options.d.ts +0 -11
- package/lib/providers/authentication.service.d.ts +0 -64
- package/lib/providers/exceptions/no-authenticator.exception.d.ts +0 -2
- package/lib/providers/index.d.ts +0 -2
- package/public-api.d.ts +0 -4
|
@@ -1,52 +0,0 @@
|
|
|
1
|
-
import { HTTP_INTERCEPTORS, HttpClientModule } from "@angular/common/http";
|
|
2
|
-
import { NgModule } from "@angular/core";
|
|
3
|
-
import { NiceAuthInterceptor } from "./api/interceptors/auth.interceptor";
|
|
4
|
-
import { Auth0MfaApi } from "./api/mfa/mfa.api";
|
|
5
|
-
import { NiceAuth0Service } from "./api/nice-auth0.service";
|
|
6
|
-
import { Auth0TokenApi } from "./api/token/token.api";
|
|
7
|
-
import { NICE_AUTH0_OPTIONS } from "./nice-auth0-kit.constant";
|
|
8
|
-
import { NiceAuthenticationService } from "./providers/authentication.service";
|
|
9
|
-
import { Auth0AuthorizationApi } from "./api/authorization/authorization.api";
|
|
10
|
-
import * as i0 from "@angular/core";
|
|
11
|
-
export class NiceAuth0Module {
|
|
12
|
-
static forRoot(options) {
|
|
13
|
-
return {
|
|
14
|
-
ngModule: NiceAuth0Module,
|
|
15
|
-
providers: [
|
|
16
|
-
{
|
|
17
|
-
provide: NICE_AUTH0_OPTIONS,
|
|
18
|
-
useValue: options
|
|
19
|
-
}
|
|
20
|
-
]
|
|
21
|
-
};
|
|
22
|
-
}
|
|
23
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: NiceAuth0Module, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
24
|
-
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.10", ngImport: i0, type: NiceAuth0Module, imports: [HttpClientModule] }); }
|
|
25
|
-
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: NiceAuth0Module, providers: [
|
|
26
|
-
Auth0MfaApi,
|
|
27
|
-
Auth0TokenApi,
|
|
28
|
-
Auth0AuthorizationApi,
|
|
29
|
-
NiceAuth0Service,
|
|
30
|
-
NiceAuthenticationService,
|
|
31
|
-
{ provide: HTTP_INTERCEPTORS, useClass: NiceAuthInterceptor, multi: true }
|
|
32
|
-
], imports: [HttpClientModule] }); }
|
|
33
|
-
}
|
|
34
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: NiceAuth0Module, decorators: [{
|
|
35
|
-
type: NgModule,
|
|
36
|
-
args: [{
|
|
37
|
-
imports: [
|
|
38
|
-
HttpClientModule
|
|
39
|
-
],
|
|
40
|
-
declarations: [],
|
|
41
|
-
providers: [
|
|
42
|
-
Auth0MfaApi,
|
|
43
|
-
Auth0TokenApi,
|
|
44
|
-
Auth0AuthorizationApi,
|
|
45
|
-
NiceAuth0Service,
|
|
46
|
-
NiceAuthenticationService,
|
|
47
|
-
{ provide: HTTP_INTERCEPTORS, useClass: NiceAuthInterceptor, multi: true }
|
|
48
|
-
],
|
|
49
|
-
exports: []
|
|
50
|
-
}]
|
|
51
|
-
}] });
|
|
52
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmljZS1hdWh0MC1raXQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvbmljZS1hdXRoMC1raXQvc3JjL2xpYi9uaWNlLWF1aHQwLWtpdC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGlCQUFpQixFQUFFLGdCQUFnQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDM0UsT0FBTyxFQUF1QixRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDOUQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0scUNBQXFDLENBQUM7QUFDMUUsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ2hELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzVELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUN0RCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUUvRCxPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUMvRSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQzs7QUFpQjlFLE1BQU0sT0FBTyxlQUFlO0lBQ2pCLE1BQU0sQ0FBQyxPQUFPLENBQUMsT0FBeUI7UUFDM0MsT0FBTztZQUNILFFBQVEsRUFBRSxlQUFlO1lBQ3pCLFNBQVMsRUFBRTtnQkFDUDtvQkFDSSxPQUFPLEVBQUUsa0JBQWtCO29CQUMzQixRQUFRLEVBQUUsT0FBTztpQkFDcEI7YUFDSjtTQUNKLENBQUM7SUFDTixDQUFDOytHQVhRLGVBQWU7Z0hBQWYsZUFBZSxZQWJwQixnQkFBZ0I7Z0hBYVgsZUFBZSxhQVZiO1lBQ1AsV0FBVztZQUNYLGFBQWE7WUFDYixxQkFBcUI7WUFDckIsZ0JBQWdCO1lBQ2hCLHlCQUF5QjtZQUN6QixFQUFFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxRQUFRLEVBQUUsbUJBQW1CLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRTtTQUM3RSxZQVZHLGdCQUFnQjs7NEZBYVgsZUFBZTtrQkFmM0IsUUFBUTttQkFBQztvQkFDTixPQUFPLEVBQUU7d0JBQ0wsZ0JBQWdCO3FCQUNuQjtvQkFDRCxZQUFZLEVBQUUsRUFBRTtvQkFDaEIsU0FBUyxFQUFFO3dCQUNQLFdBQVc7d0JBQ1gsYUFBYTt3QkFDYixxQkFBcUI7d0JBQ3JCLGdCQUFnQjt3QkFDaEIseUJBQXlCO3dCQUN6QixFQUFFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxRQUFRLEVBQUUsbUJBQW1CLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRTtxQkFDN0U7b0JBQ0QsT0FBTyxFQUFFLEVBQUU7aUJBQ2QiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBIVFRQX0lOVEVSQ0VQVE9SUywgSHR0cENsaWVudE1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb21tb24vaHR0cFwiO1xuaW1wb3J0IHsgTW9kdWxlV2l0aFByb3ZpZGVycywgTmdNb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgTmljZUF1dGhJbnRlcmNlcHRvciB9IGZyb20gXCIuL2FwaS9pbnRlcmNlcHRvcnMvYXV0aC5pbnRlcmNlcHRvclwiO1xuaW1wb3J0IHsgQXV0aDBNZmFBcGkgfSBmcm9tIFwiLi9hcGkvbWZhL21mYS5hcGlcIjtcbmltcG9ydCB7IE5pY2VBdXRoMFNlcnZpY2UgfSBmcm9tIFwiLi9hcGkvbmljZS1hdXRoMC5zZXJ2aWNlXCI7XG5pbXBvcnQgeyBBdXRoMFRva2VuQXBpIH0gZnJvbSBcIi4vYXBpL3Rva2VuL3Rva2VuLmFwaVwiO1xuaW1wb3J0IHsgTklDRV9BVVRIMF9PUFRJT05TIH0gZnJvbSBcIi4vbmljZS1hdXRoMC1raXQuY29uc3RhbnRcIjtcbmltcG9ydCB7IE5pY2VBdXRoME9wdGlvbnMgfSBmcm9tIFwiLi9uaWNlLWF1dGgwLWtpdC5vcHRpb25zXCI7XG5pbXBvcnQgeyBOaWNlQXV0aGVudGljYXRpb25TZXJ2aWNlIH0gZnJvbSBcIi4vcHJvdmlkZXJzL2F1dGhlbnRpY2F0aW9uLnNlcnZpY2VcIjtcbmltcG9ydCB7IEF1dGgwQXV0aG9yaXphdGlvbkFwaSB9IGZyb20gXCIuL2FwaS9hdXRob3JpemF0aW9uL2F1dGhvcml6YXRpb24uYXBpXCI7XG5cbkBOZ01vZHVsZSh7XG4gICAgaW1wb3J0czogW1xuICAgICAgICBIdHRwQ2xpZW50TW9kdWxlXG4gICAgXSxcbiAgICBkZWNsYXJhdGlvbnM6IFtdLFxuICAgIHByb3ZpZGVyczogW1xuICAgICAgICBBdXRoME1mYUFwaSxcbiAgICAgICAgQXV0aDBUb2tlbkFwaSxcbiAgICAgICAgQXV0aDBBdXRob3JpemF0aW9uQXBpLFxuICAgICAgICBOaWNlQXV0aDBTZXJ2aWNlLFxuICAgICAgICBOaWNlQXV0aGVudGljYXRpb25TZXJ2aWNlLFxuICAgICAgICB7IHByb3ZpZGU6IEhUVFBfSU5URVJDRVBUT1JTLCB1c2VDbGFzczogTmljZUF1dGhJbnRlcmNlcHRvciwgbXVsdGk6IHRydWUgfVxuICAgIF0sXG4gICAgZXhwb3J0czogW11cbn0pXG5leHBvcnQgY2xhc3MgTmljZUF1dGgwTW9kdWxlIHtcbiAgICBwdWJsaWMgc3RhdGljIGZvclJvb3Qob3B0aW9uczogTmljZUF1dGgwT3B0aW9ucyk6IE1vZHVsZVdpdGhQcm92aWRlcnM8TmljZUF1dGgwTW9kdWxlPiB7XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICBuZ01vZHVsZTogTmljZUF1dGgwTW9kdWxlLFxuICAgICAgICAgICAgcHJvdmlkZXJzOiBbXG4gICAgICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgICAgICBwcm92aWRlOiBOSUNFX0FVVEgwX09QVElPTlMsXG4gICAgICAgICAgICAgICAgICAgIHVzZVZhbHVlOiBvcHRpb25zXG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgXVxuICAgICAgICB9O1xuICAgIH1cbn1cbiJdfQ==
|
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
import { InjectionToken } from "@angular/core";
|
|
2
|
-
export const NICE_AUTH0_OPTIONS = new InjectionToken("nice_auth0_options");
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmljZS1hdXRoMC1raXQuY29uc3RhbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9uaWNlLWF1dGgwLWtpdC9zcmMvbGliL25pY2UtYXV0aDAta2l0LmNvbnN0YW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFL0MsTUFBTSxDQUFDLE1BQU0sa0JBQWtCLEdBQUcsSUFBSSxjQUFjLENBQUMsb0JBQW9CLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGlvblRva2VuIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcblxuZXhwb3J0IGNvbnN0IE5JQ0VfQVVUSDBfT1BUSU9OUyA9IG5ldyBJbmplY3Rpb25Ub2tlbihcIm5pY2VfYXV0aDBfb3B0aW9uc1wiKTtcbiJdfQ==
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmljZS1hdXRoMC1raXQub3B0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL25pY2UtYXV0aDAta2l0L3NyYy9saWIvbmljZS1hdXRoMC1raXQub3B0aW9ucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBOaWNlQXV0aDBPcHRpb25zIHtcbiAgICBkb21haW46IHN0cmluZztcbiAgICBjbGllbnRJZDogc3RyaW5nO1xuICAgIGNsaWVudFNlY3JldDogc3RyaW5nO1xuICAgIGF1ZGllbmNlOiBzdHJpbmc7XG4gICAgc2NvcGVzOiBzdHJpbmdbXTtcblxuICAgIC8qKlxuICAgICAqIFRva2VuIHRvIHNlbmQgaW4gdGhlIEF1dGhvcml6YXRpb24gSGVhZGVyXG4gICAgICovXG4gICAgYXV0aFRva2VuPzogXCJhY2Nlc3NUb2tlblwiIHwgXCJpZFRva2VuXCI7XG59XG4iXX0=
|
|
@@ -1,226 +0,0 @@
|
|
|
1
|
-
import { Inject, Injectable } from "@angular/core";
|
|
2
|
-
import { jwtDecode } from "jwt-decode";
|
|
3
|
-
import { BehaviorSubject, of, throwError } from "rxjs";
|
|
4
|
-
import { catchError, map, tap } from "rxjs/operators";
|
|
5
|
-
import { Auth0AssociationRequiredException } from "../api/mfa/exceptions/association-required.exception";
|
|
6
|
-
import { NiceAuth0Service } from "../api";
|
|
7
|
-
import { Auth0MfaRequiredException } from "../api/token/exceptions/mfa-required.exception";
|
|
8
|
-
import { NICE_AUTH0_OPTIONS } from "../nice-auth0-kit.constant";
|
|
9
|
-
import { NoAuthenticatorException } from "./exceptions/no-authenticator.exception";
|
|
10
|
-
import * as i0 from "@angular/core";
|
|
11
|
-
import * as i1 from "../api";
|
|
12
|
-
export var AuthorizationStateValidationResult;
|
|
13
|
-
(function (AuthorizationStateValidationResult) {
|
|
14
|
-
AuthorizationStateValidationResult["Omitted"] = "omitted";
|
|
15
|
-
AuthorizationStateValidationResult["Success"] = "success";
|
|
16
|
-
AuthorizationStateValidationResult["Failure"] = "failure";
|
|
17
|
-
})(AuthorizationStateValidationResult || (AuthorizationStateValidationResult = {}));
|
|
18
|
-
export class NiceAuthenticationService {
|
|
19
|
-
constructor(options, auth0Service) {
|
|
20
|
-
this.options = options;
|
|
21
|
-
this.auth0Service = auth0Service;
|
|
22
|
-
this.currentUser$ = new BehaviorSubject(this.currentUser);
|
|
23
|
-
}
|
|
24
|
-
get idToken() {
|
|
25
|
-
return localStorage.getItem("auth0_id_token");
|
|
26
|
-
}
|
|
27
|
-
set idToken(accessToken) {
|
|
28
|
-
localStorage.setItem("auth0_id_token", accessToken);
|
|
29
|
-
this.currentUser$.next(this.currentUser);
|
|
30
|
-
}
|
|
31
|
-
get accessToken() {
|
|
32
|
-
return localStorage.getItem("auth0_access_token");
|
|
33
|
-
}
|
|
34
|
-
set accessToken(accessToken) {
|
|
35
|
-
localStorage.setItem("auth0_access_token", accessToken);
|
|
36
|
-
}
|
|
37
|
-
get refreshToken() {
|
|
38
|
-
return localStorage.getItem("auth0_refresh_token");
|
|
39
|
-
}
|
|
40
|
-
set refreshToken(refreshToken) {
|
|
41
|
-
localStorage.setItem("auth0_refresh_token", refreshToken);
|
|
42
|
-
}
|
|
43
|
-
get authToken() {
|
|
44
|
-
if (this.options.authToken === "idToken") {
|
|
45
|
-
return this.idToken;
|
|
46
|
-
}
|
|
47
|
-
return this.accessToken;
|
|
48
|
-
}
|
|
49
|
-
get idTokenPayload() {
|
|
50
|
-
try {
|
|
51
|
-
return jwtDecode(this.idToken);
|
|
52
|
-
}
|
|
53
|
-
catch (e) {
|
|
54
|
-
console.log("Failed to decode payload: " + e);
|
|
55
|
-
return {};
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
get accessTokenPayload() {
|
|
59
|
-
try {
|
|
60
|
-
const decodedPayload = atob(this.accessToken.split(".")[1]);
|
|
61
|
-
return JSON.parse(decodedPayload);
|
|
62
|
-
}
|
|
63
|
-
catch (e) {
|
|
64
|
-
console.log("Failed to decode payload: " + e);
|
|
65
|
-
return {};
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
get authTokenPayload() {
|
|
69
|
-
if (this.options.authToken === "idToken") {
|
|
70
|
-
return this.idTokenPayload;
|
|
71
|
-
}
|
|
72
|
-
return this.accessTokenPayload;
|
|
73
|
-
}
|
|
74
|
-
get currentUser() {
|
|
75
|
-
return this.idTokenPayload;
|
|
76
|
-
}
|
|
77
|
-
checkLoggedIn() {
|
|
78
|
-
if (this.validateToken()) {
|
|
79
|
-
return of(true);
|
|
80
|
-
}
|
|
81
|
-
return this.getAuthorizationToken().pipe(map((token) => token != null), catchError(() => of(false)));
|
|
82
|
-
}
|
|
83
|
-
getAuthorizationToken() {
|
|
84
|
-
if (!this.authToken) {
|
|
85
|
-
return of(null);
|
|
86
|
-
}
|
|
87
|
-
if (this.validateToken()) {
|
|
88
|
-
return of(this.authToken);
|
|
89
|
-
}
|
|
90
|
-
if (this.refreshToken) {
|
|
91
|
-
return this.generateNewToken();
|
|
92
|
-
}
|
|
93
|
-
return of(null);
|
|
94
|
-
}
|
|
95
|
-
validateToken() {
|
|
96
|
-
if (!this.authToken) {
|
|
97
|
-
return false;
|
|
98
|
-
}
|
|
99
|
-
const exp = this.authTokenPayload.exp;
|
|
100
|
-
const now = new Date().getTime() / 1000;
|
|
101
|
-
return now < exp;
|
|
102
|
-
}
|
|
103
|
-
passwordGrant(username, password) {
|
|
104
|
-
return this.auth0Service.token.authWithPassword(username, password).pipe(map(value => {
|
|
105
|
-
this.refreshToken = value.refresh_token;
|
|
106
|
-
this.idToken = value.id_token;
|
|
107
|
-
this.accessToken = value.access_token;
|
|
108
|
-
return {
|
|
109
|
-
success: true,
|
|
110
|
-
mfaRequired: false
|
|
111
|
-
};
|
|
112
|
-
}), catchError((e) => this.catchGrantError(e)));
|
|
113
|
-
}
|
|
114
|
-
authorizationCodeGrant(code, redirectUrl) {
|
|
115
|
-
return this.auth0Service.token.authWithAuthorizationCode(code, redirectUrl).pipe(map(value => {
|
|
116
|
-
this.refreshToken = value.refresh_token;
|
|
117
|
-
this.idToken = value.id_token;
|
|
118
|
-
this.accessToken = value.access_token;
|
|
119
|
-
return {
|
|
120
|
-
success: true,
|
|
121
|
-
mfaRequired: false
|
|
122
|
-
};
|
|
123
|
-
}), catchError((e) => this.catchGrantError(e)));
|
|
124
|
-
}
|
|
125
|
-
getAuthFlowRequestUri(redirectUrl, options) {
|
|
126
|
-
return this.auth0Service.authorization.buildAuthFlowRequest(redirectUrl, options?.connection ?? undefined).pipe(map(request => {
|
|
127
|
-
if (options?.useStateValidation) {
|
|
128
|
-
localStorage.setItem("auth0_auth_flow_state", request.state);
|
|
129
|
-
}
|
|
130
|
-
return request.uri;
|
|
131
|
-
}));
|
|
132
|
-
}
|
|
133
|
-
checkAuthFlowResponse(expectedResponsePath) {
|
|
134
|
-
if (typeof expectedResponsePath === "string") {
|
|
135
|
-
expectedResponsePath = [expectedResponsePath];
|
|
136
|
-
}
|
|
137
|
-
const path = expectedResponsePath?.find(x => window.location.pathname === x);
|
|
138
|
-
if (!expectedResponsePath || path) {
|
|
139
|
-
const params = new URLSearchParams(window.location.search);
|
|
140
|
-
if (!params.has("code")) {
|
|
141
|
-
return of(null);
|
|
142
|
-
}
|
|
143
|
-
const response = {
|
|
144
|
-
path,
|
|
145
|
-
code: params.get("code"),
|
|
146
|
-
stateValidationResult: AuthorizationStateValidationResult.Omitted
|
|
147
|
-
};
|
|
148
|
-
const savedAuthorizationState = localStorage.getItem("auth0_auth_flow_state");
|
|
149
|
-
if (savedAuthorizationState) {
|
|
150
|
-
if (!params.has("state") || savedAuthorizationState !== params.get("state")) {
|
|
151
|
-
response.stateValidationResult = AuthorizationStateValidationResult.Failure;
|
|
152
|
-
}
|
|
153
|
-
else {
|
|
154
|
-
response.stateValidationResult = AuthorizationStateValidationResult.Success;
|
|
155
|
-
}
|
|
156
|
-
}
|
|
157
|
-
return of(response);
|
|
158
|
-
}
|
|
159
|
-
return of(null);
|
|
160
|
-
}
|
|
161
|
-
validateOobCode(code) {
|
|
162
|
-
return this.auth0Service.token.authWithOobCode(this.lastMfaChallengeToken, this.lastMfaOobCode, code).pipe(map(value => {
|
|
163
|
-
this.refreshToken = value.refresh_token;
|
|
164
|
-
this.idToken = value.id_token;
|
|
165
|
-
this.accessToken = value.access_token;
|
|
166
|
-
}));
|
|
167
|
-
}
|
|
168
|
-
logout() {
|
|
169
|
-
const refreshToken = localStorage.getItem("auth0_refresh_token");
|
|
170
|
-
localStorage.removeItem("auth0_id_token");
|
|
171
|
-
localStorage.removeItem("auth0_access_token");
|
|
172
|
-
localStorage.removeItem("auth0_refresh_token");
|
|
173
|
-
return this.auth0Service.token.revokeRefreshToken(refreshToken);
|
|
174
|
-
}
|
|
175
|
-
generateNewToken() {
|
|
176
|
-
return this.auth0Service.token.refreshToken(this.refreshToken).pipe(tap(value => {
|
|
177
|
-
this.refreshToken = value.refresh_token;
|
|
178
|
-
this.idToken = value.id_token;
|
|
179
|
-
this.accessToken = value.access_token;
|
|
180
|
-
}), map(value => value.access_token), catchError(e => {
|
|
181
|
-
return of(null);
|
|
182
|
-
}));
|
|
183
|
-
}
|
|
184
|
-
addMfaAuthenticator(authenticator) {
|
|
185
|
-
return this.auth0Service.mfa.associateOobAuthenticator({
|
|
186
|
-
mfaToken: this.lastMfaChallengeToken,
|
|
187
|
-
channels: [authenticator.type],
|
|
188
|
-
email: authenticator.email,
|
|
189
|
-
phoneNumber: authenticator.phoneNumber
|
|
190
|
-
}).pipe(map(value => {
|
|
191
|
-
this.lastMfaOobCode = value.oob_code;
|
|
192
|
-
}));
|
|
193
|
-
}
|
|
194
|
-
triggerMfaChallenge() {
|
|
195
|
-
return this.auth0Service.mfa.challenge({
|
|
196
|
-
type: "oob",
|
|
197
|
-
mfaToken: this.lastMfaChallengeToken
|
|
198
|
-
}).pipe(map(value => {
|
|
199
|
-
this.lastMfaOobCode = value.oob_code;
|
|
200
|
-
}));
|
|
201
|
-
}
|
|
202
|
-
catchGrantError(e) {
|
|
203
|
-
if (e instanceof Auth0MfaRequiredException) {
|
|
204
|
-
this.lastMfaChallengeToken = e.mfaToken;
|
|
205
|
-
return this.triggerMfaChallenge().pipe(map(() => ({
|
|
206
|
-
success: true,
|
|
207
|
-
mfaRequired: true
|
|
208
|
-
})), catchError((err) => {
|
|
209
|
-
if (err instanceof Auth0AssociationRequiredException) {
|
|
210
|
-
return throwError(() => new NoAuthenticatorException());
|
|
211
|
-
}
|
|
212
|
-
return throwError(() => err);
|
|
213
|
-
}));
|
|
214
|
-
}
|
|
215
|
-
return throwError(() => e);
|
|
216
|
-
}
|
|
217
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: NiceAuthenticationService, deps: [{ token: NICE_AUTH0_OPTIONS }, { token: i1.NiceAuth0Service }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
218
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: NiceAuthenticationService }); }
|
|
219
|
-
}
|
|
220
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: NiceAuthenticationService, decorators: [{
|
|
221
|
-
type: Injectable
|
|
222
|
-
}], ctorParameters: () => [{ type: undefined, decorators: [{
|
|
223
|
-
type: Inject,
|
|
224
|
-
args: [NICE_AUTH0_OPTIONS]
|
|
225
|
-
}] }, { type: i1.NiceAuth0Service }] });
|
|
226
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"authentication.service.js","sourceRoot":"","sources":["../../../../../projects/nice-auth0-kit/src/lib/providers/authentication.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable } from \"@angular/core\";\nimport { jwtDecode } from \"jwt-decode\";\nimport { BehaviorSubject, Observable, of, throwError } from \"rxjs\";\nimport { catchError, map, tap } from \"rxjs/operators\";\nimport { Auth0AssociationRequiredException } from \"../api/mfa/exceptions/association-required.exception\";\nimport { NiceAuth0Service } from \"../api\";\nimport { Auth0MfaRequiredException } from \"../api/token/exceptions/mfa-required.exception\";\nimport { NICE_AUTH0_OPTIONS } from \"../nice-auth0-kit.constant\";\nimport { NiceAuth0Options } from \"../nice-auth0-kit.options\";\nimport { NoAuthenticatorException } from \"./exceptions/no-authenticator.exception\";\n\nexport interface LoginResponse {\n    success: boolean;\n    mfaRequired: boolean;\n}\n\nexport interface SmsAuthenticator {\n    type: \"sms\";\n    phoneNumber: string;\n}\n\nexport interface EmailAuthenticator {\n    type: \"email\";\n    email: string;\n}\n\nexport interface AuthorizationFlowOptions {\n    connection?: string;\n    useStateValidation?: boolean;\n}\n\nexport enum AuthorizationStateValidationResult {\n    Omitted = \"omitted\",\n    Success = \"success\",\n    Failure = \"failure\"\n}\n\nexport interface AuthorizationFlowResponse {\n    path?: string;\n    code: string;\n    stateValidationResult: AuthorizationStateValidationResult;\n}\n\n@Injectable()\nexport class NiceAuthenticationService {\n    private lastMfaChallengeToken: string;\n    private lastMfaOobCode: string;\n\n    public currentUser$ = new BehaviorSubject(this.currentUser);\n\n    constructor(\n        @Inject(NICE_AUTH0_OPTIONS) private options: NiceAuth0Options,\n        private auth0Service: NiceAuth0Service\n    ) {}\n\n    public get idToken(): string {\n        return localStorage.getItem(\"auth0_id_token\");\n    }\n\n    public set idToken(accessToken: string) {\n        localStorage.setItem(\"auth0_id_token\", accessToken);\n        this.currentUser$.next(this.currentUser);\n    }\n\n    public get accessToken(): string {\n        return localStorage.getItem(\"auth0_access_token\");\n    }\n\n    public set accessToken(accessToken: string) {\n        localStorage.setItem(\"auth0_access_token\", accessToken);\n    }\n\n    public get refreshToken(): string {\n        return localStorage.getItem(\"auth0_refresh_token\");\n    }\n\n    public set refreshToken(refreshToken: string) {\n        localStorage.setItem(\"auth0_refresh_token\", refreshToken);\n    }\n\n    public get authToken(): string {\n        if (this.options.authToken === \"idToken\") {\n            return this.idToken;\n        }\n        return this.accessToken;\n    }\n\n    public get idTokenPayload(): any {\n        try {\n            return jwtDecode(this.idToken);\n        } catch (e) {\n            console.log(\"Failed to decode payload: \" + e);\n            return {};\n        }\n    }\n\n    public get accessTokenPayload(): any {\n        try {\n            const decodedPayload = atob(this.accessToken.split(\".\")[1]);\n            return JSON.parse(decodedPayload);\n        } catch (e) {\n            console.log(\"Failed to decode payload: \" + e);\n            return {};\n        }\n    }\n\n    public get authTokenPayload(): any {\n        if (this.options.authToken === \"idToken\") {\n            return this.idTokenPayload;\n        }\n        return this.accessTokenPayload;\n    }\n\n    public get currentUser(): any {\n        return this.idTokenPayload;\n    }\n\n    public checkLoggedIn(): Observable<boolean> {\n        if (this.validateToken()) {\n            return of(true);\n        }\n\n        return this.getAuthorizationToken().pipe(\n            map((token: string) => token != null),\n            catchError(() => of(false))\n        );\n    }\n\n    public getAuthorizationToken(): Observable<string> {\n        if (!this.authToken) {\n            return of(null);\n        }\n\n        if (this.validateToken()) {\n            return of(this.authToken);\n        }\n\n        if (this.refreshToken) {\n            return this.generateNewToken();\n        }\n\n        return of(null);\n    }\n\n    public validateToken(): boolean {\n        if (!this.authToken) {\n            return false;\n        }\n\n        const exp = this.authTokenPayload.exp;\n        const now = new Date().getTime() / 1000;\n        return now < exp;\n    }\n\n    public passwordGrant(username: string, password: string): Observable<LoginResponse> {\n        return this.auth0Service.token.authWithPassword(username, password).pipe(\n            map(value => {\n                this.refreshToken = value.refresh_token;\n                this.idToken = value.id_token;\n                this.accessToken = value.access_token;\n                return {\n                    success: true,\n                    mfaRequired: false\n                };\n            }),\n            catchError((e) => this.catchGrantError(e))\n        );\n    }\n\n    public authorizationCodeGrant(code: string, redirectUrl: string): Observable<LoginResponse> {\n        return this.auth0Service.token.authWithAuthorizationCode(code, redirectUrl).pipe(\n            map(value => {\n                this.refreshToken = value.refresh_token;\n                this.idToken = value.id_token;\n                this.accessToken = value.access_token;\n                return {\n                    success: true,\n                    mfaRequired: false\n                };\n            }),\n            catchError((e) => this.catchGrantError(e))\n        );\n    }\n\n    public getAuthFlowRequestUri(redirectUrl: string, options?: AuthorizationFlowOptions): Observable<string> {\n        return this.auth0Service.authorization.buildAuthFlowRequest(redirectUrl, options?.connection ?? undefined).pipe(map(request => {\n            if (options?.useStateValidation) {\n                localStorage.setItem(\"auth0_auth_flow_state\", request.state);\n            }\n            return request.uri;\n        }));\n    }\n\n    public checkAuthFlowResponse(expectedResponsePath?: string | string[]): Observable<AuthorizationFlowResponse | null> {\n        if (typeof expectedResponsePath === \"string\") {\n            expectedResponsePath = [expectedResponsePath];\n        }\n\n        const path = expectedResponsePath?.find(x => window.location.pathname === x);\n        if (!expectedResponsePath || path) {\n            const params = new URLSearchParams(window.location.search);\n            if (!params.has(\"code\")) {\n                return of(null);\n            }\n\n            const response = {\n                path,\n                code: params.get(\"code\"),\n                stateValidationResult: AuthorizationStateValidationResult.Omitted\n            };\n\n            const savedAuthorizationState = localStorage.getItem(\"auth0_auth_flow_state\");\n            if (savedAuthorizationState) {\n                if (!params.has(\"state\") || savedAuthorizationState !== params.get(\"state\")) {\n                    response.stateValidationResult = AuthorizationStateValidationResult.Failure;\n                } else {\n                    response.stateValidationResult = AuthorizationStateValidationResult.Success;\n                }\n            }\n\n            return of(response);\n        }\n\n        return of(null);\n    }\n\n    public validateOobCode(code: string): Observable<void> {\n        return this.auth0Service.token.authWithOobCode(this.lastMfaChallengeToken, this.lastMfaOobCode, code).pipe(\n            map(value => {\n                this.refreshToken = value.refresh_token;\n                this.idToken = value.id_token;\n                this.accessToken = value.access_token;\n            })\n        );\n    }\n\n    public logout(): Observable<void> {\n        const refreshToken = localStorage.getItem(\"auth0_refresh_token\");\n\n        localStorage.removeItem(\"auth0_id_token\");\n        localStorage.removeItem(\"auth0_access_token\");\n        localStorage.removeItem(\"auth0_refresh_token\");\n\n        return this.auth0Service.token.revokeRefreshToken(refreshToken);\n    }\n\n    public generateNewToken(): Observable<string> {\n        return this.auth0Service.token.refreshToken(this.refreshToken).pipe(\n            tap(value => {\n                this.refreshToken = value.refresh_token;\n                this.idToken = value.id_token;\n                this.accessToken = value.access_token;\n            }),\n            map(value => value.access_token),\n            catchError(e => {\n                return of(null);\n            })\n        );\n    }\n\n    public addMfaAuthenticator(authenticator: SmsAuthenticator | EmailAuthenticator): Observable<void> {\n        return this.auth0Service.mfa.associateOobAuthenticator({\n            mfaToken: this.lastMfaChallengeToken,\n            channels: [authenticator.type],\n            email: (authenticator as EmailAuthenticator).email,\n            phoneNumber: (authenticator as SmsAuthenticator).phoneNumber\n        }).pipe(\n            map(value => {\n                this.lastMfaOobCode = value.oob_code;\n            })\n        );\n    }\n\n    public triggerMfaChallenge(): Observable<void> {\n        return this.auth0Service.mfa.challenge({\n            type: \"oob\",\n            mfaToken: this.lastMfaChallengeToken\n        }).pipe(\n            map(value => {\n                this.lastMfaOobCode = value.oob_code;\n            })\n        );\n    }\n\n    private catchGrantError(e: any): Observable<LoginResponse> {\n        if (e instanceof Auth0MfaRequiredException) {\n            this.lastMfaChallengeToken = e.mfaToken;\n            return this.triggerMfaChallenge().pipe(\n                map(() => ({\n                    success: true,\n                    mfaRequired: true\n                })),\n                catchError((err) => {\n                    if (err instanceof Auth0AssociationRequiredException) {\n                        return throwError(() => new NoAuthenticatorException());\n                    }\n                    return throwError(() => err);\n                })\n            );\n        }\n        return throwError(() => e);\n    }\n\n}\n"]}
|
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
export class NoAuthenticatorException {
|
|
2
|
-
}
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm8tYXV0aGVudGljYXRvci5leGNlcHRpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uaWNlLWF1dGgwLWtpdC9zcmMvbGliL3Byb3ZpZGVycy9leGNlcHRpb25zL25vLWF1dGhlbnRpY2F0b3IuZXhjZXB0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sT0FBTyx3QkFBd0I7Q0FBRyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjbGFzcyBOb0F1dGhlbnRpY2F0b3JFeGNlcHRpb24ge31cbiJdfQ==
|
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
export * from "./exceptions/no-authenticator.exception";
|
|
2
|
-
export * from "./authentication.service";
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uaWNlLWF1dGgwLWtpdC9zcmMvbGliL3Byb3ZpZGVycy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHlDQUF5QyxDQUFDO0FBQ3hELGNBQWMsMEJBQTBCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9leGNlcHRpb25zL25vLWF1dGhlbnRpY2F0b3IuZXhjZXB0aW9uXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9hdXRoZW50aWNhdGlvbi5zZXJ2aWNlXCI7XG4iXX0=
|
package/esm2022/public-api.mjs
DELETED
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* Public API Surface of nice-auth0-kit
|
|
3
|
-
*/
|
|
4
|
-
export * from "./lib/nice-auht0-kit.module";
|
|
5
|
-
export * from "./lib/nice-auth0-kit.options";
|
|
6
|
-
export * from "./lib/api";
|
|
7
|
-
export * from "./lib/providers";
|
|
8
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL25pY2UtYXV0aDAta2l0L3NyYy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsV0FBVyxDQUFDO0FBQzFCLGNBQWMsaUJBQWlCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIG5pY2UtYXV0aDAta2l0XG4gKi9cblxuZXhwb3J0ICogZnJvbSBcIi4vbGliL25pY2UtYXVodDAta2l0Lm1vZHVsZVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbGliL25pY2UtYXV0aDAta2l0Lm9wdGlvbnNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9hcGlcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2xpYi9wcm92aWRlcnNcIjtcbiJdfQ==
|
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Generated bundle index. Do not edit.
|
|
3
|
-
*/
|
|
4
|
-
export * from './public-api';
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVjdXJzeXZlLW5pY2UtYXV0aDAta2l0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcHJvamVjdHMvbmljZS1hdXRoMC1raXQvc3JjL3JlY3Vyc3l2ZS1uaWNlLWF1dGgwLWtpdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpYy1hcGknO1xuIl19
|
package/lib/api/auth0.api.d.ts
DELETED
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import { Auth0Api } from "../auth0.api";
|
|
2
|
-
import { NiceAuth0Options } from "../../nice-auth0-kit.options";
|
|
3
|
-
import { Observable } from "rxjs";
|
|
4
|
-
import { AuthorizationFlowRequest } from "./models/authorization-flow-request.model";
|
|
5
|
-
import * as i0 from "@angular/core";
|
|
6
|
-
export declare class Auth0AuthorizationApi extends Auth0Api {
|
|
7
|
-
private options;
|
|
8
|
-
constructor(options: NiceAuth0Options);
|
|
9
|
-
buildAuthFlowRequest(redirectUrl: string, connection?: string): Observable<AuthorizationFlowRequest>;
|
|
10
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<Auth0AuthorizationApi, never>;
|
|
11
|
-
static ɵprov: i0.ɵɵInjectableDeclaration<Auth0AuthorizationApi>;
|
|
12
|
-
}
|
package/lib/api/index.d.ts
DELETED
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import { HttpEvent, HttpHandler, HttpInterceptor, HttpRequest } from "@angular/common/http";
|
|
2
|
-
import { Observable } from "rxjs";
|
|
3
|
-
import { NiceAuth0Options } from "../../nice-auth0-kit.options";
|
|
4
|
-
import { NiceAuthenticationService } from "../../providers/authentication.service";
|
|
5
|
-
import * as i0 from "@angular/core";
|
|
6
|
-
export declare class NiceAuthInterceptor implements HttpInterceptor {
|
|
7
|
-
private options;
|
|
8
|
-
private authService;
|
|
9
|
-
constructor(options: NiceAuth0Options, authService: NiceAuthenticationService);
|
|
10
|
-
intercept(req: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>>;
|
|
11
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<NiceAuthInterceptor, never>;
|
|
12
|
-
static ɵprov: i0.ɵɵInjectableDeclaration<NiceAuthInterceptor>;
|
|
13
|
-
}
|
package/lib/api/mfa/mfa.api.d.ts
DELETED
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import { HttpClient } from "@angular/common/http";
|
|
2
|
-
import { Observable } from "rxjs";
|
|
3
|
-
import { NiceAuth0Options } from "../../nice-auth0-kit.options";
|
|
4
|
-
import { Auth0Api } from "../auth0.api";
|
|
5
|
-
import { Auth0MfaAddOobAuthenticatorRequest, Auth0MfaChallengeRequest } from "./model/mfa-request.model";
|
|
6
|
-
import { Auth0ChallengeResponse } from "./model/mfa-response.model";
|
|
7
|
-
import * as i0 from "@angular/core";
|
|
8
|
-
export declare class Auth0MfaApi extends Auth0Api {
|
|
9
|
-
private options;
|
|
10
|
-
private http;
|
|
11
|
-
constructor(options: NiceAuth0Options, http: HttpClient);
|
|
12
|
-
challenge(req: Auth0MfaChallengeRequest): Observable<Auth0ChallengeResponse>;
|
|
13
|
-
associateOobAuthenticator(req: Auth0MfaAddOobAuthenticatorRequest): Observable<Auth0ChallengeResponse>;
|
|
14
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<Auth0MfaApi, never>;
|
|
15
|
-
static ɵprov: i0.ɵɵInjectableDeclaration<Auth0MfaApi>;
|
|
16
|
-
}
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import { Auth0MfaApi } from "./mfa/mfa.api";
|
|
2
|
-
import { Auth0TokenApi } from "./token/token.api";
|
|
3
|
-
import { Auth0AuthorizationApi } from "./authorization/authorization.api";
|
|
4
|
-
import * as i0 from "@angular/core";
|
|
5
|
-
export declare class NiceAuth0Service {
|
|
6
|
-
mfa: Auth0MfaApi;
|
|
7
|
-
token: Auth0TokenApi;
|
|
8
|
-
authorization: Auth0AuthorizationApi;
|
|
9
|
-
constructor(mfa: Auth0MfaApi, token: Auth0TokenApi, authorization: Auth0AuthorizationApi);
|
|
10
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<NiceAuth0Service, never>;
|
|
11
|
-
static ɵprov: i0.ɵɵInjectableDeclaration<NiceAuth0Service>;
|
|
12
|
-
}
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import { HttpClient } from "@angular/common/http";
|
|
2
|
-
import { Observable } from "rxjs";
|
|
3
|
-
import { NiceAuth0Options } from "../../nice-auth0-kit.options";
|
|
4
|
-
import { Auth0Api } from "../auth0.api";
|
|
5
|
-
import { Auth0TokenResponse } from "./models/token-response.model";
|
|
6
|
-
import * as i0 from "@angular/core";
|
|
7
|
-
export declare class Auth0TokenApi extends Auth0Api {
|
|
8
|
-
private options;
|
|
9
|
-
private http;
|
|
10
|
-
constructor(options: NiceAuth0Options, http: HttpClient);
|
|
11
|
-
authWithPassword(username: string, password: string): Observable<Auth0TokenResponse>;
|
|
12
|
-
authWithOobCode(mfaToken: string, oobCode: string, bindingCode: string): Observable<Auth0TokenResponse>;
|
|
13
|
-
authWithAuthorizationCode(authCode: string, redirectUrl: string): Observable<Auth0TokenResponse>;
|
|
14
|
-
refreshToken(refreshToken: string): Observable<Auth0TokenResponse>;
|
|
15
|
-
revokeRefreshToken(refreshToken: string): Observable<void>;
|
|
16
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<Auth0TokenApi, never>;
|
|
17
|
-
static ɵprov: i0.ɵɵInjectableDeclaration<Auth0TokenApi>;
|
|
18
|
-
}
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import { ModuleWithProviders } from "@angular/core";
|
|
2
|
-
import { NiceAuth0Options } from "./nice-auth0-kit.options";
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "@angular/common/http";
|
|
5
|
-
export declare class NiceAuth0Module {
|
|
6
|
-
static forRoot(options: NiceAuth0Options): ModuleWithProviders<NiceAuth0Module>;
|
|
7
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<NiceAuth0Module, never>;
|
|
8
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<NiceAuth0Module, never, [typeof i1.HttpClientModule], never>;
|
|
9
|
-
static ɵinj: i0.ɵɵInjectorDeclaration<NiceAuth0Module>;
|
|
10
|
-
}
|
|
@@ -1,64 +0,0 @@
|
|
|
1
|
-
import { BehaviorSubject, Observable } from "rxjs";
|
|
2
|
-
import { NiceAuth0Service } from "../api";
|
|
3
|
-
import { NiceAuth0Options } from "../nice-auth0-kit.options";
|
|
4
|
-
import * as i0 from "@angular/core";
|
|
5
|
-
export interface LoginResponse {
|
|
6
|
-
success: boolean;
|
|
7
|
-
mfaRequired: boolean;
|
|
8
|
-
}
|
|
9
|
-
export interface SmsAuthenticator {
|
|
10
|
-
type: "sms";
|
|
11
|
-
phoneNumber: string;
|
|
12
|
-
}
|
|
13
|
-
export interface EmailAuthenticator {
|
|
14
|
-
type: "email";
|
|
15
|
-
email: string;
|
|
16
|
-
}
|
|
17
|
-
export interface AuthorizationFlowOptions {
|
|
18
|
-
connection?: string;
|
|
19
|
-
useStateValidation?: boolean;
|
|
20
|
-
}
|
|
21
|
-
export declare enum AuthorizationStateValidationResult {
|
|
22
|
-
Omitted = "omitted",
|
|
23
|
-
Success = "success",
|
|
24
|
-
Failure = "failure"
|
|
25
|
-
}
|
|
26
|
-
export interface AuthorizationFlowResponse {
|
|
27
|
-
path?: string;
|
|
28
|
-
code: string;
|
|
29
|
-
stateValidationResult: AuthorizationStateValidationResult;
|
|
30
|
-
}
|
|
31
|
-
export declare class NiceAuthenticationService {
|
|
32
|
-
private options;
|
|
33
|
-
private auth0Service;
|
|
34
|
-
private lastMfaChallengeToken;
|
|
35
|
-
private lastMfaOobCode;
|
|
36
|
-
currentUser$: BehaviorSubject<any>;
|
|
37
|
-
constructor(options: NiceAuth0Options, auth0Service: NiceAuth0Service);
|
|
38
|
-
get idToken(): string;
|
|
39
|
-
set idToken(accessToken: string);
|
|
40
|
-
get accessToken(): string;
|
|
41
|
-
set accessToken(accessToken: string);
|
|
42
|
-
get refreshToken(): string;
|
|
43
|
-
set refreshToken(refreshToken: string);
|
|
44
|
-
get authToken(): string;
|
|
45
|
-
get idTokenPayload(): any;
|
|
46
|
-
get accessTokenPayload(): any;
|
|
47
|
-
get authTokenPayload(): any;
|
|
48
|
-
get currentUser(): any;
|
|
49
|
-
checkLoggedIn(): Observable<boolean>;
|
|
50
|
-
getAuthorizationToken(): Observable<string>;
|
|
51
|
-
validateToken(): boolean;
|
|
52
|
-
passwordGrant(username: string, password: string): Observable<LoginResponse>;
|
|
53
|
-
authorizationCodeGrant(code: string, redirectUrl: string): Observable<LoginResponse>;
|
|
54
|
-
getAuthFlowRequestUri(redirectUrl: string, options?: AuthorizationFlowOptions): Observable<string>;
|
|
55
|
-
checkAuthFlowResponse(expectedResponsePath?: string | string[]): Observable<AuthorizationFlowResponse | null>;
|
|
56
|
-
validateOobCode(code: string): Observable<void>;
|
|
57
|
-
logout(): Observable<void>;
|
|
58
|
-
generateNewToken(): Observable<string>;
|
|
59
|
-
addMfaAuthenticator(authenticator: SmsAuthenticator | EmailAuthenticator): Observable<void>;
|
|
60
|
-
triggerMfaChallenge(): Observable<void>;
|
|
61
|
-
private catchGrantError;
|
|
62
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<NiceAuthenticationService, never>;
|
|
63
|
-
static ɵprov: i0.ɵɵInjectableDeclaration<NiceAuthenticationService>;
|
|
64
|
-
}
|
package/lib/providers/index.d.ts
DELETED
package/public-api.d.ts
DELETED