tango-app-ui-auth 3.5.0-beta.8 → 3.5.0-beta.9
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/esm2022/lib/components/tango-auth-login/tango-auth-login.component.mjs +17 -5
- package/esm2022/lib/guards/auth.guard.mjs +27 -8
- package/esm2022/lib/services/auth.service.mjs +56 -6
- package/fesm2022/tango-app-ui-auth.mjs +97 -16
- package/fesm2022/tango-app-ui-auth.mjs.map +1 -1
- package/lib/guards/auth.guard.d.ts +2 -2
- package/lib/services/auth.service.d.ts +5 -1
- package/package.json +1 -1
@@ -18,14 +18,33 @@ export class AuthGuard {
|
|
18
18
|
}
|
19
19
|
});
|
20
20
|
}
|
21
|
-
canActivate(route, state) {
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
21
|
+
// canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot) {
|
22
|
+
// // const currentUser = localStorage.getItem('isLoggedIn');
|
23
|
+
// const currentUser = localStorage.getItem(this.authlocalStorageToken);
|
24
|
+
// if (currentUser) {
|
25
|
+
// // this.route.navigate(['/manage']);
|
26
|
+
// return true;
|
27
|
+
// } else {
|
28
|
+
// this.route.navigate(['/auth/login']);
|
29
|
+
// return false;
|
30
|
+
// }
|
31
|
+
// }
|
32
|
+
canActivate() {
|
33
|
+
const tokenStr = this.authService.getCookie(this.authlocalStorageToken);
|
34
|
+
if (!tokenStr) {
|
35
|
+
this.route.navigate(['/auth/login']);
|
36
|
+
return false;
|
37
|
+
}
|
38
|
+
try {
|
39
|
+
const tokenData = JSON.parse(tokenStr);
|
40
|
+
const isValid = !!tokenData?.authenticationToken;
|
41
|
+
if (!isValid) {
|
42
|
+
this.route.navigate(['/auth/login']);
|
43
|
+
}
|
44
|
+
return isValid;
|
27
45
|
}
|
28
|
-
|
46
|
+
catch (e) {
|
47
|
+
console.error('Invalid token in cookie', e);
|
29
48
|
this.route.navigate(['/auth/login']);
|
30
49
|
return false;
|
31
50
|
}
|
@@ -37,4 +56,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
37
56
|
type: Injectable,
|
38
57
|
args: [{ providedIn: 'root' }]
|
39
58
|
}], ctorParameters: () => [{ type: i1.AuthService }, { type: i2.GlobalStateService }, { type: i3.Router }] });
|
40
|
-
//# sourceMappingURL=data:application/json;base64,
|
59
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC5ndWFyZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RhbmdvLWF1dGgvc3JjL2xpYi9ndWFyZHMvYXV0aC5ndWFyZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7OztBQU8zQyxNQUFNLE9BQU8sU0FBUztJQUVBO0lBQWlDO0lBQzNDO0lBRkYscUJBQXFCLENBQUs7SUFDbEMsWUFBb0IsV0FBd0IsRUFBUyxFQUFxQixFQUNoRSxLQUFhO1FBREgsZ0JBQVcsR0FBWCxXQUFXLENBQWE7UUFBUyxPQUFFLEdBQUYsRUFBRSxDQUFtQjtRQUNoRSxVQUFLLEdBQUwsS0FBSyxDQUFRO1FBQ3JCLElBQUksQ0FBQyxFQUFFLENBQUMsV0FBVyxDQUFDLFNBQVMsQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFO1lBQ3BDLElBQUksR0FBRyxFQUFFO2dCQUNaLElBQUksQ0FBQyxxQkFBcUIsR0FBRyxHQUFHLEdBQUcsQ0FBQyxVQUFVLElBQUksR0FBRyxDQUFDLFlBQVksRUFBRSxDQUFDO2FBQ2pFO1FBQ0gsQ0FBQyxDQUFDLENBQUE7SUFDSixDQUFDO0lBQ0QsMkVBQTJFO0lBRTNFLCtEQUErRDtJQUMvRCwwRUFBMEU7SUFDMUUsdUJBQXVCO0lBQ3ZCLHFEQUFxRDtJQUNyRCx1QkFBdUI7SUFDdkIsYUFBYTtJQUNiLHNEQUFzRDtJQUV0RCxzQkFBc0I7SUFDdEIsTUFBTTtJQUNOLElBQUk7SUFFSixXQUFXO1FBQ1QsTUFBTSxRQUFRLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLHFCQUFxQixDQUFDLENBQUM7UUFFeEUsSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUNiLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQztZQUNyQyxPQUFPLEtBQUssQ0FBQztTQUNkO1FBRUQsSUFBSTtZQUNGLE1BQU0sU0FBUyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLENBQUM7WUFDdkMsTUFBTSxPQUFPLEdBQUcsQ0FBQyxDQUFDLFNBQVMsRUFBRSxtQkFBbUIsQ0FBQztZQUVqRCxJQUFJLENBQUMsT0FBTyxFQUFFO2dCQUNaLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQzthQUN0QztZQUVELE9BQU8sT0FBTyxDQUFDO1NBQ2hCO1FBQUMsT0FBTyxDQUFDLEVBQUU7WUFDVixPQUFPLENBQUMsS0FBSyxDQUFDLHlCQUF5QixFQUFFLENBQUMsQ0FBQyxDQUFDO1lBQzVDLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQztZQUNyQyxPQUFPLEtBQUssQ0FBQztTQUNkO0lBQ0gsQ0FBQzt3R0E5Q1UsU0FBUzs0R0FBVCxTQUFTLGNBREksTUFBTTs7NEZBQ25CLFNBQVM7a0JBRHJCLFVBQVU7bUJBQUMsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBBY3RpdmF0ZWRSb3V0ZVNuYXBzaG90LCBSb3V0ZXIsIFJvdXRlclN0YXRlU25hcHNob3QgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xyXG5pbXBvcnQgeyBBdXRoU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL2F1dGguc2VydmljZSc7XHJcbmltcG9ydCB7IEdsb2JhbFN0YXRlU2VydmljZSB9IGZyb20gJ3RhbmdvLWFwcC11aS1nbG9iYWwnO1xyXG5cclxuXHJcbkBJbmplY3RhYmxlKHsgcHJvdmlkZWRJbjogJ3Jvb3QnIH0pXHJcbmV4cG9ydCBjbGFzcyBBdXRoR3VhcmQgIHtcclxuICBwcml2YXRlIGF1dGhsb2NhbFN0b3JhZ2VUb2tlbjphbnk7XHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBhdXRoU2VydmljZTogQXV0aFNlcnZpY2UscHJpdmF0ZSBnczpHbG9iYWxTdGF0ZVNlcnZpY2UsXHJcbiAgICBwcml2YXRlIHJvdXRlOiBSb3V0ZXIpIHtcclxuICAgIHRoaXMuZ3MuZW52aXJvbm1lbnQuc3Vic2NyaWJlKChlbnYpID0+IHtcclxuICAgICAgaWYgKGVudikge1xyXG4gICB0aGlzLmF1dGhsb2NhbFN0b3JhZ2VUb2tlbiA9IGAke2Vudi5hcHBWZXJzaW9ufS0ke2Vudi5VU0VSREFUQV9LRVl9YDtcclxuICAgICAgfVxyXG4gICAgfSlcclxuICB9XHJcbiAgLy8gY2FuQWN0aXZhdGUocm91dGU6IEFjdGl2YXRlZFJvdXRlU25hcHNob3QsIHN0YXRlOiBSb3V0ZXJTdGF0ZVNuYXBzaG90KSB7XHJcblxyXG4gIC8vICAgLy8gY29uc3QgY3VycmVudFVzZXIgPSBsb2NhbFN0b3JhZ2UuZ2V0SXRlbSgnaXNMb2dnZWRJbicpO1xyXG4gIC8vICAgY29uc3QgY3VycmVudFVzZXIgPSBsb2NhbFN0b3JhZ2UuZ2V0SXRlbSh0aGlzLmF1dGhsb2NhbFN0b3JhZ2VUb2tlbik7XHJcbiAgLy8gICBpZiAoY3VycmVudFVzZXIpIHtcclxuICAvLyAgICAgICAgICAgLy8gdGhpcy5yb3V0ZS5uYXZpZ2F0ZShbJy9tYW5hZ2UnXSk7ICAgIFxyXG4gIC8vICAgICAgIHJldHVybiB0cnVlOyAgXHJcbiAgLy8gICB9IGVsc2Uge1xyXG4gIC8vICAgICAgICAgICB0aGlzLnJvdXRlLm5hdmlnYXRlKFsnL2F1dGgvbG9naW4nXSk7ICAgIFxyXG5cclxuICAvLyAgICAgICByZXR1cm4gZmFsc2U7XHJcbiAgLy8gICB9XHJcbiAgLy8gfVxyXG5cclxuICBjYW5BY3RpdmF0ZSgpOiBib29sZWFuIHtcclxuICAgIGNvbnN0IHRva2VuU3RyID0gdGhpcy5hdXRoU2VydmljZS5nZXRDb29raWUodGhpcy5hdXRobG9jYWxTdG9yYWdlVG9rZW4pO1xyXG5cclxuICAgIGlmICghdG9rZW5TdHIpIHtcclxuICAgICAgdGhpcy5yb3V0ZS5uYXZpZ2F0ZShbJy9hdXRoL2xvZ2luJ10pO1xyXG4gICAgICByZXR1cm4gZmFsc2U7XHJcbiAgICB9XHJcblxyXG4gICAgdHJ5IHtcclxuICAgICAgY29uc3QgdG9rZW5EYXRhID0gSlNPTi5wYXJzZSh0b2tlblN0cik7XHJcbiAgICAgIGNvbnN0IGlzVmFsaWQgPSAhIXRva2VuRGF0YT8uYXV0aGVudGljYXRpb25Ub2tlbjtcclxuXHJcbiAgICAgIGlmICghaXNWYWxpZCkge1xyXG4gICAgICAgIHRoaXMucm91dGUubmF2aWdhdGUoWycvYXV0aC9sb2dpbiddKTtcclxuICAgICAgfVxyXG5cclxuICAgICAgcmV0dXJuIGlzVmFsaWQ7XHJcbiAgICB9IGNhdGNoIChlKSB7XHJcbiAgICAgIGNvbnNvbGUuZXJyb3IoJ0ludmFsaWQgdG9rZW4gaW4gY29va2llJywgZSk7XHJcbiAgICAgIHRoaXMucm91dGUubmF2aWdhdGUoWycvYXV0aC9sb2dpbiddKTtcclxuICAgICAgcmV0dXJuIGZhbHNlO1xyXG4gICAgfVxyXG4gIH1cclxufVxyXG4iXX0=
|
@@ -1,3 +1,4 @@
|
|
1
|
+
import { HttpHeaders } from "@angular/common/http";
|
1
2
|
import { Injectable } from "@angular/core";
|
2
3
|
import { BehaviorSubject, catchError, map, of, throwError, } from "rxjs";
|
3
4
|
import * as i0 from "@angular/core";
|
@@ -33,12 +34,45 @@ export class AuthService {
|
|
33
34
|
}
|
34
35
|
});
|
35
36
|
}
|
37
|
+
base64Encode(str) {
|
38
|
+
return btoa(encodeURIComponent(str));
|
39
|
+
}
|
40
|
+
base64Decode(str) {
|
41
|
+
return decodeURIComponent(atob(str));
|
42
|
+
}
|
43
|
+
setCookie(name, value, days = 1) {
|
44
|
+
const encodedValue = this.base64Encode(value);
|
45
|
+
const expires = new Date(Date.now() + days * 864e5).toUTCString();
|
46
|
+
document.cookie = `${name}=${encodedValue}; expires=${expires}; path=/; Secure; SameSite=Strict`;
|
47
|
+
}
|
48
|
+
getCookie(name) {
|
49
|
+
const match = document.cookie.match(new RegExp(`(^| )${name}=([^;]+)`));
|
50
|
+
return match ? this.base64Decode(match[2]) : null;
|
51
|
+
}
|
52
|
+
// getHeaders() {
|
53
|
+
// const user: any = JSON.parse(
|
54
|
+
// localStorage.getItem(this.authlocalStorageToken) || "{}"
|
55
|
+
// );
|
56
|
+
// const headers = {
|
57
|
+
// Authorization: "Bearer " + user.authenticationToken,
|
58
|
+
// };
|
59
|
+
// return headers;
|
60
|
+
// }
|
36
61
|
getHeaders() {
|
37
|
-
const
|
38
|
-
|
39
|
-
|
62
|
+
const userTokenStr = this.getCookie(this.authlocalStorageToken);
|
63
|
+
let token = '';
|
64
|
+
if (userTokenStr) {
|
65
|
+
try {
|
66
|
+
const user = JSON.parse(userTokenStr);
|
67
|
+
token = user?.authenticationToken || '';
|
68
|
+
}
|
69
|
+
catch (e) {
|
70
|
+
console.error('Invalid token JSON in cookie');
|
71
|
+
}
|
72
|
+
}
|
73
|
+
return {
|
74
|
+
Authorization: 'Bearer ' + token
|
40
75
|
};
|
41
|
-
return headers;
|
42
76
|
}
|
43
77
|
logout() {
|
44
78
|
localStorage.removeItem(this.authlocalStorageToken);
|
@@ -71,16 +105,32 @@ export class AuthService {
|
|
71
105
|
return this.http.post(`${this.userApiUrl}/login`, data);
|
72
106
|
}
|
73
107
|
userProfileDet() {
|
108
|
+
// debugger
|
74
109
|
const user = localStorage.getItem("user-info");
|
75
110
|
if (user)
|
76
111
|
return of(JSON.parse(user));
|
112
|
+
// console.log(this.getHeaders())
|
113
|
+
const headers = new HttpHeaders(this.getHeaders());
|
77
114
|
return this.http
|
78
|
-
.get(`${this.userApiUrl}/profileV2`, { headers:
|
115
|
+
.get(`${this.userApiUrl}/profileV2`, { headers: headers })
|
79
116
|
.pipe(map((response) => {
|
80
117
|
localStorage.setItem("user-info", JSON.stringify(response.data));
|
81
118
|
return response;
|
82
119
|
}), catchError(this.handleError));
|
83
120
|
}
|
121
|
+
// userProfileDet(): Observable<any> {
|
122
|
+
// const userStr = this.getCookie("user-info");
|
123
|
+
// if (userStr) return of(JSON.parse(userStr));
|
124
|
+
// return this.http
|
125
|
+
// .get(`${this.userApiUrl}/profileV2`, { headers: this.getHeaders() })
|
126
|
+
// .pipe(
|
127
|
+
// map((response: any) => {
|
128
|
+
// this.setCookie("user-info", JSON.stringify(response.data), 7);
|
129
|
+
// return response;
|
130
|
+
// }),
|
131
|
+
// catchError(this.handleError)
|
132
|
+
// );
|
133
|
+
// }
|
84
134
|
getAllCountries() {
|
85
135
|
return this.http.get(`${this.middlewareApiUrl}/get-countries`);
|
86
136
|
}
|
@@ -114,4 +164,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
114
164
|
providedIn: "root",
|
115
165
|
}]
|
116
166
|
}], ctorParameters: () => [{ type: i1.Router }, { type: i2.HttpClient }, { type: i3.GlobalStateService }] });
|
117
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth.service.js","sourceRoot":"","sources":["../../../../../projects/tango-auth/src/lib/services/auth.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from \"@angular/common/http\";\r\nimport { Injectable } from \"@angular/core\";\r\nimport { Router } from \"@angular/router\";\r\nimport {\r\n  BehaviorSubject,\r\n  Observable,\r\n  catchError,\r\n  map,\r\n  of,\r\n  throwError,\r\n} from \"rxjs\";\r\nimport { GlobalStateService } from \"tango-app-ui-global\";\r\n\r\n@Injectable({\r\n  providedIn: \"root\",\r\n})\r\nexport class AuthService {\r\n  aboutFormData = new BehaviorSubject<any>(null);\r\n  pricingFormData = new BehaviorSubject<any>(null);\r\n  currentUserSubject = new BehaviorSubject<any>(null);\r\n  leadApiUrl: string = \"\";\r\n  middlewareApiUrl: string = \"\";\r\n  userApiUrl: string = \"\";\r\n  authlocalStorageToken: string;\r\n  paymentSubscriptionApiUrl: string;\r\n  get currentUserValue(): any {\r\n    return this.currentUserSubject.value;\r\n  }\r\n  constructor(\r\n    private router: Router,\r\n    private http: HttpClient,\r\n    private gs: GlobalStateService\r\n  ) {\r\n    this.gs.environment.subscribe((env) => {\r\n      if (env) {\r\n        this.leadApiUrl = env.leadApiUrl;\r\n        this.middlewareApiUrl = env.middlewareApiUrl;\r\n        this.paymentSubscriptionApiUrl = env.paymentSubscriptionApiUrl;\r\n        (this.userApiUrl = env.userApiUrl),\r\n          (this.authlocalStorageToken = `${env.appVersion}-${env.USERDATA_KEY}`);\r\n      }\r\n    });\r\n  }\r\n\r\n  getHeaders() {\r\n    const user: any = JSON.parse(\r\n      localStorage.getItem(this.authlocalStorageToken) || \"{}\"\r\n    );\r\n    const headers = {\r\n      Authorization: \"Bearer \" + user.authenticationToken,\r\n    };\r\n\r\n    return headers;\r\n  }\r\n\r\n  logout() {\r\n    localStorage.removeItem(this.authlocalStorageToken);\r\n    this.router.navigate([\"/auth/login\"], {\r\n      queryParams: {},\r\n    });\r\n  }\r\n\r\n  sendSignupOtp(data: any): Observable<any> {\r\n    return this.http.post(`${this.middlewareApiUrl}/signup-otp`, data);\r\n  }\r\n\r\n  signup(data: any): Observable<any> {\r\n    return this.http.post(`${this.leadApiUrl}/signup`, data);\r\n  }\r\n\r\n  requestCallback(data: any): Observable<any> {\r\n    return this.http.post(`${this.middlewareApiUrl}/request-callback`, data);\r\n  }\r\n\r\n  isClientnameTaken(data: any): Observable<any> {\r\n    return this.http.post(`${this.leadApiUrl}/isClientExist`, data);\r\n  }\r\n\r\n  isEmailTaken(data: string): Observable<any> {\r\n    return this.http.get(`${this.leadApiUrl}/isExists?corporateEmail=${data}`);\r\n  }\r\n\r\n  isMobileTaken(data: string): Observable<any> {\r\n    return this.http.get(`${this.leadApiUrl}/isExists?mobileNumber=${data}`);\r\n  }\r\n\r\n  getCountryCodes(): Observable<any> {\r\n    return this.http.get(`${this.middlewareApiUrl}/country-code`);\r\n  }\r\n\r\n  login(data: any): Observable<any> {\r\n    return this.http.post(`${this.userApiUrl}/login`, data);\r\n  }\r\n\r\n  userProfileDet(): Observable<any> {\r\n    const user: any = localStorage.getItem(\"user-info\");\r\n    if (user) return of(JSON.parse(user));\r\n    return this.http\r\n      .get(`${this.userApiUrl}/profileV2`, { headers: this.getHeaders() })\r\n      .pipe(\r\n        map((response: any) => {\r\n          localStorage.setItem(\"user-info\", JSON.stringify(response.data));\r\n          return response;\r\n        }),\r\n        catchError(this.handleError)\r\n      );\r\n  }\r\n\r\n  getAllCountries(): Observable<any> {\r\n    return this.http.get(`${this.middlewareApiUrl}/get-countries`);\r\n  }\r\n\r\n  handleError(res: any) {\r\n    return throwError(res.error);\r\n  }\r\n\r\n  getPricing(data: any): Observable<any> {\r\n    return this.http.post(\r\n      `${this.paymentSubscriptionApiUrl}/basePricing`,\r\n      data\r\n    );\r\n  }\r\n\r\n  forgotPasswordTrigger(params: any): Observable<any> {\r\n    return this.http\r\n      .get(`${this.userApiUrl}/forgot-password-email`, { params: params })\r\n      .pipe(\r\n        map((response: any) => response),\r\n        catchError(this.handleError)\r\n      );\r\n  }\r\n\r\n  forgotPassword(data: any): Observable<any> {\r\n    return this.http\r\n    .post(`${this.userApiUrl}/forgot-password-update`, data )\r\n    .pipe(\r\n      map((response: any) => response),\r\n      catchError(this.handleError)\r\n    );\r\n  }\r\n  termsAndConditionUpdate(data: any): Observable<any> {\r\n    return this.http\r\n    .post(`${this.userApiUrl}/termsAndConditionUpdate`, data )\r\n    .pipe(\r\n      map((response: any) => response),\r\n      catchError(this.handleError)\r\n    );\r\n  }\r\n  \r\n}\r\n"]}
|
167
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth.service.js","sourceRoot":"","sources":["../../../../../projects/tango-auth/src/lib/services/auth.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAc,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAC/D,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAE3C,OAAO,EACL,eAAe,EAEf,UAAU,EACV,GAAG,EACH,EAAE,EACF,UAAU,GACX,MAAM,MAAM,CAAC;;;;;AAMd,MAAM,OAAO,WAAW;IAaZ;IACA;IACA;IAdV,aAAa,GAAG,IAAI,eAAe,CAAM,IAAI,CAAC,CAAC;IAC/C,eAAe,GAAG,IAAI,eAAe,CAAM,IAAI,CAAC,CAAC;IACjD,kBAAkB,GAAG,IAAI,eAAe,CAAM,IAAI,CAAC,CAAC;IACpD,UAAU,GAAW,EAAE,CAAC;IACxB,gBAAgB,GAAW,EAAE,CAAC;IAC9B,UAAU,GAAW,EAAE,CAAC;IACxB,qBAAqB,CAAS;IAC9B,yBAAyB,CAAS;IAClC,IAAI,gBAAgB;QAClB,OAAO,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC;IACvC,CAAC;IACD,YACU,MAAc,EACd,IAAgB,EAChB,EAAsB;QAFtB,WAAM,GAAN,MAAM,CAAQ;QACd,SAAI,GAAJ,IAAI,CAAY;QAChB,OAAE,GAAF,EAAE,CAAoB;QAE9B,IAAI,CAAC,EAAE,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,GAAG,EAAE,EAAE;YACpC,IAAI,GAAG,EAAE;gBACP,IAAI,CAAC,UAAU,GAAG,GAAG,CAAC,UAAU,CAAC;gBACjC,IAAI,CAAC,gBAAgB,GAAG,GAAG,CAAC,gBAAgB,CAAC;gBAC7C,IAAI,CAAC,yBAAyB,GAAG,GAAG,CAAC,yBAAyB,CAAC;gBAC/D,CAAC,IAAI,CAAC,UAAU,GAAG,GAAG,CAAC,UAAU,CAAC;oBAChC,CAAC,IAAI,CAAC,qBAAqB,GAAG,GAAG,GAAG,CAAC,UAAU,IAAI,GAAG,CAAC,YAAY,EAAE,CAAC,CAAC;aAC1E;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IACO,YAAY,CAAC,GAAQ;QAC7B,OAAO,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC,CAAC;IACvC,CAAC;IAEO,YAAY,CAAC,GAAQ;QAC3B,OAAO,kBAAkB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;IACvC,CAAC;IACD,SAAS,CAAC,IAAY,EAAE,KAAa,EAAE,OAAe,CAAC;QACrD,MAAM,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;QAC9C,MAAM,OAAO,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,GAAG,KAAK,CAAC,CAAC,WAAW,EAAE,CAAC;QAClE,QAAQ,CAAC,MAAM,GAAG,GAAG,IAAI,IAAI,YAAY,aAAa,OAAO,mCAAmC,CAAC;IACnG,CAAC;IAED,SAAS,CAAC,IAAY;QACpB,MAAM,KAAK,GAAG,QAAQ,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,MAAM,CAAC,QAAQ,IAAI,UAAU,CAAC,CAAC,CAAC;QACxE,OAAO,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IACpD,CAAC;IACC,iBAAiB;IACjB,kCAAkC;IAClC,+DAA+D;IAC/D,OAAO;IACP,sBAAsB;IACtB,2DAA2D;IAC3D,OAAO;IAEP,oBAAoB;IACpB,IAAI;IACN,UAAU;QACR,MAAM,YAAY,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;QAChE,IAAI,KAAK,GAAG,EAAE,CAAC;QAEf,IAAI,YAAY,EAAE;YAChB,IAAI;gBACF,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;gBACtC,KAAK,GAAG,IAAI,EAAE,mBAAmB,IAAI,EAAE,CAAC;aACzC;YAAC,OAAO,CAAC,EAAE;gBACV,OAAO,CAAC,KAAK,CAAC,8BAA8B,CAAC,CAAC;aAC/C;SACF;QAED,OAAO;YACL,aAAa,EAAE,SAAS,GAAG,KAAK;SACjC,CAAC;IACJ,CAAC;IACC,MAAM;QACJ,YAAY,CAAC,UAAU,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;QACpD,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,aAAa,CAAC,EAAE;YACpC,WAAW,EAAE,EAAE;SAChB,CAAC,CAAC;IACL,CAAC;IAED,aAAa,CAAC,IAAS;QACrB,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,gBAAgB,aAAa,EAAE,IAAI,CAAC,CAAC;IACrE,CAAC;IAED,MAAM,CAAC,IAAS;QACd,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,UAAU,SAAS,EAAE,IAAI,CAAC,CAAC;IAC3D,CAAC;IAED,eAAe,CAAC,IAAS;QACvB,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,gBAAgB,mBAAmB,EAAE,IAAI,CAAC,CAAC;IAC3E,CAAC;IAED,iBAAiB,CAAC,IAAS;QACzB,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,UAAU,gBAAgB,EAAE,IAAI,CAAC,CAAC;IAClE,CAAC;IAED,YAAY,CAAC,IAAY;QACvB,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,UAAU,4BAA4B,IAAI,EAAE,CAAC,CAAC;IAC7E,CAAC;IAED,aAAa,CAAC,IAAY;QACxB,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,UAAU,0BAA0B,IAAI,EAAE,CAAC,CAAC;IAC3E,CAAC;IAED,eAAe;QACb,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,gBAAgB,eAAe,CAAC,CAAC;IAChE,CAAC;IAED,KAAK,CAAC,IAAS;QACb,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,UAAU,QAAQ,EAAE,IAAI,CAAC,CAAC;IAC1D,CAAC;IAED,cAAc;QACZ,WAAW;QACX,MAAM,IAAI,GAAQ,YAAY,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QACpD,IAAI,IAAI;YAAE,OAAO,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC;QACtC,iCAAiC;QACjC,MAAM,OAAO,GAAG,IAAI,WAAW,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC;QACnD,OAAO,IAAI,CAAC,IAAI;aACb,GAAG,CAAC,GAAG,IAAI,CAAC,UAAU,YAAY,EAAE,EAAE,OAAO,EAAE,OAAO,EAAE,CAAC;aACzD,IAAI,CACH,GAAG,CAAC,CAAC,QAAa,EAAE,EAAE;YACpB,YAAY,CAAC,OAAO,CAAC,WAAW,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC;YACjE,OAAO,QAAQ,CAAC;QAClB,CAAC,CAAC,EACF,UAAU,CAAC,IAAI,CAAC,WAAW,CAAC,CAC7B,CAAC;IACN,CAAC;IACH,sCAAsC;IACtC,iDAAiD;IACjD,iDAAiD;IAEjD,qBAAqB;IACrB,2EAA2E;IAC3E,aAAa;IACb,iCAAiC;IACjC,yEAAyE;IACzE,2BAA2B;IAC3B,YAAY;IACZ,qCAAqC;IACrC,SAAS;IACT,IAAI;IAEF,eAAe;QACb,OAAO,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,gBAAgB,gBAAgB,CAAC,CAAC;IACjE,CAAC;IAED,WAAW,CAAC,GAAQ;QAClB,OAAO,UAAU,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IAC/B,CAAC;IAED,UAAU,CAAC,IAAS;QAClB,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CACnB,GAAG,IAAI,CAAC,yBAAyB,cAAc,EAC/C,IAAI,CACL,CAAC;IACJ,CAAC;IAED,qBAAqB,CAAC,MAAW;QAC/B,OAAO,IAAI,CAAC,IAAI;aACb,GAAG,CAAC,GAAG,IAAI,CAAC,UAAU,wBAAwB,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC;aACnE,IAAI,CACH,GAAG,CAAC,CAAC,QAAa,EAAE,EAAE,CAAC,QAAQ,CAAC,EAChC,UAAU,CAAC,IAAI,CAAC,WAAW,CAAC,CAC7B,CAAC;IACN,CAAC;IAED,cAAc,CAAC,IAAS;QACtB,OAAO,IAAI,CAAC,IAAI;aACf,IAAI,CAAC,GAAG,IAAI,CAAC,UAAU,yBAAyB,EAAE,IAAI,CAAE;aACxD,IAAI,CACH,GAAG,CAAC,CAAC,QAAa,EAAE,EAAE,CAAC,QAAQ,CAAC,EAChC,UAAU,CAAC,IAAI,CAAC,WAAW,CAAC,CAC7B,CAAC;IACJ,CAAC;IACD,uBAAuB,CAAC,IAAS;QAC/B,OAAO,IAAI,CAAC,IAAI;aACf,IAAI,CAAC,GAAG,IAAI,CAAC,UAAU,0BAA0B,EAAE,IAAI,CAAE;aACzD,IAAI,CACH,GAAG,CAAC,CAAC,QAAa,EAAE,EAAE,CAAC,QAAQ,CAAC,EAChC,UAAU,CAAC,IAAI,CAAC,WAAW,CAAC,CAC7B,CAAC;IACJ,CAAC;wGApLU,WAAW;4GAAX,WAAW,cAFV,MAAM;;4FAEP,WAAW;kBAHvB,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB","sourcesContent":["import { HttpClient, HttpHeaders } from \"@angular/common/http\";\r\nimport { Injectable } from \"@angular/core\";\r\nimport { Router } from \"@angular/router\";\r\nimport {\r\n  BehaviorSubject,\r\n  Observable,\r\n  catchError,\r\n  map,\r\n  of,\r\n  throwError,\r\n} from \"rxjs\";\r\nimport { GlobalStateService } from \"tango-app-ui-global\";\r\n\r\n@Injectable({\r\n  providedIn: \"root\",\r\n})\r\nexport class AuthService {\r\n  aboutFormData = new BehaviorSubject<any>(null);\r\n  pricingFormData = new BehaviorSubject<any>(null);\r\n  currentUserSubject = new BehaviorSubject<any>(null);\r\n  leadApiUrl: string = \"\";\r\n  middlewareApiUrl: string = \"\";\r\n  userApiUrl: string = \"\";\r\n  authlocalStorageToken: string;\r\n  paymentSubscriptionApiUrl: string;\r\n  get currentUserValue(): any {\r\n    return this.currentUserSubject.value;\r\n  }\r\n  constructor(\r\n    private router: Router,\r\n    private http: HttpClient,\r\n    private gs: GlobalStateService\r\n  ) {\r\n    this.gs.environment.subscribe((env) => {\r\n      if (env) {\r\n        this.leadApiUrl = env.leadApiUrl;\r\n        this.middlewareApiUrl = env.middlewareApiUrl;\r\n        this.paymentSubscriptionApiUrl = env.paymentSubscriptionApiUrl;\r\n        (this.userApiUrl = env.userApiUrl),\r\n          (this.authlocalStorageToken = `${env.appVersion}-${env.USERDATA_KEY}`);\r\n      }\r\n    });\r\n  }\r\n  private base64Encode(str: any) {\r\n  return btoa(encodeURIComponent(str));\r\n}\r\n\r\nprivate base64Decode(str: any) {\r\n  return decodeURIComponent(atob(str));\r\n}\r\nsetCookie(name: string, value: string, days: number = 1): void {\r\n  const encodedValue = this.base64Encode(value);\r\n  const expires = new Date(Date.now() + days * 864e5).toUTCString();\r\n  document.cookie = `${name}=${encodedValue}; expires=${expires}; path=/; Secure; SameSite=Strict`;\r\n}\r\n\r\ngetCookie(name: string): string | null {\r\n  const match = document.cookie.match(new RegExp(`(^| )${name}=([^;]+)`));\r\n  return match ? this.base64Decode(match[2]) : null;\r\n}\r\n  // getHeaders() {\r\n  //   const user: any = JSON.parse(\r\n  //     localStorage.getItem(this.authlocalStorageToken) || \"{}\"\r\n  //   );\r\n  //   const headers = {\r\n  //     Authorization: \"Bearer \" + user.authenticationToken,\r\n  //   };\r\n\r\n  //   return headers;\r\n  // }\r\ngetHeaders(): { [header: string]: string } {\r\n  const userTokenStr = this.getCookie(this.authlocalStorageToken);\r\n  let token = '';\r\n\r\n  if (userTokenStr) {\r\n    try {\r\n      const user = JSON.parse(userTokenStr);\r\n      token = user?.authenticationToken || '';\r\n    } catch (e) {\r\n      console.error('Invalid token JSON in cookie');\r\n    }\r\n  }\r\n\r\n  return {\r\n    Authorization: 'Bearer ' + token\r\n  };\r\n}\r\n  logout() {\r\n    localStorage.removeItem(this.authlocalStorageToken);\r\n    this.router.navigate([\"/auth/login\"], {\r\n      queryParams: {},\r\n    });\r\n  }\r\n\r\n  sendSignupOtp(data: any): Observable<any> {\r\n    return this.http.post(`${this.middlewareApiUrl}/signup-otp`, data);\r\n  }\r\n\r\n  signup(data: any): Observable<any> {\r\n    return this.http.post(`${this.leadApiUrl}/signup`, data);\r\n  }\r\n\r\n  requestCallback(data: any): Observable<any> {\r\n    return this.http.post(`${this.middlewareApiUrl}/request-callback`, data);\r\n  }\r\n\r\n  isClientnameTaken(data: any): Observable<any> {\r\n    return this.http.post(`${this.leadApiUrl}/isClientExist`, data);\r\n  }\r\n\r\n  isEmailTaken(data: string): Observable<any> {\r\n    return this.http.get(`${this.leadApiUrl}/isExists?corporateEmail=${data}`);\r\n  }\r\n\r\n  isMobileTaken(data: string): Observable<any> {\r\n    return this.http.get(`${this.leadApiUrl}/isExists?mobileNumber=${data}`);\r\n  }\r\n\r\n  getCountryCodes(): Observable<any> {\r\n    return this.http.get(`${this.middlewareApiUrl}/country-code`);\r\n  }\r\n\r\n  login(data: any): Observable<any> {\r\n    return this.http.post(`${this.userApiUrl}/login`, data);\r\n  }\r\n\r\n  userProfileDet(): Observable<any> {\r\n    // debugger\r\n    const user: any = localStorage.getItem(\"user-info\");\r\n    if (user) return of(JSON.parse(user));\r\n    // console.log(this.getHeaders())\r\n    const headers = new HttpHeaders(this.getHeaders());\r\n    return this.http\r\n      .get(`${this.userApiUrl}/profileV2`, { headers: headers })\r\n      .pipe(\r\n        map((response: any) => {\r\n          localStorage.setItem(\"user-info\", JSON.stringify(response.data));\r\n          return response;\r\n        }),\r\n        catchError(this.handleError)\r\n      );\r\n  }\r\n// userProfileDet(): Observable<any> {\r\n//   const userStr = this.getCookie(\"user-info\");\r\n//   if (userStr) return of(JSON.parse(userStr));\r\n\r\n//   return this.http\r\n//     .get(`${this.userApiUrl}/profileV2`, { headers: this.getHeaders() })\r\n//     .pipe(\r\n//       map((response: any) => {\r\n//         this.setCookie(\"user-info\", JSON.stringify(response.data), 7);\r\n//         return response;\r\n//       }),\r\n//       catchError(this.handleError)\r\n//     );\r\n// }\r\n\r\n  getAllCountries(): Observable<any> {\r\n    return this.http.get(`${this.middlewareApiUrl}/get-countries`);\r\n  }\r\n\r\n  handleError(res: any) {\r\n    return throwError(res.error);\r\n  }\r\n\r\n  getPricing(data: any): Observable<any> {\r\n    return this.http.post(\r\n      `${this.paymentSubscriptionApiUrl}/basePricing`,\r\n      data\r\n    );\r\n  }\r\n\r\n  forgotPasswordTrigger(params: any): Observable<any> {\r\n    return this.http\r\n      .get(`${this.userApiUrl}/forgot-password-email`, { params: params })\r\n      .pipe(\r\n        map((response: any) => response),\r\n        catchError(this.handleError)\r\n      );\r\n  }\r\n\r\n  forgotPassword(data: any): Observable<any> {\r\n    return this.http\r\n    .post(`${this.userApiUrl}/forgot-password-update`, data )\r\n    .pipe(\r\n      map((response: any) => response),\r\n      catchError(this.handleError)\r\n    );\r\n  }\r\n  termsAndConditionUpdate(data: any): Observable<any> {\r\n    return this.http\r\n    .post(`${this.userApiUrl}/termsAndConditionUpdate`, data )\r\n    .pipe(\r\n      map((response: any) => response),\r\n      catchError(this.handleError)\r\n    );\r\n  }\r\n  \r\n}\r\n"]}
|
@@ -11,6 +11,7 @@ import dayjs from 'dayjs';
|
|
11
11
|
import * as CryptoJS from 'crypto-js';
|
12
12
|
import CryptoJS__default from 'crypto-js';
|
13
13
|
import * as i2 from '@angular/common/http';
|
14
|
+
import { HttpHeaders } from '@angular/common/http';
|
14
15
|
import * as i4 from 'tango-app-ui-global';
|
15
16
|
import * as i1 from '@ng-bootstrap/ng-bootstrap';
|
16
17
|
import * as i5 from 'tango-app-ui-shared';
|
@@ -55,12 +56,45 @@ class AuthService {
|
|
55
56
|
}
|
56
57
|
});
|
57
58
|
}
|
59
|
+
base64Encode(str) {
|
60
|
+
return btoa(encodeURIComponent(str));
|
61
|
+
}
|
62
|
+
base64Decode(str) {
|
63
|
+
return decodeURIComponent(atob(str));
|
64
|
+
}
|
65
|
+
setCookie(name, value, days = 1) {
|
66
|
+
const encodedValue = this.base64Encode(value);
|
67
|
+
const expires = new Date(Date.now() + days * 864e5).toUTCString();
|
68
|
+
document.cookie = `${name}=${encodedValue}; expires=${expires}; path=/; Secure; SameSite=Strict`;
|
69
|
+
}
|
70
|
+
getCookie(name) {
|
71
|
+
const match = document.cookie.match(new RegExp(`(^| )${name}=([^;]+)`));
|
72
|
+
return match ? this.base64Decode(match[2]) : null;
|
73
|
+
}
|
74
|
+
// getHeaders() {
|
75
|
+
// const user: any = JSON.parse(
|
76
|
+
// localStorage.getItem(this.authlocalStorageToken) || "{}"
|
77
|
+
// );
|
78
|
+
// const headers = {
|
79
|
+
// Authorization: "Bearer " + user.authenticationToken,
|
80
|
+
// };
|
81
|
+
// return headers;
|
82
|
+
// }
|
58
83
|
getHeaders() {
|
59
|
-
const
|
60
|
-
|
61
|
-
|
84
|
+
const userTokenStr = this.getCookie(this.authlocalStorageToken);
|
85
|
+
let token = '';
|
86
|
+
if (userTokenStr) {
|
87
|
+
try {
|
88
|
+
const user = JSON.parse(userTokenStr);
|
89
|
+
token = user?.authenticationToken || '';
|
90
|
+
}
|
91
|
+
catch (e) {
|
92
|
+
console.error('Invalid token JSON in cookie');
|
93
|
+
}
|
94
|
+
}
|
95
|
+
return {
|
96
|
+
Authorization: 'Bearer ' + token
|
62
97
|
};
|
63
|
-
return headers;
|
64
98
|
}
|
65
99
|
logout() {
|
66
100
|
localStorage.removeItem(this.authlocalStorageToken);
|
@@ -93,16 +127,32 @@ class AuthService {
|
|
93
127
|
return this.http.post(`${this.userApiUrl}/login`, data);
|
94
128
|
}
|
95
129
|
userProfileDet() {
|
130
|
+
// debugger
|
96
131
|
const user = localStorage.getItem("user-info");
|
97
132
|
if (user)
|
98
133
|
return of(JSON.parse(user));
|
134
|
+
// console.log(this.getHeaders())
|
135
|
+
const headers = new HttpHeaders(this.getHeaders());
|
99
136
|
return this.http
|
100
|
-
.get(`${this.userApiUrl}/profileV2`, { headers:
|
137
|
+
.get(`${this.userApiUrl}/profileV2`, { headers: headers })
|
101
138
|
.pipe(map((response) => {
|
102
139
|
localStorage.setItem("user-info", JSON.stringify(response.data));
|
103
140
|
return response;
|
104
141
|
}), catchError(this.handleError));
|
105
142
|
}
|
143
|
+
// userProfileDet(): Observable<any> {
|
144
|
+
// const userStr = this.getCookie("user-info");
|
145
|
+
// if (userStr) return of(JSON.parse(userStr));
|
146
|
+
// return this.http
|
147
|
+
// .get(`${this.userApiUrl}/profileV2`, { headers: this.getHeaders() })
|
148
|
+
// .pipe(
|
149
|
+
// map((response: any) => {
|
150
|
+
// this.setCookie("user-info", JSON.stringify(response.data), 7);
|
151
|
+
// return response;
|
152
|
+
// }),
|
153
|
+
// catchError(this.handleError)
|
154
|
+
// );
|
155
|
+
// }
|
106
156
|
getAllCountries() {
|
107
157
|
return this.http.get(`${this.middlewareApiUrl}/get-countries`);
|
108
158
|
}
|
@@ -323,11 +373,21 @@ class TangoAuthLoginComponent {
|
|
323
373
|
// this.router.navigateByUrl('/error/403')
|
324
374
|
return;
|
325
375
|
}
|
326
|
-
let loginToken =
|
376
|
+
// let loginToken: any =
|
377
|
+
// localStorage.getItem(this.authlocalStorageToken);
|
378
|
+
// if (loginToken) {
|
379
|
+
// loginToken = JSON.parse(loginToken);
|
380
|
+
// }
|
381
|
+
// localStorage.setItem(
|
382
|
+
// this.authlocalStorageToken,
|
383
|
+
// JSON.stringify(res?.data?.result)
|
384
|
+
// );
|
385
|
+
let loginToken = this.service.getCookie(this.authlocalStorageToken);
|
327
386
|
if (loginToken) {
|
328
387
|
loginToken = JSON.parse(loginToken);
|
329
388
|
}
|
330
|
-
|
389
|
+
// STEP 2: Store new token in cookie
|
390
|
+
this.service.setCookie(this.authlocalStorageToken, JSON.stringify(res?.data?.result), 7);
|
331
391
|
if (!res?.data.termsAndCondition) {
|
332
392
|
this.showTermsAndConditions();
|
333
393
|
}
|
@@ -340,8 +400,10 @@ class TangoAuthLoginComponent {
|
|
340
400
|
this.toastService.getErrorToast('Enter Valid Credentials');
|
341
401
|
}
|
342
402
|
else {
|
343
|
-
|
344
|
-
|
403
|
+
setTimeout(() => {
|
404
|
+
this.credentials.password = originalPassword;
|
405
|
+
this.toastService.getErrorToast('Enter Valid Credentials');
|
406
|
+
}, 100);
|
345
407
|
}
|
346
408
|
},
|
347
409
|
error: (err) => {
|
@@ -1819,14 +1881,33 @@ class AuthGuard {
|
|
1819
1881
|
}
|
1820
1882
|
});
|
1821
1883
|
}
|
1822
|
-
canActivate(route, state) {
|
1823
|
-
|
1824
|
-
|
1825
|
-
|
1826
|
-
|
1827
|
-
|
1884
|
+
// canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot) {
|
1885
|
+
// // const currentUser = localStorage.getItem('isLoggedIn');
|
1886
|
+
// const currentUser = localStorage.getItem(this.authlocalStorageToken);
|
1887
|
+
// if (currentUser) {
|
1888
|
+
// // this.route.navigate(['/manage']);
|
1889
|
+
// return true;
|
1890
|
+
// } else {
|
1891
|
+
// this.route.navigate(['/auth/login']);
|
1892
|
+
// return false;
|
1893
|
+
// }
|
1894
|
+
// }
|
1895
|
+
canActivate() {
|
1896
|
+
const tokenStr = this.authService.getCookie(this.authlocalStorageToken);
|
1897
|
+
if (!tokenStr) {
|
1898
|
+
this.route.navigate(['/auth/login']);
|
1899
|
+
return false;
|
1828
1900
|
}
|
1829
|
-
|
1901
|
+
try {
|
1902
|
+
const tokenData = JSON.parse(tokenStr);
|
1903
|
+
const isValid = !!tokenData?.authenticationToken;
|
1904
|
+
if (!isValid) {
|
1905
|
+
this.route.navigate(['/auth/login']);
|
1906
|
+
}
|
1907
|
+
return isValid;
|
1908
|
+
}
|
1909
|
+
catch (e) {
|
1910
|
+
console.error('Invalid token in cookie', e);
|
1830
1911
|
this.route.navigate(['/auth/login']);
|
1831
1912
|
return false;
|
1832
1913
|
}
|