@dangl/angular-dangl-identity-client 6.2.0-beta0010 → 6.2.1-beta0010
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/README.md +25 -0
- package/api-client.d.ts +178 -178
- package/dangl-identity.module.d.ts +6 -7
- package/{esm2020 → esm2022}/api-client.mjs +551 -551
- package/{esm2020 → esm2022}/dangl-angular-dangl-identity-client.mjs +4 -4
- package/esm2022/dangl-identity.module.mjs +30 -0
- package/{esm2020 → esm2022}/interceptors/dangl-identity-request-validator.mjs +1 -1
- package/{esm2020 → esm2022}/interceptors/jwt-interceptor.service.mjs +47 -47
- package/esm2022/messengers/authentication.messenger.mjs +170 -0
- package/{esm2020 → esm2022}/models/jwt-storage.mjs +1 -1
- package/{esm2020 → esm2022}/models/user-info.mjs +1 -1
- package/{esm2020 → esm2022}/public_api.mjs +11 -11
- package/{esm2020 → esm2022}/services/authentication.service.mjs +39 -39
- package/{esm2020 → esm2022}/services/jwt-token.service.mjs +101 -101
- package/{fesm2020 → fesm2022}/dangl-angular-dangl-identity-client.mjs +905 -873
- package/fesm2022/dangl-angular-dangl-identity-client.mjs.map +1 -0
- package/index.d.ts +5 -5
- package/interceptors/dangl-identity-request-validator.d.ts +4 -4
- package/interceptors/jwt-interceptor.service.d.ts +16 -16
- package/messengers/authentication.messenger.d.ts +28 -26
- package/models/jwt-storage.d.ts +5 -5
- package/models/user-info.d.ts +11 -11
- package/package.json +7 -13
- package/public_api.d.ts +8 -8
- package/services/authentication.service.d.ts +14 -14
- package/services/jwt-token.service.d.ts +28 -28
- package/esm2020/dangl-identity.module.mjs +0 -29
- package/esm2020/messengers/authentication.messenger.mjs +0 -146
- package/fesm2015/dangl-angular-dangl-identity-client.mjs +0 -896
- package/fesm2015/dangl-angular-dangl-identity-client.mjs.map +0 -1
- package/fesm2020/dangl-angular-dangl-identity-client.mjs.map +0 -1
|
@@ -1,146 +0,0 @@
|
|
|
1
|
-
import { Injectable } from '@angular/core';
|
|
2
|
-
import { ReplaySubject, Subject } from 'rxjs';
|
|
3
|
-
import { JwtHelperService } from '@auth0/angular-jwt';
|
|
4
|
-
import { takeUntil } from 'rxjs/operators';
|
|
5
|
-
import * as i0 from "@angular/core";
|
|
6
|
-
import * as i1 from "../services/jwt-token.service";
|
|
7
|
-
import * as i2 from "../api-client";
|
|
8
|
-
export class AuthenticationMessenger {
|
|
9
|
-
constructor(jwtTokenService, danglIdentityClient) {
|
|
10
|
-
this.jwtTokenService = jwtTokenService;
|
|
11
|
-
this.danglIdentityClient = danglIdentityClient;
|
|
12
|
-
this.jwtHelperService = new JwtHelperService();
|
|
13
|
-
this.$destroyed = new Subject();
|
|
14
|
-
this.isAuthenticated = new ReplaySubject(1);
|
|
15
|
-
this.username = new ReplaySubject(1);
|
|
16
|
-
this.email = new ReplaySubject(1);
|
|
17
|
-
this.identiconId = new ReplaySubject(1);
|
|
18
|
-
this.userInfo = new ReplaySubject(1);
|
|
19
|
-
this.tokenRefreshStarted = new Subject();
|
|
20
|
-
this.tokenRefreshFinished = new Subject();
|
|
21
|
-
jwtTokenService.tokenRefreshStarted
|
|
22
|
-
.pipe(takeUntil(this.$destroyed))
|
|
23
|
-
.subscribe(() => this.tokenRefreshStarted.next());
|
|
24
|
-
jwtTokenService.tokenRefreshFinished
|
|
25
|
-
.pipe(takeUntil(this.$destroyed))
|
|
26
|
-
.subscribe((successfulRefresh) => this.tokenRefreshFinished.next(successfulRefresh));
|
|
27
|
-
jwtTokenService.tokenStored
|
|
28
|
-
.pipe(takeUntil(this.$destroyed))
|
|
29
|
-
.subscribe((jwtToken) => this.refreshAuthenticationStatus(jwtToken));
|
|
30
|
-
jwtTokenService
|
|
31
|
-
.getToken()
|
|
32
|
-
.subscribe((token) => this.refreshAuthenticationStatus(token));
|
|
33
|
-
}
|
|
34
|
-
ngOnDestroy() {
|
|
35
|
-
this.isAuthenticated.complete();
|
|
36
|
-
this.username.complete();
|
|
37
|
-
this.email.complete();
|
|
38
|
-
this.identiconId.complete();
|
|
39
|
-
this.userInfo.complete();
|
|
40
|
-
this.tokenRefreshStarted.complete();
|
|
41
|
-
this.tokenRefreshFinished.complete();
|
|
42
|
-
this.$destroyed.next();
|
|
43
|
-
this.$destroyed.complete();
|
|
44
|
-
}
|
|
45
|
-
refreshUserInfoFromServer() {
|
|
46
|
-
this.danglIdentityClient.getUserInfo().subscribe({
|
|
47
|
-
next: (serverUserInfo) => {
|
|
48
|
-
if (serverUserInfo.userIsAuthenticated) {
|
|
49
|
-
const userInfo = {
|
|
50
|
-
deserializedToken: null,
|
|
51
|
-
email: serverUserInfo.currentUserEmail,
|
|
52
|
-
id: serverUserInfo.currentUserId,
|
|
53
|
-
identiconId: serverUserInfo.currentUserIdenticonId,
|
|
54
|
-
roles: [],
|
|
55
|
-
claims: {},
|
|
56
|
-
username: serverUserInfo.currentUserName,
|
|
57
|
-
};
|
|
58
|
-
serverUserInfo.userClaims.forEach((claim) => {
|
|
59
|
-
if (claim.type === 'role') {
|
|
60
|
-
userInfo.roles.push(claim.value);
|
|
61
|
-
}
|
|
62
|
-
else if (userInfo.claims[claim.type] === undefined) {
|
|
63
|
-
userInfo.claims[claim.type] = [claim.value];
|
|
64
|
-
}
|
|
65
|
-
else {
|
|
66
|
-
userInfo.claims[claim.type].push(claim.value);
|
|
67
|
-
}
|
|
68
|
-
});
|
|
69
|
-
this.isAuthenticated.next(true);
|
|
70
|
-
this.username.next(serverUserInfo.currentUserName);
|
|
71
|
-
this.email.next(serverUserInfo.currentUserEmail);
|
|
72
|
-
this.identiconId.next(serverUserInfo.currentUserIdenticonId);
|
|
73
|
-
this.userInfo.next(userInfo);
|
|
74
|
-
}
|
|
75
|
-
else {
|
|
76
|
-
this.isAuthenticated.next(false);
|
|
77
|
-
this.username.next(null);
|
|
78
|
-
this.email.next(null);
|
|
79
|
-
this.identiconId.next(null);
|
|
80
|
-
this.userInfo.next(null);
|
|
81
|
-
}
|
|
82
|
-
},
|
|
83
|
-
});
|
|
84
|
-
}
|
|
85
|
-
refreshAuthenticationStatus(jwtToken) {
|
|
86
|
-
if (jwtToken) {
|
|
87
|
-
const isValidToken = jwtToken.expiresAt > new Date().getTime() / 1000;
|
|
88
|
-
if (this.lastBroadcastAccessToken === jwtToken.accessToken) {
|
|
89
|
-
return;
|
|
90
|
-
}
|
|
91
|
-
this.lastBroadcastAccessToken = jwtToken.accessToken;
|
|
92
|
-
if (isValidToken) {
|
|
93
|
-
this.isAuthenticated.next(true);
|
|
94
|
-
const decodedToken = this.jwtHelperService.decodeToken(jwtToken.accessToken);
|
|
95
|
-
this.username.next(decodedToken['name']);
|
|
96
|
-
this.email.next(decodedToken['email']);
|
|
97
|
-
this.identiconId.next(decodedToken['identicon_id']);
|
|
98
|
-
const tokenClaims = {};
|
|
99
|
-
for (const tokenProp in decodedToken) {
|
|
100
|
-
if (decodedToken.hasOwnProperty(tokenProp)) {
|
|
101
|
-
const property = decodedToken[tokenProp];
|
|
102
|
-
if (typeof property === 'string') {
|
|
103
|
-
if (tokenClaims[tokenProp] === undefined) {
|
|
104
|
-
tokenClaims[tokenProp] = [];
|
|
105
|
-
}
|
|
106
|
-
tokenClaims[tokenProp].push(property);
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
}
|
|
110
|
-
this.userInfo.next({
|
|
111
|
-
id: decodedToken['sub'],
|
|
112
|
-
claims: tokenClaims,
|
|
113
|
-
deserializedToken: decodedToken,
|
|
114
|
-
email: decodedToken['email'],
|
|
115
|
-
identiconId: decodedToken['identicon_id'],
|
|
116
|
-
username: decodedToken['name'],
|
|
117
|
-
roles: decodedToken['role'],
|
|
118
|
-
});
|
|
119
|
-
}
|
|
120
|
-
else {
|
|
121
|
-
this.isAuthenticated.next(false);
|
|
122
|
-
this.jwtTokenService.refreshToken().subscribe(() => { });
|
|
123
|
-
}
|
|
124
|
-
}
|
|
125
|
-
else {
|
|
126
|
-
if (this.lastBroadcastAccessToken === null) {
|
|
127
|
-
return;
|
|
128
|
-
}
|
|
129
|
-
this.lastBroadcastAccessToken = null;
|
|
130
|
-
this.isAuthenticated.next(false);
|
|
131
|
-
this.username.next(null);
|
|
132
|
-
this.email.next(null);
|
|
133
|
-
this.identiconId.next(null);
|
|
134
|
-
this.userInfo.next(null);
|
|
135
|
-
}
|
|
136
|
-
}
|
|
137
|
-
}
|
|
138
|
-
AuthenticationMessenger.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.4", ngImport: i0, type: AuthenticationMessenger, deps: [{ token: i1.JwtTokenService }, { token: i2.DanglIdentityClient }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
139
|
-
AuthenticationMessenger.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.0.4", ngImport: i0, type: AuthenticationMessenger, providedIn: 'root' });
|
|
140
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.4", ngImport: i0, type: AuthenticationMessenger, decorators: [{
|
|
141
|
-
type: Injectable,
|
|
142
|
-
args: [{
|
|
143
|
-
providedIn: 'root',
|
|
144
|
-
}]
|
|
145
|
-
}], ctorParameters: function () { return [{ type: i1.JwtTokenService }, { type: i2.DanglIdentityClient }]; } });
|
|
146
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"authentication.messenger.js","sourceRoot":"","sources":["../../../../projects/angular-dangl-identity-client/src/messengers/authentication.messenger.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, OnDestroy } from '@angular/core';\r\nimport { ReplaySubject, Subject } from 'rxjs';\r\n\r\nimport { DanglIdentityClient } from '../api-client';\r\nimport { JwtHelperService } from '@auth0/angular-jwt';\r\nimport { JwtStorage } from '../models/jwt-storage';\r\nimport { JwtTokenService } from '../services/jwt-token.service';\r\nimport { UserInfo } from '../models/user-info';\r\nimport { takeUntil } from 'rxjs/operators';\r\n\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class AuthenticationMessenger implements OnDestroy {\r\n  private jwtHelperService = new JwtHelperService();\r\n  private lastBroadcastAccessToken: string;\r\n  private $destroyed = new Subject();\r\n\r\n  readonly isAuthenticated = new ReplaySubject<boolean>(1);\r\n  readonly username = new ReplaySubject<string>(1);\r\n  readonly email = new ReplaySubject<string>(1);\r\n  readonly identiconId = new ReplaySubject<string>(1);\r\n  readonly userInfo = new ReplaySubject<UserInfo>(1);\r\n  readonly tokenRefreshStarted = new Subject();\r\n  readonly tokenRefreshFinished = new Subject<boolean>();\r\n\r\n  constructor(\r\n    private jwtTokenService: JwtTokenService,\r\n    private danglIdentityClient: DanglIdentityClient\r\n  ) {\r\n    jwtTokenService.tokenRefreshStarted\r\n      .pipe(takeUntil(this.$destroyed))\r\n      .subscribe(() => this.tokenRefreshStarted.next());\r\n\r\n    jwtTokenService.tokenRefreshFinished\r\n      .pipe(takeUntil(this.$destroyed))\r\n      .subscribe((successfulRefresh) =>\r\n        this.tokenRefreshFinished.next(successfulRefresh)\r\n      );\r\n\r\n    jwtTokenService.tokenStored\r\n      .pipe(takeUntil(this.$destroyed))\r\n      .subscribe((jwtToken) => this.refreshAuthenticationStatus(jwtToken));\r\n\r\n    jwtTokenService\r\n      .getToken()\r\n      .subscribe((token) => this.refreshAuthenticationStatus(token));\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.isAuthenticated.complete();\r\n    this.username.complete();\r\n    this.email.complete();\r\n    this.identiconId.complete();\r\n    this.userInfo.complete();\r\n    this.tokenRefreshStarted.complete();\r\n    this.tokenRefreshFinished.complete();\r\n    this.$destroyed.next();\r\n    this.$destroyed.complete();\r\n  }\r\n\r\n  refreshUserInfoFromServer(): void {\r\n    this.danglIdentityClient.getUserInfo().subscribe({\r\n      next: (serverUserInfo) => {\r\n        if (serverUserInfo.userIsAuthenticated) {\r\n          const userInfo: UserInfo = {\r\n            deserializedToken: null,\r\n            email: serverUserInfo.currentUserEmail,\r\n            id: serverUserInfo.currentUserId,\r\n            identiconId: serverUserInfo.currentUserIdenticonId,\r\n            roles: [],\r\n            claims: {},\r\n            username: serverUserInfo.currentUserName,\r\n          };\r\n\r\n          serverUserInfo.userClaims.forEach((claim) => {\r\n            if (claim.type === 'role') {\r\n              userInfo.roles.push(claim.value);\r\n            } else if (userInfo.claims[claim.type] === undefined) {\r\n              userInfo.claims[claim.type] = [claim.value];\r\n            } else {\r\n              userInfo.claims[claim.type].push(claim.value);\r\n            }\r\n          });\r\n          this.isAuthenticated.next(true);\r\n          this.username.next(serverUserInfo.currentUserName);\r\n          this.email.next(serverUserInfo.currentUserEmail);\r\n          this.identiconId.next(serverUserInfo.currentUserIdenticonId);\r\n          this.userInfo.next(userInfo);\r\n        } else {\r\n          this.isAuthenticated.next(false);\r\n          this.username.next(null);\r\n          this.email.next(null);\r\n          this.identiconId.next(null);\r\n          this.userInfo.next(null);\r\n        }\r\n      },\r\n    });\r\n  }\r\n\r\n  private refreshAuthenticationStatus(jwtToken?: JwtStorage) {\r\n    if (jwtToken) {\r\n      const isValidToken = jwtToken.expiresAt > new Date().getTime() / 1000;\r\n      if (this.lastBroadcastAccessToken === jwtToken.accessToken) {\r\n        return;\r\n      }\r\n      this.lastBroadcastAccessToken = jwtToken.accessToken;\r\n      if (isValidToken) {\r\n        this.isAuthenticated.next(true);\r\n        const decodedToken = this.jwtHelperService.decodeToken(\r\n          jwtToken.accessToken\r\n        );\r\n        this.username.next(decodedToken['name']);\r\n        this.email.next(decodedToken['email']);\r\n        this.identiconId.next(decodedToken['identicon_id']);\r\n\r\n        const tokenClaims: { [claim: string]: string[] } = {};\r\n        for (const tokenProp in decodedToken) {\r\n          if (decodedToken.hasOwnProperty(tokenProp)) {\r\n            const property = decodedToken[tokenProp];\r\n            if (typeof property === 'string') {\r\n              if (tokenClaims[tokenProp] === undefined) {\r\n                tokenClaims[tokenProp] = [];\r\n              }\r\n\r\n              tokenClaims[tokenProp].push(property);\r\n            }\r\n          }\r\n        }\r\n\r\n        this.userInfo.next({\r\n          id: decodedToken['sub'],\r\n          claims: tokenClaims,\r\n          deserializedToken: decodedToken,\r\n          email: decodedToken['email'],\r\n          identiconId: decodedToken['identicon_id'],\r\n          username: decodedToken['name'],\r\n          roles: decodedToken['role'],\r\n        });\r\n      } else {\r\n        this.isAuthenticated.next(false);\r\n        this.jwtTokenService.refreshToken().subscribe(() => {});\r\n      }\r\n    } else {\r\n      if (this.lastBroadcastAccessToken === null) {\r\n        return;\r\n      }\r\n      this.lastBroadcastAccessToken = null;\r\n      this.isAuthenticated.next(false);\r\n      this.username.next(null);\r\n      this.email.next(null);\r\n      this.identiconId.next(null);\r\n      this.userInfo.next(null);\r\n    }\r\n  }\r\n}\r\n"]}
|