@acontplus/ng-auth 1.0.0

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.
@@ -0,0 +1,148 @@
1
+ export { TOKEN_PROVIDER } from '@acontplus/ng-infrastructure';
2
+ import * as i0 from '@angular/core';
3
+ import { inject, Injectable } from '@angular/core';
4
+ import { Router } from '@angular/router';
5
+ import { jwtDecode } from 'jwt-decode';
6
+ import { ENVIRONMENT } from '@acontplus/ng-config';
7
+
8
+ class TokenRepository {
9
+ environment = inject(ENVIRONMENT);
10
+ saveTokens(tokens, rememberMe = false) {
11
+ this.setToken(tokens.token, rememberMe);
12
+ this.setRefreshToken(tokens.refreshToken, rememberMe);
13
+ }
14
+ getAccessToken() {
15
+ return (localStorage.getItem(this.environment.tokenKey) ||
16
+ sessionStorage.getItem(this.environment.tokenKey));
17
+ }
18
+ getRefreshToken() {
19
+ return (localStorage.getItem(this.environment.refreshTokenKey) ||
20
+ sessionStorage.getItem(this.environment.refreshTokenKey));
21
+ }
22
+ setToken(token, rememberMe = false) {
23
+ if (rememberMe) {
24
+ localStorage.setItem(this.environment.tokenKey, token);
25
+ }
26
+ else {
27
+ sessionStorage.setItem(this.environment.tokenKey, token);
28
+ }
29
+ }
30
+ setRefreshToken(refreshToken, rememberMe = false) {
31
+ if (rememberMe) {
32
+ localStorage.setItem(this.environment.refreshTokenKey, refreshToken);
33
+ }
34
+ else {
35
+ sessionStorage.setItem(this.environment.refreshTokenKey, refreshToken);
36
+ }
37
+ }
38
+ clearTokens() {
39
+ localStorage.removeItem(this.environment.tokenKey);
40
+ localStorage.removeItem(this.environment.refreshTokenKey);
41
+ sessionStorage.removeItem(this.environment.tokenKey);
42
+ sessionStorage.removeItem(this.environment.refreshTokenKey);
43
+ }
44
+ isAuthenticated() {
45
+ const accessToken = this.getAccessToken();
46
+ const refreshToken = this.getRefreshToken();
47
+ if (!accessToken || !refreshToken) {
48
+ return false;
49
+ }
50
+ try {
51
+ const decodedAccessToken = jwtDecode(accessToken);
52
+ const accessExpiration = Number(decodedAccessToken.exp);
53
+ const currentTimeUTC = Math.floor(Date.now() / 1000);
54
+ if (accessExpiration > currentTimeUTC) {
55
+ return true;
56
+ }
57
+ return this.isRefreshTokenValid();
58
+ }
59
+ catch {
60
+ return false;
61
+ }
62
+ }
63
+ isRefreshTokenValid() {
64
+ const refreshToken = this.getRefreshToken();
65
+ if (!refreshToken) {
66
+ return false;
67
+ }
68
+ try {
69
+ return true; // Backend validates expiration
70
+ }
71
+ catch {
72
+ return false;
73
+ }
74
+ }
75
+ needsRefresh() {
76
+ const accessToken = this.getAccessToken();
77
+ if (!accessToken) {
78
+ return false;
79
+ }
80
+ try {
81
+ const decodedToken = jwtDecode(accessToken);
82
+ const expiration = Number(decodedToken.exp);
83
+ const currentTimeUTC = Math.floor(Date.now() / 1000);
84
+ const timeUntilExpiry = expiration - currentTimeUTC;
85
+ return timeUntilExpiry <= 300; // 5 minutes
86
+ }
87
+ catch {
88
+ return false;
89
+ }
90
+ }
91
+ getTokenPayload() {
92
+ const token = this.getAccessToken();
93
+ if (!token)
94
+ return null;
95
+ try {
96
+ return jwtDecode(token);
97
+ }
98
+ catch (error) {
99
+ return null;
100
+ }
101
+ }
102
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.2", ngImport: i0, type: TokenRepository, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
103
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.2", ngImport: i0, type: TokenRepository, providedIn: 'root' });
104
+ }
105
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.2", ngImport: i0, type: TokenRepository, decorators: [{
106
+ type: Injectable,
107
+ args: [{
108
+ providedIn: 'root',
109
+ }]
110
+ }] });
111
+
112
+ class AuthTokenService {
113
+ tokenRepository;
114
+ constructor(tokenRepository) {
115
+ this.tokenRepository = tokenRepository;
116
+ }
117
+ getToken() {
118
+ return this.tokenRepository.getAccessToken();
119
+ }
120
+ isAuthenticated() {
121
+ return this.tokenRepository.isAuthenticated();
122
+ }
123
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.2", ngImport: i0, type: AuthTokenService, deps: [{ token: TokenRepository }], target: i0.ɵɵFactoryTarget.Injectable });
124
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.3.2", ngImport: i0, type: AuthTokenService, providedIn: 'root' });
125
+ }
126
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.2", ngImport: i0, type: AuthTokenService, decorators: [{
127
+ type: Injectable,
128
+ args: [{ providedIn: 'root' }]
129
+ }], ctorParameters: () => [{ type: TokenRepository }] });
130
+
131
+ const authGuard = (_route, _state) => {
132
+ const authService = inject(AuthTokenService);
133
+ const router = inject(Router);
134
+ const environment = inject(ENVIRONMENT);
135
+ if (authService.isAuthenticated()) {
136
+ return true;
137
+ }
138
+ // Redirect to login page (configurable via environment)
139
+ router.navigate([environment.loginRoute]);
140
+ return false;
141
+ };
142
+
143
+ /**
144
+ * Generated bundle index. Do not edit.
145
+ */
146
+
147
+ export { AuthTokenService, TokenRepository, authGuard };
148
+ //# sourceMappingURL=acontplus-ng-auth.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"acontplus-ng-auth.mjs","sources":["../tmp-esm2022/lib/repositories/token.repository.js","../tmp-esm2022/lib/services/auth-token.service.js","../tmp-esm2022/lib/guards/auth.guard.js","../tmp-esm2022/acontplus-ng-auth.js"],"sourcesContent":["import { Injectable, inject } from '@angular/core';\nimport { jwtDecode } from 'jwt-decode';\nimport { ENVIRONMENT } from '@acontplus/ng-config';\nimport * as i0 from \"@angular/core\";\nexport class TokenRepository {\n environment = inject(ENVIRONMENT);\n saveTokens(tokens, rememberMe = false) {\n this.setToken(tokens.token, rememberMe);\n this.setRefreshToken(tokens.refreshToken, rememberMe);\n }\n getAccessToken() {\n return (localStorage.getItem(this.environment.tokenKey) ||\n sessionStorage.getItem(this.environment.tokenKey));\n }\n getRefreshToken() {\n return (localStorage.getItem(this.environment.refreshTokenKey) ||\n sessionStorage.getItem(this.environment.refreshTokenKey));\n }\n setToken(token, rememberMe = false) {\n if (rememberMe) {\n localStorage.setItem(this.environment.tokenKey, token);\n }\n else {\n sessionStorage.setItem(this.environment.tokenKey, token);\n }\n }\n setRefreshToken(refreshToken, rememberMe = false) {\n if (rememberMe) {\n localStorage.setItem(this.environment.refreshTokenKey, refreshToken);\n }\n else {\n sessionStorage.setItem(this.environment.refreshTokenKey, refreshToken);\n }\n }\n clearTokens() {\n localStorage.removeItem(this.environment.tokenKey);\n localStorage.removeItem(this.environment.refreshTokenKey);\n sessionStorage.removeItem(this.environment.tokenKey);\n sessionStorage.removeItem(this.environment.refreshTokenKey);\n }\n isAuthenticated() {\n const accessToken = this.getAccessToken();\n const refreshToken = this.getRefreshToken();\n if (!accessToken || !refreshToken) {\n return false;\n }\n try {\n const decodedAccessToken = jwtDecode(accessToken);\n const accessExpiration = Number(decodedAccessToken.exp);\n const currentTimeUTC = Math.floor(Date.now() / 1000);\n if (accessExpiration > currentTimeUTC) {\n return true;\n }\n return this.isRefreshTokenValid();\n }\n catch {\n return false;\n }\n }\n isRefreshTokenValid() {\n const refreshToken = this.getRefreshToken();\n if (!refreshToken) {\n return false;\n }\n try {\n return true; // Backend validates expiration\n }\n catch {\n return false;\n }\n }\n needsRefresh() {\n const accessToken = this.getAccessToken();\n if (!accessToken) {\n return false;\n }\n try {\n const decodedToken = jwtDecode(accessToken);\n const expiration = Number(decodedToken.exp);\n const currentTimeUTC = Math.floor(Date.now() / 1000);\n const timeUntilExpiry = expiration - currentTimeUTC;\n return timeUntilExpiry <= 300; // 5 minutes\n }\n catch {\n return false;\n }\n }\n getTokenPayload() {\n const token = this.getAccessToken();\n if (!token)\n return null;\n try {\n return jwtDecode(token);\n }\n catch (error) {\n return null;\n }\n }\n static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.3.2\", ngImport: i0, type: TokenRepository, deps: [], target: i0.ɵɵFactoryTarget.Injectable });\n static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: \"12.0.0\", version: \"20.3.2\", ngImport: i0, type: TokenRepository, providedIn: 'root' });\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.3.2\", ngImport: i0, type: TokenRepository, decorators: [{\n type: Injectable,\n args: [{\n providedIn: 'root',\n }]\n }] });\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"token.repository.js","sourceRoot":"","sources":["../../../../../../packages/ng-auth/src/lib/repositories/token.repository.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, inject } from '@angular/core';\nimport { jwtDecode } from 'jwt-decode';\nimport { AuthTokens } from '@acontplus/core';\nimport { ENVIRONMENT } from '@acontplus/ng-config';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class TokenRepository {\n  private environment = inject(ENVIRONMENT);\n\n  saveTokens(tokens: AuthTokens, rememberMe = false): void {\n    this.setToken(tokens.token, rememberMe);\n    this.setRefreshToken(tokens.refreshToken, rememberMe);\n  }\n\n  getAccessToken(): string | null {\n    return (\n      localStorage.getItem(this.environment.tokenKey) ||\n      sessionStorage.getItem(this.environment.tokenKey)\n    );\n  }\n\n  getRefreshToken(): string | null {\n    return (\n      localStorage.getItem(this.environment.refreshTokenKey) ||\n      sessionStorage.getItem(this.environment.refreshTokenKey)\n    );\n  }\n\n  setToken(token: string, rememberMe = false): void {\n    if (rememberMe) {\n      localStorage.setItem(this.environment.tokenKey, token);\n    } else {\n      sessionStorage.setItem(this.environment.tokenKey, token);\n    }\n  }\n\n  setRefreshToken(refreshToken: string, rememberMe = false): void {\n    if (rememberMe) {\n      localStorage.setItem(this.environment.refreshTokenKey, refreshToken);\n    } else {\n      sessionStorage.setItem(this.environment.refreshTokenKey, refreshToken);\n    }\n  }\n\n  clearTokens(): void {\n    localStorage.removeItem(this.environment.tokenKey);\n    localStorage.removeItem(this.environment.refreshTokenKey);\n    sessionStorage.removeItem(this.environment.tokenKey);\n    sessionStorage.removeItem(this.environment.refreshTokenKey);\n  }\n\n  isAuthenticated(): boolean {\n    const accessToken = this.getAccessToken();\n    const refreshToken = this.getRefreshToken();\n\n    if (!accessToken || !refreshToken) {\n      return false;\n    }\n\n    try {\n      const decodedAccessToken = jwtDecode(accessToken);\n      const accessExpiration = Number(decodedAccessToken.exp);\n      const currentTimeUTC = Math.floor(Date.now() / 1000);\n\n      if (accessExpiration > currentTimeUTC) {\n        return true;\n      }\n\n      return this.isRefreshTokenValid();\n    } catch {\n      return false;\n    }\n  }\n\n  private isRefreshTokenValid(): boolean {\n    const refreshToken = this.getRefreshToken();\n    if (!refreshToken) {\n      return false;\n    }\n\n    try {\n      return true; // Backend validates expiration\n    } catch {\n      return false;\n    }\n  }\n\n  needsRefresh(): boolean {\n    const accessToken = this.getAccessToken();\n    if (!accessToken) {\n      return false;\n    }\n\n    try {\n      const decodedToken = jwtDecode(accessToken);\n      const expiration = Number(decodedToken.exp);\n      const currentTimeUTC = Math.floor(Date.now() / 1000);\n      const timeUntilExpiry = expiration - currentTimeUTC;\n\n      return timeUntilExpiry <= 300; // 5 minutes\n    } catch {\n      return false;\n    }\n  }\n\n  getTokenPayload(): any {\n    const token = this.getAccessToken();\n    if (!token) return null;\n\n    try {\n      return jwtDecode(token);\n    } catch (error) {\n      return null;\n    }\n  }\n}\n"]}","import { Injectable } from '@angular/core';\nimport * as i0 from \"@angular/core\";\nimport * as i1 from \"../repositories/token.repository\";\nexport class AuthTokenService {\n tokenRepository;\n constructor(tokenRepository) {\n this.tokenRepository = tokenRepository;\n }\n getToken() {\n return this.tokenRepository.getAccessToken();\n }\n isAuthenticated() {\n return this.tokenRepository.isAuthenticated();\n }\n static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.3.2\", ngImport: i0, type: AuthTokenService, deps: [{ token: i1.TokenRepository }], target: i0.ɵɵFactoryTarget.Injectable });\n static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: \"12.0.0\", version: \"20.3.2\", ngImport: i0, type: AuthTokenService, providedIn: 'root' });\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.3.2\", ngImport: i0, type: AuthTokenService, decorators: [{\n type: Injectable,\n args: [{ providedIn: 'root' }]\n }], ctorParameters: () => [{ type: i1.TokenRepository }] });\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC10b2tlbi5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvbmctYXV0aC9zcmMvbGliL3NlcnZpY2VzL2F1dGgtdG9rZW4uc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFLM0MsTUFBTSxPQUFPLGdCQUFnQjtJQUNQO0lBQXBCLFlBQW9CLGVBQWdDO1FBQWhDLG9CQUFlLEdBQWYsZUFBZSxDQUFpQjtJQUFHLENBQUM7SUFFeEQsUUFBUTtRQUNOLE9BQU8sSUFBSSxDQUFDLGVBQWUsQ0FBQyxjQUFjLEVBQUUsQ0FBQztJQUMvQyxDQUFDO0lBRUQsZUFBZTtRQUNiLE9BQU8sSUFBSSxDQUFDLGVBQWUsQ0FBQyxlQUFlLEVBQUUsQ0FBQztJQUNoRCxDQUFDO3VHQVRVLGdCQUFnQjsyR0FBaEIsZ0JBQWdCLGNBREgsTUFBTTs7MkZBQ25CLGdCQUFnQjtrQkFENUIsVUFBVTttQkFBQyxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBJVG9rZW5Qcm92aWRlciB9IGZyb20gJ0BhY29udHBsdXMvbmctaW5mcmFzdHJ1Y3R1cmUnO1xuaW1wb3J0IHsgVG9rZW5SZXBvc2l0b3J5IH0gZnJvbSAnLi4vcmVwb3NpdG9yaWVzL3Rva2VuLnJlcG9zaXRvcnknO1xuXG5ASW5qZWN0YWJsZSh7IHByb3ZpZGVkSW46ICdyb290JyB9KVxuZXhwb3J0IGNsYXNzIEF1dGhUb2tlblNlcnZpY2UgaW1wbGVtZW50cyBJVG9rZW5Qcm92aWRlciB7XG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgdG9rZW5SZXBvc2l0b3J5OiBUb2tlblJlcG9zaXRvcnkpIHt9XG5cbiAgZ2V0VG9rZW4oKTogc3RyaW5nIHwgbnVsbCB7XG4gICAgcmV0dXJuIHRoaXMudG9rZW5SZXBvc2l0b3J5LmdldEFjY2Vzc1Rva2VuKCk7XG4gIH1cblxuICBpc0F1dGhlbnRpY2F0ZWQoKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHRoaXMudG9rZW5SZXBvc2l0b3J5LmlzQXV0aGVudGljYXRlZCgpO1xuICB9XG59XG4iXX0=","import { inject } from '@angular/core';\nimport { Router } from '@angular/router';\nimport { AuthTokenService } from '../services/auth-token.service';\nimport { ENVIRONMENT } from '@acontplus/ng-config';\nexport const authGuard = (_route, _state) => {\n const authService = inject(AuthTokenService);\n const router = inject(Router);\n const environment = inject(ENVIRONMENT);\n if (authService.isAuthenticated()) {\n return true;\n }\n // Redirect to login page (configurable via environment)\n router.navigate([environment.loginRoute]);\n return false;\n};\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC5ndWFyZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL25nLWF1dGgvc3JjL2xpYi9ndWFyZHMvYXV0aC5ndWFyZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBaUIsTUFBTSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDeEQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDbEUsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBRW5ELE1BQU0sQ0FBQyxNQUFNLFNBQVMsR0FBa0IsQ0FBQyxNQUFNLEVBQUUsTUFBTSxFQUFFLEVBQUU7SUFDekQsTUFBTSxXQUFXLEdBQUcsTUFBTSxDQUFDLGdCQUFnQixDQUFDLENBQUM7SUFDN0MsTUFBTSxNQUFNLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQzlCLE1BQU0sV0FBVyxHQUFHLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQztJQUV4QyxJQUFJLFdBQVcsQ0FBQyxlQUFlLEVBQUUsRUFBRSxDQUFDO1FBQ2xDLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVELHdEQUF3RDtJQUN4RCxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUMsV0FBVyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUM7SUFDMUMsT0FBTyxLQUFLLENBQUM7QUFDZixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENhbkFjdGl2YXRlRm4sIFJvdXRlciB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5pbXBvcnQgeyBBdXRoVG9rZW5TZXJ2aWNlIH0gZnJvbSAnLi4vc2VydmljZXMvYXV0aC10b2tlbi5zZXJ2aWNlJztcbmltcG9ydCB7IEVOVklST05NRU5UIH0gZnJvbSAnQGFjb250cGx1cy9uZy1jb25maWcnO1xuXG5leHBvcnQgY29uc3QgYXV0aEd1YXJkOiBDYW5BY3RpdmF0ZUZuID0gKF9yb3V0ZSwgX3N0YXRlKSA9PiB7XG4gIGNvbnN0IGF1dGhTZXJ2aWNlID0gaW5qZWN0KEF1dGhUb2tlblNlcnZpY2UpO1xuICBjb25zdCByb3V0ZXIgPSBpbmplY3QoUm91dGVyKTtcbiAgY29uc3QgZW52aXJvbm1lbnQgPSBpbmplY3QoRU5WSVJPTk1FTlQpO1xuXG4gIGlmIChhdXRoU2VydmljZS5pc0F1dGhlbnRpY2F0ZWQoKSkge1xuICAgIHJldHVybiB0cnVlO1xuICB9XG5cbiAgLy8gUmVkaXJlY3QgdG8gbG9naW4gcGFnZSAoY29uZmlndXJhYmxlIHZpYSBlbnZpcm9ubWVudClcbiAgcm91dGVyLm5hdmlnYXRlKFtlbnZpcm9ubWVudC5sb2dpblJvdXRlXSk7XG4gIHJldHVybiBmYWxzZTtcbn07XG4iXX0=","/**\n * Generated bundle index. Do not edit.\n */\nexport * from './index';\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNvbnRwbHVzLW5nLWF1dGguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9uZy1hdXRoL3NyYy9hY29udHBsdXMtbmctYXV0aC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ=="],"names":["i1.TokenRepository"],"mappings":"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"}
package/index.d.ts ADDED
@@ -0,0 +1,34 @@
1
+ import { ITokenProvider } from '@acontplus/ng-infrastructure';
2
+ export { ITokenProvider, TOKEN_PROVIDER } from '@acontplus/ng-infrastructure';
3
+ import { CanActivateFn } from '@angular/router';
4
+ import { AuthTokens } from '@acontplus/core';
5
+ import * as i0 from '@angular/core';
6
+
7
+ declare const authGuard: CanActivateFn;
8
+
9
+ declare class TokenRepository {
10
+ private environment;
11
+ saveTokens(tokens: AuthTokens, rememberMe?: boolean): void;
12
+ getAccessToken(): string | null;
13
+ getRefreshToken(): string | null;
14
+ setToken(token: string, rememberMe?: boolean): void;
15
+ setRefreshToken(refreshToken: string, rememberMe?: boolean): void;
16
+ clearTokens(): void;
17
+ isAuthenticated(): boolean;
18
+ private isRefreshTokenValid;
19
+ needsRefresh(): boolean;
20
+ getTokenPayload(): any;
21
+ static ɵfac: i0.ɵɵFactoryDeclaration<TokenRepository, never>;
22
+ static ɵprov: i0.ɵɵInjectableDeclaration<TokenRepository>;
23
+ }
24
+
25
+ declare class AuthTokenService implements ITokenProvider {
26
+ private tokenRepository;
27
+ constructor(tokenRepository: TokenRepository);
28
+ getToken(): string | null;
29
+ isAuthenticated(): boolean;
30
+ static ɵfac: i0.ɵɵFactoryDeclaration<AuthTokenService, never>;
31
+ static ɵprov: i0.ɵɵInjectableDeclaration<AuthTokenService>;
32
+ }
33
+
34
+ export { AuthTokenService, TokenRepository, authGuard };
package/package.json ADDED
@@ -0,0 +1,67 @@
1
+ {
2
+ "name": "@acontplus/ng-auth",
3
+ "version": "1.0.0",
4
+ "description": "Acontplus Angular Authentication Module",
5
+ "dependencies": {
6
+ "@acontplus/ng-infrastructure": "^1.0.0",
7
+ "@acontplus/ng-config": "^1.0.0",
8
+ "tslib": "^2.3.0"
9
+ },
10
+ "peerDependencies": {
11
+ "@acontplus/core": "^1.0.12",
12
+ "@angular/common": "^20.3.2",
13
+ "@angular/core": "^20.3.2",
14
+ "@angular/router": "^20.3.2"
15
+ },
16
+ "sideEffects": false,
17
+ "main": "fesm2022/acontplus-ng-auth.mjs",
18
+ "module": "fesm2022/acontplus-ng-auth.mjs",
19
+ "typings": "index.d.ts",
20
+ "files": [
21
+ "index.d.ts",
22
+ "*.d.ts",
23
+ "**/*.d.ts",
24
+ "fesm2022/**/*"
25
+ ],
26
+ "engines": {
27
+ "node": ">=18.0.0"
28
+ },
29
+ "publishConfig": {
30
+ "access": "public",
31
+ "registry": "https://registry.npmjs.org/"
32
+ },
33
+ "keywords": [
34
+ "acontplus",
35
+ "angular",
36
+ "authentication",
37
+ "jwt",
38
+ "guards",
39
+ "typescript",
40
+ "frontend",
41
+ "library"
42
+ ],
43
+ "author": "Emilio Senguana <sengua2017@gmail.com>",
44
+ "license": "MIT",
45
+ "bugs": {
46
+ "url": "https://github.com/Acontplus-S-A-S/acontplus-libs/issues"
47
+ },
48
+ "homepage": "https://github.com/Acontplus-S-A-S/acontplus-libs#readme",
49
+ "repository": {
50
+ "type": "git",
51
+ "url": "git+https://github.com/Acontplus-S-A-S/acontplus-libs.git"
52
+ },
53
+ "release": {
54
+ "branches": [
55
+ "main"
56
+ ]
57
+ },
58
+ "exports": {
59
+ "./package.json": {
60
+ "default": "./package.json"
61
+ },
62
+ ".": {
63
+ "types": "./index.d.ts",
64
+ "default": "./fesm2022/acontplus-ng-auth.mjs"
65
+ }
66
+ }
67
+ }