1 | /**
|
2 | * @license
|
3 | * Copyright Akveo. All Rights Reserved.
|
4 | * Licensed under the MIT License. See License.txt in the project root for license information.
|
5 | */
|
6 | import { Inject, Injectable } from '@angular/core';
|
7 | import { of as observableOf } from 'rxjs';
|
8 | import { switchMap, map } from 'rxjs/operators';
|
9 | import { NB_AUTH_STRATEGIES } from '../auth.options';
|
10 | import * as i0 from "@angular/core";
|
11 | import * as i1 from "./token/token.service";
|
12 | /**
|
13 | * Common authentication service.
|
14 | * Should be used to as an interlayer between UI Components and Auth Strategy.
|
15 | */
|
16 | export class NbAuthService {
|
17 | constructor(tokenService, strategies) {
|
18 | this.tokenService = tokenService;
|
19 | this.strategies = strategies;
|
20 | }
|
21 | /**
|
22 | * Retrieves current authenticated token stored
|
23 | * @returns {Observable<any>}
|
24 | */
|
25 | getToken() {
|
26 | return this.tokenService.get();
|
27 | }
|
28 | /**
|
29 | * Returns true if auth token is present in the token storage
|
30 | * @returns {Observable<boolean>}
|
31 | */
|
32 | isAuthenticated() {
|
33 | return this.getToken()
|
34 | .pipe(map((token) => token.isValid()));
|
35 | }
|
36 | /**
|
37 | * Returns true if valid auth token is present in the token storage.
|
38 | * If not, calls the strategy refreshToken, and returns isAuthenticated() if success, false otherwise
|
39 | * @returns {Observable<boolean>}
|
40 | */
|
41 | isAuthenticatedOrRefresh() {
|
42 | return this.getToken()
|
43 | .pipe(switchMap(token => {
|
44 | if (token.getValue() && !token.isValid()) {
|
45 | return this.refreshToken(token.getOwnerStrategyName(), token)
|
46 | .pipe(switchMap(res => {
|
47 | if (res.isSuccess()) {
|
48 | return this.isAuthenticated();
|
49 | }
|
50 | else {
|
51 | return observableOf(false);
|
52 | }
|
53 | }));
|
54 | }
|
55 | else {
|
56 | return observableOf(token.isValid());
|
57 | }
|
58 | }));
|
59 | }
|
60 | /**
|
61 | * Returns tokens stream
|
62 | * @returns {Observable<NbAuthSimpleToken>}
|
63 | */
|
64 | onTokenChange() {
|
65 | return this.tokenService.tokenChange();
|
66 | }
|
67 | /**
|
68 | * Returns authentication status stream
|
69 | * @returns {Observable<boolean>}
|
70 | */
|
71 | onAuthenticationChange() {
|
72 | return this.onTokenChange()
|
73 | .pipe(map((token) => token.isValid()));
|
74 | }
|
75 | /**
|
76 | * Authenticates with the selected strategy
|
77 | * Stores received token in the token storage
|
78 | *
|
79 | * Example:
|
80 | * authenticate('email', {email: 'email@example.com', password: 'test'})
|
81 | *
|
82 | * @param strategyName
|
83 | * @param data
|
84 | * @returns {Observable<NbAuthResult>}
|
85 | */
|
86 | authenticate(strategyName, data) {
|
87 | return this.getStrategy(strategyName).authenticate(data)
|
88 | .pipe(switchMap((result) => {
|
89 | return this.processResultToken(result);
|
90 | }));
|
91 | }
|
92 | /**
|
93 | * Registers with the selected strategy
|
94 | * Stores received token in the token storage
|
95 | *
|
96 | * Example:
|
97 | * register('email', {email: 'email@example.com', name: 'Some Name', password: 'test'})
|
98 | *
|
99 | * @param strategyName
|
100 | * @param data
|
101 | * @returns {Observable<NbAuthResult>}
|
102 | */
|
103 | register(strategyName, data) {
|
104 | return this.getStrategy(strategyName).register(data)
|
105 | .pipe(switchMap((result) => {
|
106 | return this.processResultToken(result);
|
107 | }));
|
108 | }
|
109 | /**
|
110 | * Sign outs with the selected strategy
|
111 | * Removes token from the token storage
|
112 | *
|
113 | * Example:
|
114 | * logout('email')
|
115 | *
|
116 | * @param strategyName
|
117 | * @returns {Observable<NbAuthResult>}
|
118 | */
|
119 | logout(strategyName) {
|
120 | return this.getStrategy(strategyName).logout()
|
121 | .pipe(switchMap((result) => {
|
122 | if (result.isSuccess()) {
|
123 | this.tokenService.clear()
|
124 | .pipe(map(() => result));
|
125 | }
|
126 | return observableOf(result);
|
127 | }));
|
128 | }
|
129 | /**
|
130 | * Sends forgot password request to the selected strategy
|
131 | *
|
132 | * Example:
|
133 | * requestPassword('email', {email: 'email@example.com'})
|
134 | *
|
135 | * @param strategyName
|
136 | * @param data
|
137 | * @returns {Observable<NbAuthResult>}
|
138 | */
|
139 | requestPassword(strategyName, data) {
|
140 | return this.getStrategy(strategyName).requestPassword(data);
|
141 | }
|
142 | /**
|
143 | * Tries to reset password with the selected strategy
|
144 | *
|
145 | * Example:
|
146 | * resetPassword('email', {newPassword: 'test'})
|
147 | *
|
148 | * @param strategyName
|
149 | * @param data
|
150 | * @returns {Observable<NbAuthResult>}
|
151 | */
|
152 | resetPassword(strategyName, data) {
|
153 | return this.getStrategy(strategyName).resetPassword(data);
|
154 | }
|
155 | /**
|
156 | * Sends a refresh token request
|
157 | * Stores received token in the token storage
|
158 | *
|
159 | * Example:
|
160 | * refreshToken('email', {token: token})
|
161 | *
|
162 | * @param {string} strategyName
|
163 | * @param data
|
164 | * @returns {Observable<NbAuthResult>}
|
165 | */
|
166 | refreshToken(strategyName, data) {
|
167 | return this.getStrategy(strategyName).refreshToken(data)
|
168 | .pipe(switchMap((result) => {
|
169 | return this.processResultToken(result);
|
170 | }));
|
171 | }
|
172 | /**
|
173 | * Get registered strategy by name
|
174 | *
|
175 | * Example:
|
176 | * getStrategy('email')
|
177 | *
|
178 | * @param {string} provider
|
179 | * @returns {NbAbstractAuthProvider}
|
180 | */
|
181 | getStrategy(strategyName) {
|
182 | const found = this.strategies.find((strategy) => strategy.getName() === strategyName);
|
183 | if (!found) {
|
184 | throw new TypeError(`There is no Auth Strategy registered under '${strategyName}' name`);
|
185 | }
|
186 | return found;
|
187 | }
|
188 | processResultToken(result) {
|
189 | if (result.isSuccess() && result.getToken()) {
|
190 | return this.tokenService.set(result.getToken())
|
191 | .pipe(map((token) => {
|
192 | return result;
|
193 | }));
|
194 | }
|
195 | return observableOf(result);
|
196 | }
|
197 | }
|
198 | NbAuthService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: NbAuthService, deps: [{ token: i1.NbTokenService }, { token: NB_AUTH_STRATEGIES }], target: i0.ɵɵFactoryTarget.Injectable });
|
199 | NbAuthService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: NbAuthService });
|
200 | i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: NbAuthService, decorators: [{
|
201 | type: Injectable
|
202 | }], ctorParameters: function () { return [{ type: i1.NbTokenService }, { type: undefined, decorators: [{
|
203 | type: Inject,
|
204 | args: [NB_AUTH_STRATEGIES]
|
205 | }] }]; } });
|
206 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth.service.js","sourceRoot":"","sources":["../../../../src/framework/auth/services/auth.service.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Akveo. All Rights Reserved.\n * Licensed under the MIT License. See License.txt in the project root for license information.\n */\nimport { Inject, Injectable } from '@angular/core';\n\nimport { Observable, of as observableOf } from 'rxjs';\nimport { switchMap, map } from 'rxjs/operators';\n\nimport { NbAuthStrategy } from '../strategies/auth-strategy';\nimport { NB_AUTH_STRATEGIES } from '../auth.options';\nimport { NbAuthResult } from './auth-result';\nimport { NbTokenService } from './token/token.service';\nimport { NbAuthToken } from './token/token';\n\n/**\n * Common authentication service.\n * Should be used to as an interlayer between UI Components and Auth Strategy.\n */\n@Injectable()\nexport class NbAuthService {\n\n  constructor(protected tokenService: NbTokenService,\n              @Inject(NB_AUTH_STRATEGIES) protected strategies) {\n  }\n\n  /**\n   * Retrieves current authenticated token stored\n   * @returns {Observable<any>}\n   */\n  getToken(): Observable<NbAuthToken> {\n    return this.tokenService.get();\n  }\n\n  /**\n   * Returns true if auth token is present in the token storage\n   * @returns {Observable<boolean>}\n   */\n  isAuthenticated(): Observable<boolean> {\n    return this.getToken()\n      .pipe(map((token: NbAuthToken) => token.isValid()));\n  }\n\n  /**\n   * Returns true if valid auth token is present in the token storage.\n   * If not, calls the strategy refreshToken, and returns isAuthenticated() if success, false otherwise\n   * @returns {Observable<boolean>}\n   */\n  isAuthenticatedOrRefresh(): Observable<boolean> {\n    return this.getToken()\n      .pipe(\n        switchMap(token => {\n        if (token.getValue() && !token.isValid()) {\n          return this.refreshToken(token.getOwnerStrategyName(), token)\n            .pipe(\n              switchMap(res => {\n                if (res.isSuccess()) {\n                  return this.isAuthenticated();\n                } else {\n                  return observableOf(false);\n                }\n              }),\n            )\n        } else {\n          return observableOf(token.isValid());\n        }\n    }));\n  }\n\n  /**\n   * Returns tokens stream\n   * @returns {Observable<NbAuthSimpleToken>}\n   */\n  onTokenChange(): Observable<NbAuthToken> {\n    return this.tokenService.tokenChange();\n  }\n\n  /**\n   * Returns authentication status stream\n   * @returns {Observable<boolean>}\n   */\n  onAuthenticationChange(): Observable<boolean> {\n    return this.onTokenChange()\n      .pipe(map((token: NbAuthToken) => token.isValid()));\n  }\n\n  /**\n   * Authenticates with the selected strategy\n   * Stores received token in the token storage\n   *\n   * Example:\n   * authenticate('email', {email: 'email@example.com', password: 'test'})\n   *\n   * @param strategyName\n   * @param data\n   * @returns {Observable<NbAuthResult>}\n   */\n  authenticate(strategyName: string, data?: any): Observable<NbAuthResult> {\n    return this.getStrategy(strategyName).authenticate(data)\n      .pipe(\n        switchMap((result: NbAuthResult) => {\n          return this.processResultToken(result);\n        }),\n      );\n  }\n\n  /**\n   * Registers with the selected strategy\n   * Stores received token in the token storage\n   *\n   * Example:\n   * register('email', {email: 'email@example.com', name: 'Some Name', password: 'test'})\n   *\n   * @param strategyName\n   * @param data\n   * @returns {Observable<NbAuthResult>}\n   */\n  register(strategyName: string, data?: any): Observable<NbAuthResult> {\n    return this.getStrategy(strategyName).register(data)\n      .pipe(\n        switchMap((result: NbAuthResult) => {\n          return this.processResultToken(result);\n        }),\n      );\n  }\n\n  /**\n   * Sign outs with the selected strategy\n   * Removes token from the token storage\n   *\n   * Example:\n   * logout('email')\n   *\n   * @param strategyName\n   * @returns {Observable<NbAuthResult>}\n   */\n  logout(strategyName: string): Observable<NbAuthResult> {\n    return this.getStrategy(strategyName).logout()\n      .pipe(\n        switchMap((result: NbAuthResult) => {\n          if (result.isSuccess()) {\n            this.tokenService.clear()\n              .pipe(map(() => result));\n          }\n          return observableOf(result);\n        }),\n      );\n  }\n\n  /**\n   * Sends forgot password request to the selected strategy\n   *\n   * Example:\n   * requestPassword('email', {email: 'email@example.com'})\n   *\n   * @param strategyName\n   * @param data\n   * @returns {Observable<NbAuthResult>}\n   */\n  requestPassword(strategyName: string, data?: any): Observable<NbAuthResult> {\n    return this.getStrategy(strategyName).requestPassword(data);\n  }\n\n  /**\n   * Tries to reset password with the selected strategy\n   *\n   * Example:\n   * resetPassword('email', {newPassword: 'test'})\n   *\n   * @param strategyName\n   * @param data\n   * @returns {Observable<NbAuthResult>}\n   */\n  resetPassword(strategyName: string, data?: any): Observable<NbAuthResult> {\n    return this.getStrategy(strategyName).resetPassword(data);\n  }\n\n  /**\n   * Sends a refresh token request\n   * Stores received token in the token storage\n   *\n   * Example:\n   * refreshToken('email', {token: token})\n   *\n   * @param {string} strategyName\n   * @param data\n   * @returns {Observable<NbAuthResult>}\n   */\n  refreshToken(strategyName: string, data?: any): Observable<NbAuthResult> {\n    return this.getStrategy(strategyName).refreshToken(data)\n      .pipe(\n        switchMap((result: NbAuthResult) => {\n          return this.processResultToken(result);\n        }),\n      );\n  }\n\n  /**\n   * Get registered strategy by name\n   *\n   * Example:\n   * getStrategy('email')\n   *\n   * @param {string} provider\n   * @returns {NbAbstractAuthProvider}\n   */\n  protected getStrategy(strategyName: string): NbAuthStrategy {\n    const found = this.strategies.find((strategy: NbAuthStrategy) => strategy.getName() === strategyName);\n\n    if (!found) {\n      throw new TypeError(`There is no Auth Strategy registered under '${strategyName}' name`);\n    }\n\n    return found;\n  }\n\n  private processResultToken(result: NbAuthResult) {\n    if (result.isSuccess() && result.getToken()) {\n      return this.tokenService.set(result.getToken())\n        .pipe(\n          map((token: NbAuthToken) => {\n            return result;\n          }),\n        );\n    }\n\n    return observableOf(result);\n  }\n}\n"]} |
\ | No newline at end of file |