ngx-histaff-alpha 2.4.3 → 2.4.5

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.
@@ -43,6 +43,8 @@ export class SocketService {
43
43
  });
44
44
  connection.on("ReceiveMessage", (activity) => {
45
45
  console.log("MONITORING: ", activity);
46
+ if (this.appConfigService.DEBUG_ENABLED)
47
+ debugger;
46
48
  switch (activity.signalType) {
47
49
  case EnumSignalRType.TASK_PROGRESS:
48
50
  this.longTaskService.message$.next(activity.message);
@@ -142,4 +144,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
142
144
  providedIn: 'root'
143
145
  }]
144
146
  }], ctorParameters: () => [{ type: i1.AuthService }, { type: i2.UserActivityService }, { type: i3.HubConnectionService }, { type: i4.AppConfigService }, { type: i5.AlertService }, { type: i6.Router }, { type: i7.LongTaskService }] });
145
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"socket.service.js","sourceRoot":"","sources":["../../../../../../projects/ngx-histaff-alpha/src/lib/app/services/socket.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, isDevMode } from '@angular/core';\r\nimport { AuthService } from './auth.service';\r\nimport { HubConnectionService } from './hub-connection.service';\r\nimport { HubConnection, HubConnectionBuilder, LogLevel } from '@microsoft/signalr';\r\nimport { IUserActivityData, UserActivityService } from './user-activity.service';\r\nimport { AppConfigService } from './app-config.service';\r\nimport { IHubConnectionActivity } from '../interfaces/IHubConnectionActivity';\r\nimport { AlertService } from '../libraries/alert/alert.service';\r\nimport { LongTaskService } from '../libraries/services/long-task.service';\r\nimport { alertOptions } from '../constants/alertOptions';\r\nimport { EnumSignalRType } from '../enum/EnumSignalRType';\r\nimport { Router } from '@angular/router';\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class SocketService {\r\n\r\n  constructor(\r\n    private authService: AuthService,\r\n    private userActivityService: UserActivityService,\r\n    private hubConnectionService: HubConnectionService,\r\n    private appConfigService: AppConfigService,\r\n    private alertService: AlertService,\r\n    private router: Router,\r\n    private longTaskService: LongTaskService\r\n  ) { }\r\n\r\n  createHubConnection() {\r\n    const token = this.authService.data$.value?.token;\r\n    if (!!!token) {\r\n      console.warn(\"No user logged in\");\r\n      return;\r\n    }\r\n\r\n    const connection: HubConnection = new HubConnectionBuilder()\r\n      .withUrl(this.appConfigService.BASE_URL + '/hubs/signal', {\r\n        // .withUrl('https://tanleica.com/hubs/signal', {\r\n        headers: {\r\n          \"Access-Control-Allow-Credentials\": true,\r\n          \"Access-Control-Allow-Origin\": true,\r\n        } as any,\r\n        withCredentials: false,\r\n        accessTokenFactory: () => token,\r\n      })\r\n      .configureLogging(LogLevel.None)\r\n      .build()\r\n\r\n    connection.on(\"ReceiveSystemMessage\", message => {\r\n      console.log(\"System message: \", message)\r\n    })\r\n\r\n    connection.on(\"ReceiveMessage\", (activity: IHubConnectionActivity) => {\r\n\r\n      console.log(\"MONITORING: \", activity);\r\n\r\n      switch (activity.signalType) {\r\n        case EnumSignalRType.TASK_PROGRESS:\r\n          this.longTaskService.message$.next(activity.message)\r\n          this.longTaskService.data$.next((activity as any).data)\r\n          this.longTaskService.error$.next((activity as any).error)\r\n          break;\r\n        case EnumSignalRType.LOG_IN:\r\n          if (isDevMode()) this.alertService.info(activity.message, alertOptions)\r\n          break;\r\n        case EnumSignalRType.ENTITY_CHANGED:\r\n          if (isDevMode()) this.alertService.info(activity.message, alertOptions)\r\n          break;\r\n        case EnumSignalRType.ACTIVITY:\r\n          const { loginTime } = activity;\r\n          const { sid, username, pathname, avatar, hubConnectionId, accessTime, userActivity } = activity.data;\r\n\r\n          const currentSid = this.authService.data$.value?.fullName;\r\n\r\n          console.group(\"ACTIVITY\")\r\n          console.log(\"isDevMode()\", isDevMode());\r\n          console.log(\"Incoming loginTime\", loginTime);\r\n          console.log(\"Your loginTime\", this.authService.data$.value?.loginTime!);\r\n          console.log(\"Incoming sid\", sid);\r\n          console.log(\"Your sid\", currentSid);\r\n\r\n          console.groupEnd();\r\n\r\n          if (loginTime < this.authService.data$.value?.loginTime! && sid === currentSid /*&& isDevMode()*/) {\r\n\r\n            if (isDevMode()) {\r\n\r\n              this.alertService.error(\r\n                `Trong môi trường Dev, tài khoản (${sid}) đã được dùng trước rồi nhé. Xin đăng nhập bằng tài khoản khác`,\r\n                { ...alertOptions, autoClose: false }\r\n              )\r\n\r\n              setTimeout(() => {\r\n                this.authService.userLogout().subscribe(x => {\r\n                  if (x.ok && x.status === 200) {\r\n                    this.authService.postLogout();\r\n                  }\r\n                });\r\n              }, 3000)\r\n\r\n            }\r\n          }\r\n\r\n          const merged = this.userActivityService.mergeActivities(userActivity)\r\n          const found = merged.filter(item => item.sid === sid)\r\n          if (found.length) {\r\n            const newState: IUserActivityData = { sid, username, pathname, avatar, hubConnectionId, accessTime }\r\n            merged.filter(item => item.sid !== sid).push(newState)\r\n          } else {\r\n            merged.push({ sid, username, pathname, avatar, hubConnectionId, accessTime })\r\n          }\r\n\r\n          this.userActivityService.userActivity$.next(merged);\r\n\r\n          break;\r\n        case EnumSignalRType.ACTIVITY_HISTORY_RESET:\r\n          this.userActivityService.userActivity$.next([]);\r\n          break;\r\n\r\n        default:\r\n          break;\r\n      }\r\n\r\n\r\n    })\r\n\r\n    const start = async () => {\r\n      let id\r\n      try {\r\n        this.hubConnectionService.message = \"HubConnection creating requested.\"\r\n        await connection.start();\r\n        console.log(\"🟢🟢🟢 SignalR Connected.\");\r\n        this.hubConnectionService.message = \"HubConnection created.\";\r\n        this.hubConnectionService.hubConnection$.next(connection);\r\n\r\n        if (id) clearTimeout(id)\r\n\r\n      } catch (err: any) {\r\n        console.group(`🔴🔴🔴 HUB CONNECTION PROBLEM ====================`)\r\n        this.hubConnectionService.message = err;\r\n        console.warn(\"hubConnection start() error: \", err)\r\n\r\n        if (typeof err === 'string') {\r\n          if (err.indexOf(`Status code '401'`) >= 0) {\r\n            console.warn(\"The token expired\")\r\n          } else {\r\n            id = setTimeout(start, 5000)\r\n          }\r\n        } else {\r\n          id = setTimeout(start, 5000)\r\n        }\r\n        console.groupEnd()\r\n      }\r\n    }\r\n\r\n    connection.onclose(async () => {\r\n      await start();\r\n    })\r\n\r\n    // Start the connection.\r\n    start();\r\n  }\r\n\r\n}\r\n"]}
147
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"socket.service.js","sourceRoot":"","sources":["../../../../../../projects/ngx-histaff-alpha/src/lib/app/services/socket.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, isDevMode } from '@angular/core';\r\nimport { AuthService } from './auth.service';\r\nimport { HubConnectionService } from './hub-connection.service';\r\nimport { HubConnection, HubConnectionBuilder, LogLevel } from '@microsoft/signalr';\r\nimport { IUserActivityData, UserActivityService } from './user-activity.service';\r\nimport { AppConfigService } from './app-config.service';\r\nimport { IHubConnectionActivity } from '../interfaces/IHubConnectionActivity';\r\nimport { AlertService } from '../libraries/alert/alert.service';\r\nimport { LongTaskService } from '../libraries/services/long-task.service';\r\nimport { alertOptions } from '../constants/alertOptions';\r\nimport { EnumSignalRType } from '../enum/EnumSignalRType';\r\nimport { Router } from '@angular/router';\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class SocketService {\r\n\r\n  constructor(\r\n    private authService: AuthService,\r\n    private userActivityService: UserActivityService,\r\n    private hubConnectionService: HubConnectionService,\r\n    private appConfigService: AppConfigService,\r\n    private alertService: AlertService,\r\n    private router: Router,\r\n    private longTaskService: LongTaskService\r\n  ) { }\r\n\r\n  createHubConnection() {\r\n    const token = this.authService.data$.value?.token;\r\n    if (!!!token) {\r\n      console.warn(\"No user logged in\");\r\n      return;\r\n    }\r\n\r\n    const connection: HubConnection = new HubConnectionBuilder()\r\n      .withUrl(this.appConfigService.BASE_URL + '/hubs/signal', {\r\n        // .withUrl('https://tanleica.com/hubs/signal', {\r\n        headers: {\r\n          \"Access-Control-Allow-Credentials\": true,\r\n          \"Access-Control-Allow-Origin\": true,\r\n        } as any,\r\n        withCredentials: false,\r\n        accessTokenFactory: () => token,\r\n      })\r\n      .configureLogging(LogLevel.None)\r\n      .build()\r\n\r\n    connection.on(\"ReceiveSystemMessage\", message => {\r\n      console.log(\"System message: \", message)\r\n    })\r\n\r\n    connection.on(\"ReceiveMessage\", (activity: IHubConnectionActivity) => {\r\n\r\n      console.log(\"MONITORING: \", activity);\r\n      if (this.appConfigService.DEBUG_ENABLED) debugger\r\n\r\n      switch (activity.signalType) {\r\n        case EnumSignalRType.TASK_PROGRESS:\r\n          this.longTaskService.message$.next(activity.message)\r\n          this.longTaskService.data$.next((activity as any).data)\r\n          this.longTaskService.error$.next((activity as any).error)\r\n          break;\r\n        case EnumSignalRType.LOG_IN:\r\n          if (isDevMode()) this.alertService.info(activity.message, alertOptions)\r\n          break;\r\n        case EnumSignalRType.ENTITY_CHANGED:\r\n          if (isDevMode()) this.alertService.info(activity.message, alertOptions)\r\n          break;\r\n        case EnumSignalRType.ACTIVITY:\r\n          const { loginTime } = activity;\r\n          const { sid, username, pathname, avatar, hubConnectionId, accessTime, userActivity } = activity.data;\r\n\r\n          const currentSid = this.authService.data$.value?.fullName;\r\n\r\n          console.group(\"ACTIVITY\")\r\n          console.log(\"isDevMode()\", isDevMode());\r\n          console.log(\"Incoming loginTime\", loginTime);\r\n          console.log(\"Your loginTime\", this.authService.data$.value?.loginTime!);\r\n          console.log(\"Incoming sid\", sid);\r\n          console.log(\"Your sid\", currentSid);\r\n\r\n          console.groupEnd();\r\n\r\n          if (loginTime < this.authService.data$.value?.loginTime! && sid === currentSid /*&& isDevMode()*/) {\r\n\r\n            if (isDevMode()) {\r\n\r\n              this.alertService.error(\r\n                `Trong môi trường Dev, tài khoản (${sid}) đã được dùng trước rồi nhé. Xin đăng nhập bằng tài khoản khác`,\r\n                { ...alertOptions, autoClose: false }\r\n              )\r\n\r\n              setTimeout(() => {\r\n                this.authService.userLogout().subscribe(x => {\r\n                  if (x.ok && x.status === 200) {\r\n                    this.authService.postLogout();\r\n                  }\r\n                });\r\n              }, 3000)\r\n\r\n            }\r\n          }\r\n\r\n          const merged = this.userActivityService.mergeActivities(userActivity)\r\n          const found = merged.filter(item => item.sid === sid)\r\n          if (found.length) {\r\n            const newState: IUserActivityData = { sid, username, pathname, avatar, hubConnectionId, accessTime }\r\n            merged.filter(item => item.sid !== sid).push(newState)\r\n          } else {\r\n            merged.push({ sid, username, pathname, avatar, hubConnectionId, accessTime })\r\n          }\r\n\r\n          this.userActivityService.userActivity$.next(merged);\r\n\r\n          break;\r\n        case EnumSignalRType.ACTIVITY_HISTORY_RESET:\r\n          this.userActivityService.userActivity$.next([]);\r\n          break;\r\n\r\n        default:\r\n          break;\r\n      }\r\n\r\n\r\n    })\r\n\r\n    const start = async () => {\r\n      let id\r\n      try {\r\n        this.hubConnectionService.message = \"HubConnection creating requested.\"\r\n        await connection.start();\r\n        console.log(\"🟢🟢🟢 SignalR Connected.\");\r\n        this.hubConnectionService.message = \"HubConnection created.\";\r\n        this.hubConnectionService.hubConnection$.next(connection);\r\n\r\n        if (id) clearTimeout(id)\r\n\r\n      } catch (err: any) {\r\n        console.group(`🔴🔴🔴 HUB CONNECTION PROBLEM ====================`)\r\n        this.hubConnectionService.message = err;\r\n        console.warn(\"hubConnection start() error: \", err)\r\n\r\n        if (typeof err === 'string') {\r\n          if (err.indexOf(`Status code '401'`) >= 0) {\r\n            console.warn(\"The token expired\")\r\n          } else {\r\n            id = setTimeout(start, 5000)\r\n          }\r\n        } else {\r\n          id = setTimeout(start, 5000)\r\n        }\r\n        console.groupEnd()\r\n      }\r\n    }\r\n\r\n    connection.onclose(async () => {\r\n      await start();\r\n    })\r\n\r\n    // Start the connection.\r\n    start();\r\n  }\r\n\r\n}\r\n"]}
@@ -3944,6 +3944,8 @@ class SocketService {
3944
3944
  });
3945
3945
  connection.on("ReceiveMessage", (activity) => {
3946
3946
  console.log("MONITORING: ", activity);
3947
+ if (this.appConfigService.DEBUG_ENABLED)
3948
+ debugger;
3947
3949
  switch (activity.signalType) {
3948
3950
  case EnumSignalRType.TASK_PROGRESS:
3949
3951
  this.longTaskService.message$.next(activity.message);