new-front-common-library 18.0.2-REF1 → 18.0.2-REF2
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/util/services/auth/auth.service.mjs +4 -9
- package/esm2022/lib/util/services/notification/notification.service.mjs +20 -17
- package/fesm2022/new-front-common-library.mjs +33 -35
- package/fesm2022/new-front-common-library.mjs.map +1 -1
- package/lib/util/services/auth/auth.service.d.ts +0 -3
- package/lib/util/services/notification/notification.service.d.ts +5 -3
- package/package.json +1 -1
|
@@ -1,23 +1,18 @@
|
|
|
1
1
|
import { Injectable } from '@angular/core';
|
|
2
2
|
import { BehaviorSubject } from 'rxjs';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "../notification/notification.service";
|
|
5
4
|
export class AuthService {
|
|
6
|
-
constructor(
|
|
7
|
-
this.notificationService = notificationService;
|
|
5
|
+
constructor() {
|
|
8
6
|
this.isAuthenticatedSubject = new BehaviorSubject(false);
|
|
9
7
|
this.isAuthenticated$ = this.isAuthenticatedSubject.asObservable();
|
|
10
8
|
}
|
|
11
9
|
setAuthenticated(isAuthenticated) {
|
|
12
|
-
if (isAuthenticated) {
|
|
13
|
-
this.notificationService.connect();
|
|
14
|
-
}
|
|
15
10
|
this.isAuthenticatedSubject.next(isAuthenticated);
|
|
16
11
|
}
|
|
17
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.10", ngImport: i0, type: AuthService, deps: [
|
|
12
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.10", ngImport: i0, type: AuthService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
18
13
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.10", ngImport: i0, type: AuthService }); }
|
|
19
14
|
}
|
|
20
15
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.10", ngImport: i0, type: AuthService, decorators: [{
|
|
21
16
|
type: Injectable
|
|
22
|
-
}]
|
|
23
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
17
|
+
}] });
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmV3LWZyb250LWNvbW1vbi1saWJyYXJ5L3NyYy9saWIvdXRpbC9zZXJ2aWNlcy9hdXRoL2F1dGguc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzNDLE9BQU8sRUFBRSxlQUFlLEVBQWMsTUFBTSxNQUFNLENBQUM7O0FBR25ELE1BQU0sT0FBTyxXQUFXO0lBRHhCO1FBR21CLDJCQUFzQixHQUE2QixJQUFJLGVBQWUsQ0FBVSxLQUFLLENBQUMsQ0FBQztRQUV4RyxxQkFBZ0IsR0FBd0IsSUFBSSxDQUFDLHNCQUFzQixDQUFDLFlBQVksRUFBRSxDQUFDO0tBS3BGO0lBSFEsZ0JBQWdCLENBQUMsZUFBd0I7UUFDOUMsSUFBSSxDQUFDLHNCQUFzQixDQUFDLElBQUksQ0FBQyxlQUFlLENBQUMsQ0FBQztJQUNwRCxDQUFDOytHQVJVLFdBQVc7bUhBQVgsV0FBVzs7NEZBQVgsV0FBVztrQkFEdkIsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCwgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgQXV0aFNlcnZpY2Uge1xuXG4gIHByaXZhdGUgcmVhZG9ubHkgaXNBdXRoZW50aWNhdGVkU3ViamVjdDogQmVoYXZpb3JTdWJqZWN0PGJvb2xlYW4+ID0gbmV3IEJlaGF2aW9yU3ViamVjdDxib29sZWFuPihmYWxzZSk7XG5cbiAgaXNBdXRoZW50aWNhdGVkJDogT2JzZXJ2YWJsZTxib29sZWFuPiA9IHRoaXMuaXNBdXRoZW50aWNhdGVkU3ViamVjdC5hc09ic2VydmFibGUoKTtcblxuICBwdWJsaWMgc2V0QXV0aGVudGljYXRlZChpc0F1dGhlbnRpY2F0ZWQ6IGJvb2xlYW4pOiB2b2lkIHtcbiAgICB0aGlzLmlzQXV0aGVudGljYXRlZFN1YmplY3QubmV4dChpc0F1dGhlbnRpY2F0ZWQpO1xuICB9XG59XG4iXX0=
|
|
@@ -8,14 +8,16 @@ import { WEB_CONFIG } from '../../config';
|
|
|
8
8
|
import * as i0 from "@angular/core";
|
|
9
9
|
import * as i1 from "../api/notification-api.service";
|
|
10
10
|
import * as i2 from "../storage/local-storage.service";
|
|
11
|
+
import * as i3 from "../auth/auth.service";
|
|
11
12
|
export const NOTIFICATION_WEBSOCKET_URL = '/authorization-api/ws';
|
|
12
13
|
export const NOTIFICATION_TOPIC = '/topic/notification';
|
|
13
14
|
export const ACKED_NOTIFICATIONS_LOCAL_STORAGE_KEY = 'ackedNotifications';
|
|
14
15
|
export class NotificationService {
|
|
15
|
-
constructor(config, notificationApiService, localStorage) {
|
|
16
|
+
constructor(config, notificationApiService, localStorage, authService) {
|
|
16
17
|
this.config = config;
|
|
17
18
|
this.notificationApiService = notificationApiService;
|
|
18
19
|
this.localStorage = localStorage;
|
|
20
|
+
this.authService = authService;
|
|
19
21
|
this.stompClient = null;
|
|
20
22
|
this.notificationSubject = new BehaviorSubject(null);
|
|
21
23
|
// Observable for components to subscribe to messages
|
|
@@ -23,9 +25,19 @@ export class NotificationService {
|
|
|
23
25
|
// Subject to track the connection status (connected/disconnected)
|
|
24
26
|
this.connectionSubject = new BehaviorSubject(false);
|
|
25
27
|
this.apiUrl = this.config.api_url + NOTIFICATION_WEBSOCKET_URL;
|
|
28
|
+
authService.isAuthenticated$.subscribe(isAuthenticated => {
|
|
29
|
+
if (isAuthenticated) {
|
|
30
|
+
this.fetchLiveNotifications();
|
|
31
|
+
this.subscribeToNotifications();
|
|
32
|
+
}
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
ackNotification(notification) {
|
|
36
|
+
const ackedNotifications = this.localStorage.get(ACKED_NOTIFICATIONS_LOCAL_STORAGE_KEY) ?? [];
|
|
37
|
+
ackedNotifications.push(notification.id);
|
|
38
|
+
this.localStorage.post(ACKED_NOTIFICATIONS_LOCAL_STORAGE_KEY, ackedNotifications);
|
|
26
39
|
}
|
|
27
|
-
|
|
28
|
-
// Fetch live notifications
|
|
40
|
+
fetchLiveNotifications() {
|
|
29
41
|
this.notificationApiService.getLiveNotifications().subscribe(notifications => {
|
|
30
42
|
const liveNotificationIds = notifications.map(notification => notification.id);
|
|
31
43
|
// Clear up any acked notifications that have expired (no longer live)
|
|
@@ -37,6 +49,8 @@ export class NotificationService {
|
|
|
37
49
|
.filter(notification => ackedNotifications.indexOf(notification.id) === -1)
|
|
38
50
|
.forEach(notification => this.handleNotification(notification));
|
|
39
51
|
});
|
|
52
|
+
}
|
|
53
|
+
subscribeToNotifications() {
|
|
40
54
|
if (this.stompClient) {
|
|
41
55
|
return;
|
|
42
56
|
}
|
|
@@ -67,17 +81,6 @@ export class NotificationService {
|
|
|
67
81
|
console.log('Activating stomp client');
|
|
68
82
|
this.stompClient.activate();
|
|
69
83
|
}
|
|
70
|
-
disconnect() {
|
|
71
|
-
if (this.stompClient) {
|
|
72
|
-
void this.stompClient.deactivate();
|
|
73
|
-
this.stompClient = null;
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
ackNotification(notification) {
|
|
77
|
-
const ackedNotifications = this.localStorage.get(ACKED_NOTIFICATIONS_LOCAL_STORAGE_KEY) ?? [];
|
|
78
|
-
ackedNotifications.push(notification.id);
|
|
79
|
-
this.localStorage.post(ACKED_NOTIFICATIONS_LOCAL_STORAGE_KEY, ackedNotifications);
|
|
80
|
-
}
|
|
81
84
|
handleNotification(notification) {
|
|
82
85
|
const targetSectionIds = notification.targetSections.map(section => section.id);
|
|
83
86
|
const userSectionIds = this.user.permissions.map(permission => permission.sectionId);
|
|
@@ -85,7 +88,7 @@ export class NotificationService {
|
|
|
85
88
|
this.notificationSubject.next(notification);
|
|
86
89
|
}
|
|
87
90
|
}
|
|
88
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.10", ngImport: i0, type: NotificationService, deps: [{ token: WEB_CONFIG }, { token: i1.NotificationApiService }, { token: i2.LocalStorageService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
91
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.10", ngImport: i0, type: NotificationService, deps: [{ token: WEB_CONFIG }, { token: i1.NotificationApiService }, { token: i2.LocalStorageService }, { token: i3.AuthService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
89
92
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.10", ngImport: i0, type: NotificationService, providedIn: 'root' }); }
|
|
90
93
|
}
|
|
91
94
|
__decorate([
|
|
@@ -99,5 +102,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.10", ngImpo
|
|
|
99
102
|
}], ctorParameters: () => [{ type: undefined, decorators: [{
|
|
100
103
|
type: Inject,
|
|
101
104
|
args: [WEB_CONFIG]
|
|
102
|
-
}] }, { type: i1.NotificationApiService }, { type: i2.LocalStorageService }], propDecorators: { user: [] } });
|
|
103
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notification.service.js","sourceRoot":"","sources":["../../../../../../../projects/new-front-common-library/src/lib/util/services/notification/notification.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable } from '@angular/core';\nimport { Client, Message } from '@stomp/stompjs';\nimport { BehaviorSubject } from 'rxjs';\nimport SockJS from 'sockjs-client';\nimport { User } from '../../decorators/user.decorator';\nimport { Config, WEB_CONFIG } from '../../config';\nimport { NotificationModel, UserModel } from '../../models';\nimport { NotificationApiService } from '../api/notification-api.service';\nimport { LocalStorageService } from '../storage/local-storage.service';\n\nexport const NOTIFICATION_WEBSOCKET_URL = '/authorization-api/ws';\nexport const NOTIFICATION_TOPIC = '/topic/notification';\nexport const ACKED_NOTIFICATIONS_LOCAL_STORAGE_KEY = 'ackedNotifications';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class NotificationService {\n  @User() public user: UserModel;\n\n  public apiUrl: string;\n  private stompClient: Client | null = null;\n\n  private readonly notificationSubject = new BehaviorSubject<NotificationModel>(null);\n\n  // Observable for components to subscribe to messages\n  public notifications$ = this.notificationSubject.asObservable();\n\n  // Subject to track the connection status (connected/disconnected)\n  private readonly connectionSubject = new BehaviorSubject<boolean>(false);\n\n  constructor(@Inject(WEB_CONFIG) private readonly config: Config,\n              private readonly notificationApiService: NotificationApiService,\n              private readonly localStorage: LocalStorageService,) {\n    this.apiUrl = this.config.api_url + NOTIFICATION_WEBSOCKET_URL;\n  }\n\n  public connect(): void {\n    // Fetch live notifications\n    this.notificationApiService.getLiveNotifications().subscribe(notifications => {\n      const liveNotificationIds = notifications.map(notification => notification.id);\n\n      // Clear up any acked notifications that have expired (no longer live)\n      let ackedNotifications: number[] = this.localStorage.get(ACKED_NOTIFICATIONS_LOCAL_STORAGE_KEY) ?? [];\n      ackedNotifications = ackedNotifications.filter(ackedNotificationId => liveNotificationIds.indexOf(ackedNotificationId) >= 0)\n      this.localStorage.post(ACKED_NOTIFICATIONS_LOCAL_STORAGE_KEY, ackedNotifications);\n\n      // Handle new notifications\n      notifications.filter(notification => notification.published)\n        .filter(notification => ackedNotifications.indexOf(notification.id) === -1)\n        .forEach(notification => this.handleNotification(notification));\n    });\n\n    if (this.stompClient) {\n      return;\n    }\n\n    // Start listening for new notifications\n    const socket = new SockJS(this.apiUrl); // Initialize the SockJS WebSocket connection to the server\n\n    // Configure the STOMP client with connection details\n    this.stompClient = new Client({\n      webSocketFactory: () => socket, // Use SockJS as the WebSocket factory\n      reconnectDelay: 5000, // Reconnect delay if connection is lost\n    });\n\n    if (!this.stompClient) {\n      console.error('Failed to initialize stomp client');\n      return;\n    }\n\n    // On successful connection\n    this.stompClient.onConnect = () => {\n      this.connectionSubject.next(true);\n      // Register notification callback\n      this.stompClient.subscribe(NOTIFICATION_TOPIC, (message: Message) => {\n        const notification: NotificationModel = JSON.parse(message.body);\n        this.handleNotification(notification);\n      });\n    };\n\n    this.stompClient.onStompError = (frame) => {\n      console.error('Broker reported error: ' + frame.headers['message']);\n      console.error('Additional details: ' + frame.body);\n    };\n\n    console.log('Activating stomp client');\n    this.stompClient.activate();\n  }\n\n  public disconnect(): void {\n    if (this.stompClient) {\n       void this.stompClient.deactivate();\n       this.stompClient = null;\n    }\n  }\n\n  public ackNotification(notification: NotificationModel): void {\n    const ackedNotifications: number[] = this.localStorage.get(ACKED_NOTIFICATIONS_LOCAL_STORAGE_KEY) ?? [];\n    ackedNotifications.push(notification.id);\n    this.localStorage.post(ACKED_NOTIFICATIONS_LOCAL_STORAGE_KEY, ackedNotifications);\n  }\n\n  private handleNotification(notification: NotificationModel): void {\n    const targetSectionIds = notification.targetSections.map(section => section.id);\n    const userSectionIds = this.user.permissions.map(permission => permission.sectionId);\n\n    if (targetSectionIds.some((targetSectionId) => userSectionIds.includes(targetSectionId))) {\n      this.notificationSubject.next(notification);\n    }\n  }\n}\n"]}
|
|
105
|
+
}] }, { type: i1.NotificationApiService }, { type: i2.LocalStorageService }, { type: i3.AuthService }], propDecorators: { user: [] } });
|
|
106
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notification.service.js","sourceRoot":"","sources":["../../../../../../../projects/new-front-common-library/src/lib/util/services/notification/notification.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable } from '@angular/core';\nimport { Client, Message } from '@stomp/stompjs';\nimport { BehaviorSubject } from 'rxjs';\nimport SockJS from 'sockjs-client';\nimport { User } from '../../decorators/user.decorator';\nimport { Config, WEB_CONFIG } from '../../config';\nimport { NotificationModel, UserModel } from '../../models';\nimport { NotificationApiService } from '../api/notification-api.service';\nimport { LocalStorageService } from '../storage/local-storage.service';\nimport { AuthService } from '../auth/auth.service';\n\nexport const NOTIFICATION_WEBSOCKET_URL = '/authorization-api/ws';\nexport const NOTIFICATION_TOPIC = '/topic/notification';\nexport const ACKED_NOTIFICATIONS_LOCAL_STORAGE_KEY = 'ackedNotifications';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class NotificationService {\n  @User() public user: UserModel;\n\n  public apiUrl: string;\n  private stompClient: Client | null = null;\n\n  private readonly notificationSubject = new BehaviorSubject<NotificationModel>(null);\n\n  // Observable for components to subscribe to messages\n  public notifications$ = this.notificationSubject.asObservable();\n\n  // Subject to track the connection status (connected/disconnected)\n  private readonly connectionSubject = new BehaviorSubject<boolean>(false);\n\n  constructor(@Inject(WEB_CONFIG) private readonly config: Config,\n              private readonly notificationApiService: NotificationApiService,\n              private readonly localStorage: LocalStorageService,\n              readonly authService: AuthService) {\n    this.apiUrl = this.config.api_url + NOTIFICATION_WEBSOCKET_URL;\n    authService.isAuthenticated$.subscribe(isAuthenticated => {\n      if (isAuthenticated) {\n        this.fetchLiveNotifications();\n        this.subscribeToNotifications();\n      }\n    });\n  }\n\n  public ackNotification(notification: NotificationModel): void {\n    const ackedNotifications: number[] = this.localStorage.get(ACKED_NOTIFICATIONS_LOCAL_STORAGE_KEY) ?? [];\n    ackedNotifications.push(notification.id);\n    this.localStorage.post(ACKED_NOTIFICATIONS_LOCAL_STORAGE_KEY, ackedNotifications);\n  }\n\n  private fetchLiveNotifications(): void {\n    this.notificationApiService.getLiveNotifications().subscribe(notifications => {\n      const liveNotificationIds = notifications.map(notification => notification.id);\n\n      // Clear up any acked notifications that have expired (no longer live)\n      let ackedNotifications: number[] = this.localStorage.get(ACKED_NOTIFICATIONS_LOCAL_STORAGE_KEY) ?? [];\n      ackedNotifications = ackedNotifications.filter(ackedNotificationId => liveNotificationIds.indexOf(ackedNotificationId) >= 0)\n      this.localStorage.post(ACKED_NOTIFICATIONS_LOCAL_STORAGE_KEY, ackedNotifications);\n\n      // Handle new notifications\n      notifications.filter(notification => notification.published)\n        .filter(notification => ackedNotifications.indexOf(notification.id) === -1)\n        .forEach(notification => this.handleNotification(notification));\n    });\n  }\n\n  private subscribeToNotifications(): void {\n    if (this.stompClient) {\n      return;\n    }\n\n    // Start listening for new notifications\n    const socket = new SockJS(this.apiUrl); // Initialize the SockJS WebSocket connection to the server\n\n    // Configure the STOMP client with connection details\n    this.stompClient = new Client({\n      webSocketFactory: () => socket, // Use SockJS as the WebSocket factory\n      reconnectDelay: 5000, // Reconnect delay if connection is lost\n    });\n\n    if (!this.stompClient) {\n      console.error('Failed to initialize stomp client');\n      return;\n    }\n\n    // On successful connection\n    this.stompClient.onConnect = () => {\n      this.connectionSubject.next(true);\n      // Register notification callback\n      this.stompClient.subscribe(NOTIFICATION_TOPIC, (message: Message) => {\n        const notification: NotificationModel = JSON.parse(message.body);\n        this.handleNotification(notification);\n      });\n    };\n\n    this.stompClient.onStompError = (frame) => {\n      console.error('Broker reported error: ' + frame.headers['message']);\n      console.error('Additional details: ' + frame.body);\n    };\n\n    console.log('Activating stomp client');\n    this.stompClient.activate();\n  }\n\n  private handleNotification(notification: NotificationModel): void {\n    const targetSectionIds = notification.targetSections.map(section => section.id);\n    const userSectionIds = this.user.permissions.map(permission => permission.sectionId);\n\n    if (targetSectionIds.some((targetSectionId) => userSectionIds.includes(targetSectionId))) {\n      this.notificationSubject.next(notification);\n    }\n  }\n}\n"]}
|
|
@@ -2598,14 +2598,30 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.10", ngImpo
|
|
|
2598
2598
|
args: [WEB_CONFIG]
|
|
2599
2599
|
}] }, { type: i1$5.HttpClient }] });
|
|
2600
2600
|
|
|
2601
|
+
class AuthService {
|
|
2602
|
+
constructor() {
|
|
2603
|
+
this.isAuthenticatedSubject = new BehaviorSubject(false);
|
|
2604
|
+
this.isAuthenticated$ = this.isAuthenticatedSubject.asObservable();
|
|
2605
|
+
}
|
|
2606
|
+
setAuthenticated(isAuthenticated) {
|
|
2607
|
+
this.isAuthenticatedSubject.next(isAuthenticated);
|
|
2608
|
+
}
|
|
2609
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.10", ngImport: i0, type: AuthService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
2610
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.10", ngImport: i0, type: AuthService }); }
|
|
2611
|
+
}
|
|
2612
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.10", ngImport: i0, type: AuthService, decorators: [{
|
|
2613
|
+
type: Injectable
|
|
2614
|
+
}] });
|
|
2615
|
+
|
|
2601
2616
|
const NOTIFICATION_WEBSOCKET_URL = '/authorization-api/ws';
|
|
2602
2617
|
const NOTIFICATION_TOPIC = '/topic/notification';
|
|
2603
2618
|
const ACKED_NOTIFICATIONS_LOCAL_STORAGE_KEY = 'ackedNotifications';
|
|
2604
2619
|
class NotificationService {
|
|
2605
|
-
constructor(config, notificationApiService, localStorage) {
|
|
2620
|
+
constructor(config, notificationApiService, localStorage, authService) {
|
|
2606
2621
|
this.config = config;
|
|
2607
2622
|
this.notificationApiService = notificationApiService;
|
|
2608
2623
|
this.localStorage = localStorage;
|
|
2624
|
+
this.authService = authService;
|
|
2609
2625
|
this.stompClient = null;
|
|
2610
2626
|
this.notificationSubject = new BehaviorSubject(null);
|
|
2611
2627
|
// Observable for components to subscribe to messages
|
|
@@ -2613,9 +2629,19 @@ class NotificationService {
|
|
|
2613
2629
|
// Subject to track the connection status (connected/disconnected)
|
|
2614
2630
|
this.connectionSubject = new BehaviorSubject(false);
|
|
2615
2631
|
this.apiUrl = this.config.api_url + NOTIFICATION_WEBSOCKET_URL;
|
|
2632
|
+
authService.isAuthenticated$.subscribe(isAuthenticated => {
|
|
2633
|
+
if (isAuthenticated) {
|
|
2634
|
+
this.fetchLiveNotifications();
|
|
2635
|
+
this.subscribeToNotifications();
|
|
2636
|
+
}
|
|
2637
|
+
});
|
|
2616
2638
|
}
|
|
2617
|
-
|
|
2618
|
-
|
|
2639
|
+
ackNotification(notification) {
|
|
2640
|
+
const ackedNotifications = this.localStorage.get(ACKED_NOTIFICATIONS_LOCAL_STORAGE_KEY) ?? [];
|
|
2641
|
+
ackedNotifications.push(notification.id);
|
|
2642
|
+
this.localStorage.post(ACKED_NOTIFICATIONS_LOCAL_STORAGE_KEY, ackedNotifications);
|
|
2643
|
+
}
|
|
2644
|
+
fetchLiveNotifications() {
|
|
2619
2645
|
this.notificationApiService.getLiveNotifications().subscribe(notifications => {
|
|
2620
2646
|
const liveNotificationIds = notifications.map(notification => notification.id);
|
|
2621
2647
|
// Clear up any acked notifications that have expired (no longer live)
|
|
@@ -2627,6 +2653,8 @@ class NotificationService {
|
|
|
2627
2653
|
.filter(notification => ackedNotifications.indexOf(notification.id) === -1)
|
|
2628
2654
|
.forEach(notification => this.handleNotification(notification));
|
|
2629
2655
|
});
|
|
2656
|
+
}
|
|
2657
|
+
subscribeToNotifications() {
|
|
2630
2658
|
if (this.stompClient) {
|
|
2631
2659
|
return;
|
|
2632
2660
|
}
|
|
@@ -2657,17 +2685,6 @@ class NotificationService {
|
|
|
2657
2685
|
console.log('Activating stomp client');
|
|
2658
2686
|
this.stompClient.activate();
|
|
2659
2687
|
}
|
|
2660
|
-
disconnect() {
|
|
2661
|
-
if (this.stompClient) {
|
|
2662
|
-
void this.stompClient.deactivate();
|
|
2663
|
-
this.stompClient = null;
|
|
2664
|
-
}
|
|
2665
|
-
}
|
|
2666
|
-
ackNotification(notification) {
|
|
2667
|
-
const ackedNotifications = this.localStorage.get(ACKED_NOTIFICATIONS_LOCAL_STORAGE_KEY) ?? [];
|
|
2668
|
-
ackedNotifications.push(notification.id);
|
|
2669
|
-
this.localStorage.post(ACKED_NOTIFICATIONS_LOCAL_STORAGE_KEY, ackedNotifications);
|
|
2670
|
-
}
|
|
2671
2688
|
handleNotification(notification) {
|
|
2672
2689
|
const targetSectionIds = notification.targetSections.map(section => section.id);
|
|
2673
2690
|
const userSectionIds = this.user.permissions.map(permission => permission.sectionId);
|
|
@@ -2675,7 +2692,7 @@ class NotificationService {
|
|
|
2675
2692
|
this.notificationSubject.next(notification);
|
|
2676
2693
|
}
|
|
2677
2694
|
}
|
|
2678
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.10", ngImport: i0, type: NotificationService, deps: [{ token: WEB_CONFIG }, { token: NotificationApiService }, { token: LocalStorageService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
2695
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.10", ngImport: i0, type: NotificationService, deps: [{ token: WEB_CONFIG }, { token: NotificationApiService }, { token: LocalStorageService }, { token: AuthService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
2679
2696
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.10", ngImport: i0, type: NotificationService, providedIn: 'root' }); }
|
|
2680
2697
|
}
|
|
2681
2698
|
__decorate([
|
|
@@ -2689,7 +2706,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.10", ngImpo
|
|
|
2689
2706
|
}], ctorParameters: () => [{ type: undefined, decorators: [{
|
|
2690
2707
|
type: Inject,
|
|
2691
2708
|
args: [WEB_CONFIG]
|
|
2692
|
-
}] }, { type: NotificationApiService }, { type: LocalStorageService }], propDecorators: { user: [] } });
|
|
2709
|
+
}] }, { type: NotificationApiService }, { type: LocalStorageService }, { type: AuthService }], propDecorators: { user: [] } });
|
|
2693
2710
|
|
|
2694
2711
|
class NotificationBarComponent {
|
|
2695
2712
|
constructor() {
|
|
@@ -3147,25 +3164,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.10", ngImpo
|
|
|
3147
3164
|
type: Injectable
|
|
3148
3165
|
}], ctorParameters: () => [] });
|
|
3149
3166
|
|
|
3150
|
-
class AuthService {
|
|
3151
|
-
constructor(notificationService) {
|
|
3152
|
-
this.notificationService = notificationService;
|
|
3153
|
-
this.isAuthenticatedSubject = new BehaviorSubject(false);
|
|
3154
|
-
this.isAuthenticated$ = this.isAuthenticatedSubject.asObservable();
|
|
3155
|
-
}
|
|
3156
|
-
setAuthenticated(isAuthenticated) {
|
|
3157
|
-
if (isAuthenticated) {
|
|
3158
|
-
this.notificationService.connect();
|
|
3159
|
-
}
|
|
3160
|
-
this.isAuthenticatedSubject.next(isAuthenticated);
|
|
3161
|
-
}
|
|
3162
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.10", ngImport: i0, type: AuthService, deps: [{ token: NotificationService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
3163
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.10", ngImport: i0, type: AuthService }); }
|
|
3164
|
-
}
|
|
3165
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.10", ngImport: i0, type: AuthService, decorators: [{
|
|
3166
|
-
type: Injectable
|
|
3167
|
-
}], ctorParameters: () => [{ type: NotificationService }] });
|
|
3168
|
-
|
|
3169
3167
|
class UtilModule {
|
|
3170
3168
|
constructor() {
|
|
3171
3169
|
this.langService = inject(LangService);
|