@tiba-spark/client-shared-lib 25.2.1-559 → 25.2.2-18

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.
@@ -263,17 +263,17 @@ export class SignalR {
263
263
  this.devicesStatusChanged(DeviceStatusDto.fromJS(data));
264
264
  break;
265
265
  case RtEventType.DynamicPricingCondition:
266
- datadogLogs.logger.info(`RT - Got ${JSON.stringify(data)} event`);
266
+ datadogLogs.logger.debug(`RT - Got ${JSON.stringify(data)} event`);
267
267
  this.notificationChanged(NotificationDto.fromJS(data), obj.guid);
268
268
  break;
269
269
  case RtEventType.Alert:
270
270
  case RtEventType.LostTicket:
271
271
  case RtEventType.LPRmismatch:
272
- datadogLogs.logger.info(`RT - Got ${JSON.stringify(data)} event`);
272
+ datadogLogs.logger.debug(`RT - Got ${JSON.stringify(data)} event`);
273
273
  this.alertChanged(AlertDto.fromJS(data), obj.guid);
274
274
  break;
275
275
  case RtEventType.ParkState:
276
- datadogLogs.logger.info(`RT - Got ${JSON.stringify(data)} event`);
276
+ datadogLogs.logger.debug(`RT - Got ${JSON.stringify(data)} event`);
277
277
  this.deviceActivityChanged(data);
278
278
  this.parkActivityChanged(data);
279
279
  break;
@@ -439,4 +439,4 @@ export function getSecondsBackoff(retryCount) {
439
439
  const [minSeconds, maxSeconds] = delaysTableInSeconds[retryCount] || [0, 0];
440
440
  return (Math.floor(Math.random() * (maxSeconds - minSeconds + 1)) + minSeconds) * ONE_SECOND_IN_MILLISECONDS;
441
441
  }
442
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"signalr.service.js","sourceRoot":"","sources":["../../../../../projects/client-shared-lib/src/libraries/services/signalr.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpStatusCode } from '@angular/common/http';\r\nimport { Injector } from '@angular/core';\r\nimport { datadogLogs } from '@datadog/browser-logs';\r\nimport { HttpTransportType, HubConnection, HubConnectionBuilder, HubConnectionState } from '@microsoft/signalr';\r\nimport { Dispatch } from '@ngxs-labs/dispatch-decorator';\r\nimport { Store } from '@ngxs/store';\r\nimport moment from 'moment';\r\nimport { MonoTypeOperatorFunction, of } from 'rxjs';\r\nimport { map } from 'rxjs/operators';\r\nimport { NotificationEventService } from '../components/notification/notification-event.service';\r\nimport { ONE_SECOND_IN_MILLISECONDS } from '../constants/global-constants';\r\nimport { AppType } from '../enums/app-type.enum';\r\nimport { AlertChangedAction, HandleAlertsAction, HandledNotificationAction, HandleNotificationAction, NotificationChangedAction } from '../modules/alerts-and-notifications/alerts-and-notifications.actions';\r\nimport { SignalRRefreshTokenAction } from '../modules/auth/refresh-token.actions';\r\nimport { FacilityChangedAction, FacilityRemoteCommandExecutedAction, ServicesRunningStatusChangedAction, ZoneChangedAction } from '../modules/facility/facility.actions';\r\nimport { FacilityState } from '../modules/facility/facility.state';\r\nimport { ParkActivityChangedAction } from '../modules/park-activities/park-activities.actions';\r\nimport { DeviceActivityChangedAction, DeviceEventChangedAction, DeviceStatusChangedAction, LprTransactionsChangedAction } from '../modules/park-manager/park-manager.actions';\r\nimport { SidenavState } from '../modules/sidenav/sidenav.state';\r\nimport { AddSmartparkAction } from '../modules/smartparks/smartpark-dialog.actions';\r\nimport { AlertDto, NotificationDto, SmartparkDto } from '../service-proxy/cloud-service-proxies';\r\nimport {\r\n  DeviceEventDto, DeviceStatusDto, EventActivityDto, FacilityDto, FacilityRemoteCommandEvent,\r\n  FacilityRemoteCommandTypes, LprTransactionDto, NotificationEventType, NotificationSubscriptionDto,\r\n  RTEventSubscriptionDto, RtEventType, ServicesRunningStatusDto, ZoneDto\r\n} from '../service-proxy/edge-service-proxies';\r\nimport { AppConfigService } from './app-config.service';\r\nimport { GeneralActionService } from './general-action.service';\r\nimport { RealtimeEventService } from './realtime-event.service';\r\nimport { SessionStorageService } from './session-storage.service';\r\n\r\nexport class SignalRObject {\r\n  constructor(public guid: string, public jsonPayload: string) {\r\n  }\r\n}\r\n\r\nexport class RTObjectObject extends SignalRObject {\r\n  constructor(public rtEventType: RtEventType, public parkId: number, public guid: string, public jsonPayload: string) {\r\n    super(guid, jsonPayload);\r\n  }\r\n}\r\n\r\nexport class SparkNotification extends SignalRObject {\r\n  constructor(public notificationType: NotificationEventType, public guid: string, public identifier: string, public jsonPayload: string) {\r\n    super(guid, jsonPayload);\r\n  }\r\n}\r\n\r\nexport abstract class SignalR {\r\n\r\n  public connection: HubConnection;\r\n  public subscriptionQueue: any[] = [];\r\n  public notificationSubscriptionQueue: any[] = [];\r\n\r\n  protected store: Store;\r\n  protected realtimeEventService: RealtimeEventService;\r\n  protected notificationEventService: NotificationEventService;\r\n  protected sessionStorageService: SessionStorageService;\r\n  protected appConfig: AppConfigService;\r\n  protected generalActionService: GeneralActionService;\r\n\r\n  constructor(public injector: Injector) {\r\n    this.store = injector.get(Store);\r\n    this.realtimeEventService = injector.get(RealtimeEventService);\r\n    this.notificationEventService = injector.get(NotificationEventService);\r\n    this.sessionStorageService = injector.get(SessionStorageService);\r\n    this.appConfig = injector.get(AppConfigService);\r\n    this.generalActionService = injector.get(GeneralActionService);\r\n  }\r\n\r\n  public initRealtimeEventListeners() {\r\n    const config = this.appConfig.getConfig();\r\n    const baseUrl = config.appType === AppType.Mobile ? config.apiBaseURL : '';\r\n    const url = `${baseUrl}/realtime`;\r\n\r\n    datadogLogs.logger.info(`RT API Base Url - ${url}`);\r\n\r\n    const maxConsecutiveFailedRetryCount = config.signalR.maxConsecutiveFailedRetryCount;\r\n\r\n    this.connection = new HubConnectionBuilder()\r\n      .withUrl(url, {\r\n        accessTokenFactory: () => this.sessionStorageService.accessToken,\r\n        skipNegotiation: true,  // Skip the negotiation step\r\n        transport: HttpTransportType.WebSockets  // Use WebSockets directly\r\n      })\r\n      .withAutomaticReconnect(new TibaRetryPolicy(maxConsecutiveFailedRetryCount))\r\n      .build();\r\n\r\n    this.connection.onreconnecting((error) => {\r\n      datadogLogs.logger.info('Attempting to reconnect:', error);\r\n    });\r\n\r\n    this.connection.onclose((error) => {\r\n      datadogLogs.logger.info('Connection closed after all retry attempts:', error);\r\n    });\r\n\r\n    this.connection.onreconnected((connectionId) => {\r\n      datadogLogs.logger.info(`Successfully reconnected SIGNALR!. ConnectionId: ${connectionId}`);\r\n\r\n      this.checkForUpdate();\r\n      const guid = this.store.selectSnapshot(FacilityState.guid);\r\n      if (!!guid) {\r\n        this.setSparkCoreConnection(true, guid);\r\n      }\r\n      const reconnectRtEventsSubscriptions = this.realtimeEventService.getSubscriptionForReconnect();\r\n      this.invokeRealtimeRegistration(reconnectRtEventsSubscriptions, this.handleRealTimeAwaitingSubscriptions.bind(this));\r\n\r\n      const notificationSubscriptions = this.notificationEventService.getSubscriptionForReconnect();\r\n      notificationSubscriptions.forEach(notificationSubscription => {\r\n        this.invokeNotificationRegistration(notificationSubscription);\r\n      });\r\n\r\n      this.handleNotificationAwaitingSubscription();\r\n    });\r\n\r\n    this.connection.on('RtEvent', (rtEventType: RtEventType, parkId: number, guid: string, jsonPayload: string) => {\r\n      of(new RTObjectObject(rtEventType, parkId, guid, jsonPayload))\r\n        .pipe(this.handleJsonPayloadToLower())\r\n        .subscribe((res) => {\r\n          this._dispatchRtEvent(res as RTObjectObject);\r\n        });\r\n    });\r\n\r\n    this.connection.on('Notification', (type: NotificationEventType, guid: string, identifier: string, jsonPayload: string) => {\r\n      of(new SparkNotification(type, guid, identifier, jsonPayload))\r\n        .pipe(this.handleJsonPayloadToLower())\r\n        .subscribe((res) => {\r\n          this._dispatchNotification(res as SparkNotification);\r\n        });\r\n    });\r\n  }\r\n\r\n  protected abstract checkForUpdate(): void;\r\n\r\n  public connect() {\r\n    this._connect(this.connection);\r\n  }\r\n\r\n  public disconnect() {\r\n    this._disconnect(this.connection);\r\n  }\r\n\r\n  subscribeForRealtime(rtEventSubscriptions: RTEventSubscriptionDto, triggerFunction?: () => void) {\r\n    if (this.connection) {\r\n      if (this.connection.state !== HubConnectionState.Connected) {\r\n        this.subscriptionQueue.push(() => this.subscribeForRealtime(rtEventSubscriptions, triggerFunction));\r\n      } else {\r\n        const rtEventSubscriptionDelta = this.realtimeEventService.handleRealtimeEventsSubscriptions(rtEventSubscriptions);\r\n        if (rtEventSubscriptionDelta.subscribe.length || rtEventSubscriptionDelta.unSubscribe.length) {\r\n          this.invokeRealtimeRegistration(rtEventSubscriptionDelta, triggerFunction);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  subscribeForNotifications(notificationSubscription: NotificationSubscriptionDto, triggerFunction?: () => void) {\r\n    if (this.connection) {\r\n      if (this.connection.state !== HubConnectionState.Connected) {\r\n        this.notificationSubscriptionQueue.push(() => this.subscribeForNotifications(notificationSubscription, triggerFunction));\r\n      } else {\r\n        const notificationSubscriptionDelta = this.notificationEventService.handleNotificationSubscriptions(notificationSubscription);\r\n        if (!!notificationSubscriptionDelta) {\r\n          this.invokeNotificationRegistration(notificationSubscriptionDelta, triggerFunction);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  private invokeRealtimeRegistration(rtEventSubscriptions: RTEventSubscriptionDto, triggerFunction?: () => void) {\r\n    const appModule = this.store.selectSnapshot(SidenavState.appModule);\r\n    if (rtEventSubscriptions.userId) {\r\n      this.connection.invoke<RTEventSubscriptionDto>('RegisterPark', rtEventSubscriptions, appModule).then((subTo) => {\r\n        if (triggerFunction) {\r\n          triggerFunction();\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  private invokeNotificationRegistration(notificationSubscription: NotificationSubscriptionDto, triggerFunction?: () => void) {\r\n    if (notificationSubscription && notificationSubscription.userId) {\r\n      this.connection.invoke<NotificationSubscriptionDto>('RegisterNotifications', notificationSubscription).then((subTo) => {\r\n        if (triggerFunction) {\r\n          triggerFunction();\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  public setSparkCoreConnection(isConnected: boolean, guid: string) {\r\n    const servicesRunningStatus = this.store.selectSnapshot(FacilityState.servicesRunningStatusDictionary)[guid];\r\n    servicesRunningStatus.isSparkCoreConnected = isConnected;\r\n    if (!isConnected) {\r\n      const facilityGuid = this.store.selectSnapshot(FacilityState.guid);\r\n      const serverClientTimeSpan = this.store.selectSnapshot(FacilityState.clientServerDiffDictionary)[facilityGuid] || 0;\r\n      servicesRunningStatus.sparkCoreDisconnectedTimestamp = moment().subtract(serverClientTimeSpan, 'milliseconds');\r\n    } else {\r\n      servicesRunningStatus.sparkCoreDisconnectedTimestamp = null;\r\n    }\r\n    this.servicesRunningStatusChanged(servicesRunningStatus, guid);\r\n  }\r\n\r\n  private handleJsonPayloadToLower(): MonoTypeOperatorFunction<SignalRObject> {\r\n    return $input => $input.pipe(map(res => {\r\n      const obj = JSON.parse(res.jsonPayload);\r\n      res.jsonPayload = JSON.stringify(obj, (key, value) => {\r\n        if (value && typeof value === 'object' && !Array.isArray(value)) {\r\n          const replacement = {};\r\n          for (const k in value) {\r\n            if (Object.hasOwnProperty.call(value, k)) {\r\n              if (k.length === 2) {\r\n                replacement[k && k.toLowerCase()] = value[k];\r\n              } else {\r\n                replacement[k && k.charAt(0).toLowerCase() + k.substring(1)] = value[k];\r\n              }\r\n            }\r\n          }\r\n          return replacement;\r\n        }\r\n        return value;\r\n      });\r\n      return res;\r\n    }));\r\n  }\r\n\r\n  protected abstract dispatchNotification(obj: SparkNotification): void;\r\n\r\n  private _dispatchNotification(obj: SparkNotification) {\r\n    const data = JSON.parse(obj.jsonPayload);\r\n    console.debug(`Received Notification type ===> ${obj.notificationType}`);\r\n    switch (obj.notificationType) {\r\n      case NotificationEventType.InitialCloudConnect:\r\n        this.initializeSmartParkConnection(data);\r\n        break;\r\n      case NotificationEventType.FacilityRemoteCommandExecuted:\r\n        // TODO: this condition will be removed when all \"FacilityRemoteCommandExecuted\" notification\r\n        // will be removed upon being executed in the server\r\n        // For more explanation see: SPRK3-6704\r\n        if (data.type === FacilityRemoteCommandTypes.TransmitSpecialDays) {\r\n          const notificationSubscription = this.notificationEventService.getNotificationSubscriptionsEntity();\r\n          notificationSubscription.type = obj.notificationType;\r\n          notificationSubscription.unsubscribe = true;\r\n          notificationSubscription.identifier = this.notificationEventService.getNotificationIdentifier(data.guid, data.parkId,\r\n            obj.notificationType, notificationSubscription.userId);\r\n          this.subscribeForNotifications(notificationSubscription);\r\n        }\r\n\r\n        this.facilityRemoteCommandExecuted(data);\r\n        break;\r\n      case NotificationEventType.GeneralActions:\r\n        this.generalActionService.dispatchGeneralActions(data);\r\n        break;\r\n      case NotificationEventType.HandleAlert:\r\n        this.handleAlerts(AlertDto.fromJS(data), obj.guid);\r\n        break;\r\n      case NotificationEventType.HandledNotification:\r\n        this.handledNotification(NotificationDto.fromJS(data), obj.guid);\r\n        break;\r\n      case NotificationEventType.HandleNotification:\r\n        this.handleNotification(NotificationDto.fromJS(data), obj.guid);\r\n        break;\r\n\r\n      case NotificationEventType.ReportGenerated:\r\n      case NotificationEventType.ReceiptGenerated:\r\n      case NotificationEventType.StickerGenerated:\r\n      case NotificationEventType.ApplicationUpdate:\r\n      case NotificationEventType.CreateRole:\r\n      case NotificationEventType.UpdateRole:\r\n        this.dispatchNotification(obj);\r\n        break;\r\n      default:\r\n        console.debug(`Unknown notification type ===> ${obj.notificationType}`);\r\n        break;\r\n    }\r\n  }\r\n\r\n  protected abstract dispatchRtEvent(obj: RTObjectObject): void;\r\n\r\n  private _dispatchRtEvent(obj: RTObjectObject) {\r\n    const data = JSON.parse(obj.jsonPayload);\r\n    switch (obj.rtEventType) {\r\n      case RtEventType.DeviceStatus:\r\n        this.devicesStatusChanged(DeviceStatusDto.fromJS(data));\r\n        break;\r\n\r\n      case RtEventType.DynamicPricingCondition:\r\n        datadogLogs.logger.info(`RT - Got ${JSON.stringify(data)} event`);\r\n        this.notificationChanged(NotificationDto.fromJS(data), obj.guid);\r\n        break;\r\n\r\n      case RtEventType.Alert:\r\n      case RtEventType.LostTicket:\r\n      case RtEventType.LPRmismatch:\r\n        datadogLogs.logger.info(`RT - Got ${JSON.stringify(data)} event`);\r\n        this.alertChanged(AlertDto.fromJS(data), obj.guid);\r\n        break;\r\n\r\n      case RtEventType.ParkState:\r\n        datadogLogs.logger.info(`RT - Got ${JSON.stringify(data)} event`);\r\n        this.deviceActivityChanged(data);\r\n        this.parkActivityChanged(data);\r\n        break;\r\n\r\n      case RtEventType.DeviceEvent:\r\n        this.deviceEventChanged(data);\r\n        break;\r\n\r\n      case RtEventType.ServicesStatus:\r\n        this.servicesRunningStatusChanged(ServicesRunningStatusDto.fromJS(data), obj.guid);\r\n        break;\r\n\r\n      case RtEventType.Zone:\r\n        this.zoneChanged(ZoneDto.fromJS(data), obj.parkId);\r\n        break;\r\n\r\n      case RtEventType.Facility:\r\n        this.facilityChanged(FacilityDto.fromJS(data), obj.guid);\r\n        break;\r\n\r\n      case RtEventType.Occupancy:\r\n      case RtEventType.Revenue:\r\n      case RtEventType.OpenTicketTransaction:\r\n      case RtEventType.CloseTicketTransaction:\r\n      case RtEventType.MonthlyTransaction:\r\n      case RtEventType.GuestTransaction:\r\n      case RtEventType.PaymentTransaction:\r\n      case RtEventType.LPRTransaction:\r\n        this.dispatchRtEvent(obj);\r\n        break;\r\n\r\n      default:\r\n        console.debug(`Unknown event type ===> ${obj.rtEventType}`);\r\n        break;\r\n    }\r\n  }\r\n\r\n  private _connect(connection: HubConnection) {\r\n    console.debug('SignalR Establishing Connection...');\r\n    connection.start()\r\n      .then(() => {\r\n        console.debug(`SignalR Connection Established!`);\r\n        this.handleRealTimeAwaitingSubscriptions();\r\n        this.handleNotificationAwaitingSubscription();\r\n      })\r\n      .catch(async (e) => {\r\n        this.retryConnection(connection, 1);\r\n      });\r\n  }\r\n\r\n  private _disconnect(connection: HubConnection) {\r\n    console.debug('SignalR Stopping Connection...');\r\n    connection?.stop()\r\n      .then(() => {\r\n        console.debug(`SignalR Connection Stopped!`);\r\n        this.handleDisconnect();\r\n      })\r\n      .catch(async (err) => {\r\n        console.error(`Error => ${err}, Timestamp: ${new Date()}`);\r\n      });\r\n  }\r\n\r\n  private retryConnection(connection: HubConnection, retryCount: number): void {\r\n    setTimeout(() => {\r\n      console.debug(`SignalR Establishing Connection. Retry #${retryCount}. Timestamp: ${new Date()}`);\r\n      connection.start()\r\n        .then(() => {\r\n          console.debug(`SignalR Connection Established! Retry #${retryCount}`);\r\n          this.handleRealTimeAwaitingSubscriptions();\r\n          this.handleNotificationAwaitingSubscription();\r\n        })\r\n        .catch(() => {\r\n          const config = this.appConfig.getConfig();\r\n\r\n          if (retryCount <= config.signalR.maxConsecutiveFailedRetryCount) {\r\n            this.retryConnection(connection, retryCount + 1);\r\n          }\r\n        });\r\n    }, getSecondsBackoff(retryCount));\r\n  }\r\n\r\n  private handleRealTimeAwaitingSubscriptions() {\r\n    this.subscriptionQueue.forEach(awaitingSubscription => awaitingSubscription());\r\n    this.subscriptionQueue.splice(0);\r\n  }\r\n  private handleNotificationAwaitingSubscription() {\r\n    this.notificationSubscriptionQueue.forEach(awaitingSubscription => awaitingSubscription());\r\n    this.notificationSubscriptionQueue.splice(0);\r\n  }\r\n\r\n  private handleDisconnect() {\r\n    this.subscriptionQueue = [];\r\n    this.notificationSubscriptionQueue = [];\r\n    this.realtimeEventService.resetAllSubscriptions();\r\n  }\r\n\r\n  @Dispatch() devicesStatusChanged = (deviceStatus: DeviceStatusDto) =>\r\n    new DeviceStatusChangedAction(deviceStatus);\r\n  @Dispatch() facilityChanged = (data: FacilityDto, guid: string) =>\r\n    new FacilityChangedAction(data, guid);\r\n  @Dispatch() servicesRunningStatusChanged = (servicesRunningStatus: ServicesRunningStatusDto, guid: string) =>\r\n    new ServicesRunningStatusChangedAction(servicesRunningStatus, guid);\r\n  @Dispatch() parkActivityChanged = (activity: EventActivityDto) =>\r\n    new ParkActivityChangedAction(activity);\r\n  @Dispatch() deviceEventChanged = (devEvent: DeviceEventDto) =>\r\n    new DeviceEventChangedAction(devEvent);\r\n  @Dispatch() deviceActivityChanged = (eventActivity: EventActivityDto) =>\r\n    new DeviceActivityChangedAction(eventActivity);\r\n  @Dispatch() lprTransactionsChanged = (lprTrans: LprTransactionDto) =>\r\n    new LprTransactionsChangedAction(lprTrans);\r\n  @Dispatch() alertChanged = (alertDto: AlertDto, guid: string) =>\r\n    new AlertChangedAction(alertDto, guid);\r\n  @Dispatch() notificationChanged = (notificationDto: NotificationDto, guid: string) =>\r\n    new NotificationChangedAction(notificationDto, guid);\r\n  @Dispatch() handledNotification = (notificationDto: NotificationDto, guid: string) =>\r\n    new HandledNotificationAction(notificationDto, guid);\r\n  @Dispatch() handleAlerts = (alertDto: AlertDto, guid: string) =>\r\n    new HandleAlertsAction(alertDto, guid);\r\n  @Dispatch() handleNotification = (notificationDto: NotificationDto, guid: string) =>\r\n    new HandleNotificationAction(notificationDto, guid);\r\n  @Dispatch() zoneChanged = (zoneDto: ZoneDto, parkId: number) =>\r\n    new ZoneChangedAction(zoneDto, parkId);\r\n  @Dispatch() initializeSmartParkConnection = (smartpark: SmartparkDto) =>\r\n    new AddSmartparkAction(smartpark);\r\n  @Dispatch() facilityRemoteCommandExecuted = (facilityRemoteCommandEvent: FacilityRemoteCommandEvent) =>\r\n    new FacilityRemoteCommandExecutedAction(facilityRemoteCommandEvent);\r\n}\r\n\r\nexport class TibaRetryPolicy implements signalR.IRetryPolicy {\r\n\r\n  private maxConsecutiveFailedRetryCount: number;\r\n\r\n  constructor(maxConsecutiveFailedRetryCount: number) {\r\n    this.maxConsecutiveFailedRetryCount = maxConsecutiveFailedRetryCount;\r\n  }\r\n\r\n  nextRetryDelayInMilliseconds(retryContext: signalR.RetryContext): number {\r\n    let milliseconds: number = null;\r\n    const currentRetryCount = retryContext.previousRetryCount + 1;\r\n\r\n    if (currentRetryCount < this.maxConsecutiveFailedRetryCount) {\r\n      const unauthorized = retryContext.retryReason.message.includes(`Status code '${HttpStatusCode.Unauthorized}'`);\r\n\r\n      if (unauthorized) {\r\n        datadogLogs.logger.info(`TibaRetryPolicy -> unauthorized token. Message:  ${retryContext.retryReason.message}`);\r\n        this.signalRRefreshToken();\r\n      } else {\r\n        datadogLogs.logger.info(`TibaRetryPolicy -> failed negotiation #${currentRetryCount}. Message: ${retryContext.retryReason.message}`);\r\n\r\n        milliseconds = getSecondsBackoff(currentRetryCount);\r\n      }\r\n    }\r\n\r\n    return milliseconds;\r\n  }\r\n\r\n  @Dispatch() signalRRefreshToken = () => new SignalRRefreshTokenAction();\r\n}\r\n\r\nexport function getSecondsBackoff(retryCount: number): number {\r\n  const delaysTableInSeconds: { [key: number]: number[]; } = {\r\n    1: [5, 20], //5s - 20s\r\n    2: [25, 40], // 25s - 40s\r\n    3: [45, 60], // 45s - 60s\r\n    4: [65, 80], // 65s - 80s\r\n    5: [600, 900],  // 10m - 15m\r\n  };\r\n  const [minSeconds, maxSeconds] = delaysTableInSeconds[retryCount] || [0, 0];\r\n  return (Math.floor(Math.random() * (maxSeconds - minSeconds + 1)) + minSeconds) * ONE_SECOND_IN_MILLISECONDS;\r\n}\r\n"]}
442
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"signalr.service.js","sourceRoot":"","sources":["../../../../../projects/client-shared-lib/src/libraries/services/signalr.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpStatusCode } from '@angular/common/http';\r\nimport { Injector } from '@angular/core';\r\nimport { datadogLogs } from '@datadog/browser-logs';\r\nimport { HttpTransportType, HubConnection, HubConnectionBuilder, HubConnectionState } from '@microsoft/signalr';\r\nimport { Dispatch } from '@ngxs-labs/dispatch-decorator';\r\nimport { Store } from '@ngxs/store';\r\nimport moment from 'moment';\r\nimport { MonoTypeOperatorFunction, of } from 'rxjs';\r\nimport { map } from 'rxjs/operators';\r\nimport { NotificationEventService } from '../components/notification/notification-event.service';\r\nimport { ONE_SECOND_IN_MILLISECONDS } from '../constants/global-constants';\r\nimport { AppType } from '../enums/app-type.enum';\r\nimport { AlertChangedAction, HandleAlertsAction, HandledNotificationAction, HandleNotificationAction, NotificationChangedAction } from '../modules/alerts-and-notifications/alerts-and-notifications.actions';\r\nimport { SignalRRefreshTokenAction } from '../modules/auth/refresh-token.actions';\r\nimport { FacilityChangedAction, FacilityRemoteCommandExecutedAction, ServicesRunningStatusChangedAction, ZoneChangedAction } from '../modules/facility/facility.actions';\r\nimport { FacilityState } from '../modules/facility/facility.state';\r\nimport { ParkActivityChangedAction } from '../modules/park-activities/park-activities.actions';\r\nimport { DeviceActivityChangedAction, DeviceEventChangedAction, DeviceStatusChangedAction, LprTransactionsChangedAction } from '../modules/park-manager/park-manager.actions';\r\nimport { SidenavState } from '../modules/sidenav/sidenav.state';\r\nimport { AddSmartparkAction } from '../modules/smartparks/smartpark-dialog.actions';\r\nimport { AlertDto, NotificationDto, SmartparkDto } from '../service-proxy/cloud-service-proxies';\r\nimport {\r\n  DeviceEventDto, DeviceStatusDto, EventActivityDto, FacilityDto, FacilityRemoteCommandEvent,\r\n  FacilityRemoteCommandTypes, LprTransactionDto, NotificationEventType, NotificationSubscriptionDto,\r\n  RTEventSubscriptionDto, RtEventType, ServicesRunningStatusDto, ZoneDto\r\n} from '../service-proxy/edge-service-proxies';\r\nimport { AppConfigService } from './app-config.service';\r\nimport { GeneralActionService } from './general-action.service';\r\nimport { RealtimeEventService } from './realtime-event.service';\r\nimport { SessionStorageService } from './session-storage.service';\r\n\r\nexport class SignalRObject {\r\n  constructor(public guid: string, public jsonPayload: string) {\r\n  }\r\n}\r\n\r\nexport class RTObjectObject extends SignalRObject {\r\n  constructor(public rtEventType: RtEventType, public parkId: number, public guid: string, public jsonPayload: string) {\r\n    super(guid, jsonPayload);\r\n  }\r\n}\r\n\r\nexport class SparkNotification extends SignalRObject {\r\n  constructor(public notificationType: NotificationEventType, public guid: string, public identifier: string, public jsonPayload: string) {\r\n    super(guid, jsonPayload);\r\n  }\r\n}\r\n\r\nexport abstract class SignalR {\r\n\r\n  public connection: HubConnection;\r\n  public subscriptionQueue: any[] = [];\r\n  public notificationSubscriptionQueue: any[] = [];\r\n\r\n  protected store: Store;\r\n  protected realtimeEventService: RealtimeEventService;\r\n  protected notificationEventService: NotificationEventService;\r\n  protected sessionStorageService: SessionStorageService;\r\n  protected appConfig: AppConfigService;\r\n  protected generalActionService: GeneralActionService;\r\n\r\n  constructor(public injector: Injector) {\r\n    this.store = injector.get(Store);\r\n    this.realtimeEventService = injector.get(RealtimeEventService);\r\n    this.notificationEventService = injector.get(NotificationEventService);\r\n    this.sessionStorageService = injector.get(SessionStorageService);\r\n    this.appConfig = injector.get(AppConfigService);\r\n    this.generalActionService = injector.get(GeneralActionService);\r\n  }\r\n\r\n  public initRealtimeEventListeners() {\r\n    const config = this.appConfig.getConfig();\r\n    const baseUrl = config.appType === AppType.Mobile ? config.apiBaseURL : '';\r\n    const url = `${baseUrl}/realtime`;\r\n\r\n    datadogLogs.logger.info(`RT API Base Url - ${url}`);\r\n\r\n    const maxConsecutiveFailedRetryCount = config.signalR.maxConsecutiveFailedRetryCount;\r\n\r\n    this.connection = new HubConnectionBuilder()\r\n      .withUrl(url, {\r\n        accessTokenFactory: () => this.sessionStorageService.accessToken,\r\n        skipNegotiation: true,  // Skip the negotiation step\r\n        transport: HttpTransportType.WebSockets  // Use WebSockets directly\r\n      })\r\n      .withAutomaticReconnect(new TibaRetryPolicy(maxConsecutiveFailedRetryCount))\r\n      .build();\r\n\r\n    this.connection.onreconnecting((error) => {\r\n      datadogLogs.logger.info('Attempting to reconnect:', error);\r\n    });\r\n\r\n    this.connection.onclose((error) => {\r\n      datadogLogs.logger.info('Connection closed after all retry attempts:', error);\r\n    });\r\n\r\n    this.connection.onreconnected((connectionId) => {\r\n      datadogLogs.logger.info(`Successfully reconnected SIGNALR!. ConnectionId: ${connectionId}`);\r\n\r\n      this.checkForUpdate();\r\n      const guid = this.store.selectSnapshot(FacilityState.guid);\r\n      if (!!guid) {\r\n        this.setSparkCoreConnection(true, guid);\r\n      }\r\n      const reconnectRtEventsSubscriptions = this.realtimeEventService.getSubscriptionForReconnect();\r\n      this.invokeRealtimeRegistration(reconnectRtEventsSubscriptions, this.handleRealTimeAwaitingSubscriptions.bind(this));\r\n\r\n      const notificationSubscriptions = this.notificationEventService.getSubscriptionForReconnect();\r\n      notificationSubscriptions.forEach(notificationSubscription => {\r\n        this.invokeNotificationRegistration(notificationSubscription);\r\n      });\r\n\r\n      this.handleNotificationAwaitingSubscription();\r\n    });\r\n\r\n    this.connection.on('RtEvent', (rtEventType: RtEventType, parkId: number, guid: string, jsonPayload: string) => {\r\n      of(new RTObjectObject(rtEventType, parkId, guid, jsonPayload))\r\n        .pipe(this.handleJsonPayloadToLower())\r\n        .subscribe((res) => {\r\n          this._dispatchRtEvent(res as RTObjectObject);\r\n        });\r\n    });\r\n\r\n    this.connection.on('Notification', (type: NotificationEventType, guid: string, identifier: string, jsonPayload: string) => {\r\n      of(new SparkNotification(type, guid, identifier, jsonPayload))\r\n        .pipe(this.handleJsonPayloadToLower())\r\n        .subscribe((res) => {\r\n          this._dispatchNotification(res as SparkNotification);\r\n        });\r\n    });\r\n  }\r\n\r\n  protected abstract checkForUpdate(): void;\r\n\r\n  public connect() {\r\n    this._connect(this.connection);\r\n  }\r\n\r\n  public disconnect() {\r\n    this._disconnect(this.connection);\r\n  }\r\n\r\n  subscribeForRealtime(rtEventSubscriptions: RTEventSubscriptionDto, triggerFunction?: () => void) {\r\n    if (this.connection) {\r\n      if (this.connection.state !== HubConnectionState.Connected) {\r\n        this.subscriptionQueue.push(() => this.subscribeForRealtime(rtEventSubscriptions, triggerFunction));\r\n      } else {\r\n        const rtEventSubscriptionDelta = this.realtimeEventService.handleRealtimeEventsSubscriptions(rtEventSubscriptions);\r\n        if (rtEventSubscriptionDelta.subscribe.length || rtEventSubscriptionDelta.unSubscribe.length) {\r\n          this.invokeRealtimeRegistration(rtEventSubscriptionDelta, triggerFunction);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  subscribeForNotifications(notificationSubscription: NotificationSubscriptionDto, triggerFunction?: () => void) {\r\n    if (this.connection) {\r\n      if (this.connection.state !== HubConnectionState.Connected) {\r\n        this.notificationSubscriptionQueue.push(() => this.subscribeForNotifications(notificationSubscription, triggerFunction));\r\n      } else {\r\n        const notificationSubscriptionDelta = this.notificationEventService.handleNotificationSubscriptions(notificationSubscription);\r\n        if (!!notificationSubscriptionDelta) {\r\n          this.invokeNotificationRegistration(notificationSubscriptionDelta, triggerFunction);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  private invokeRealtimeRegistration(rtEventSubscriptions: RTEventSubscriptionDto, triggerFunction?: () => void) {\r\n    const appModule = this.store.selectSnapshot(SidenavState.appModule);\r\n    if (rtEventSubscriptions.userId) {\r\n      this.connection.invoke<RTEventSubscriptionDto>('RegisterPark', rtEventSubscriptions, appModule).then((subTo) => {\r\n        if (triggerFunction) {\r\n          triggerFunction();\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  private invokeNotificationRegistration(notificationSubscription: NotificationSubscriptionDto, triggerFunction?: () => void) {\r\n    if (notificationSubscription && notificationSubscription.userId) {\r\n      this.connection.invoke<NotificationSubscriptionDto>('RegisterNotifications', notificationSubscription).then((subTo) => {\r\n        if (triggerFunction) {\r\n          triggerFunction();\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  public setSparkCoreConnection(isConnected: boolean, guid: string) {\r\n    const servicesRunningStatus = this.store.selectSnapshot(FacilityState.servicesRunningStatusDictionary)[guid];\r\n    servicesRunningStatus.isSparkCoreConnected = isConnected;\r\n    if (!isConnected) {\r\n      const facilityGuid = this.store.selectSnapshot(FacilityState.guid);\r\n      const serverClientTimeSpan = this.store.selectSnapshot(FacilityState.clientServerDiffDictionary)[facilityGuid] || 0;\r\n      servicesRunningStatus.sparkCoreDisconnectedTimestamp = moment().subtract(serverClientTimeSpan, 'milliseconds');\r\n    } else {\r\n      servicesRunningStatus.sparkCoreDisconnectedTimestamp = null;\r\n    }\r\n    this.servicesRunningStatusChanged(servicesRunningStatus, guid);\r\n  }\r\n\r\n  private handleJsonPayloadToLower(): MonoTypeOperatorFunction<SignalRObject> {\r\n    return $input => $input.pipe(map(res => {\r\n      const obj = JSON.parse(res.jsonPayload);\r\n      res.jsonPayload = JSON.stringify(obj, (key, value) => {\r\n        if (value && typeof value === 'object' && !Array.isArray(value)) {\r\n          const replacement = {};\r\n          for (const k in value) {\r\n            if (Object.hasOwnProperty.call(value, k)) {\r\n              if (k.length === 2) {\r\n                replacement[k && k.toLowerCase()] = value[k];\r\n              } else {\r\n                replacement[k && k.charAt(0).toLowerCase() + k.substring(1)] = value[k];\r\n              }\r\n            }\r\n          }\r\n          return replacement;\r\n        }\r\n        return value;\r\n      });\r\n      return res;\r\n    }));\r\n  }\r\n\r\n  protected abstract dispatchNotification(obj: SparkNotification): void;\r\n\r\n  private _dispatchNotification(obj: SparkNotification) {\r\n    const data = JSON.parse(obj.jsonPayload);\r\n    console.debug(`Received Notification type ===> ${obj.notificationType}`);\r\n    switch (obj.notificationType) {\r\n      case NotificationEventType.InitialCloudConnect:\r\n        this.initializeSmartParkConnection(data);\r\n        break;\r\n      case NotificationEventType.FacilityRemoteCommandExecuted:\r\n        // TODO: this condition will be removed when all \"FacilityRemoteCommandExecuted\" notification\r\n        // will be removed upon being executed in the server\r\n        // For more explanation see: SPRK3-6704\r\n        if (data.type === FacilityRemoteCommandTypes.TransmitSpecialDays) {\r\n          const notificationSubscription = this.notificationEventService.getNotificationSubscriptionsEntity();\r\n          notificationSubscription.type = obj.notificationType;\r\n          notificationSubscription.unsubscribe = true;\r\n          notificationSubscription.identifier = this.notificationEventService.getNotificationIdentifier(data.guid, data.parkId,\r\n            obj.notificationType, notificationSubscription.userId);\r\n          this.subscribeForNotifications(notificationSubscription);\r\n        }\r\n\r\n        this.facilityRemoteCommandExecuted(data);\r\n        break;\r\n      case NotificationEventType.GeneralActions:\r\n        this.generalActionService.dispatchGeneralActions(data);\r\n        break;\r\n      case NotificationEventType.HandleAlert:\r\n        this.handleAlerts(AlertDto.fromJS(data), obj.guid);\r\n        break;\r\n      case NotificationEventType.HandledNotification:\r\n        this.handledNotification(NotificationDto.fromJS(data), obj.guid);\r\n        break;\r\n      case NotificationEventType.HandleNotification:\r\n        this.handleNotification(NotificationDto.fromJS(data), obj.guid);\r\n        break;\r\n\r\n      case NotificationEventType.ReportGenerated:\r\n      case NotificationEventType.ReceiptGenerated:\r\n      case NotificationEventType.StickerGenerated:\r\n      case NotificationEventType.ApplicationUpdate:\r\n      case NotificationEventType.CreateRole:\r\n      case NotificationEventType.UpdateRole:\r\n        this.dispatchNotification(obj);\r\n        break;\r\n      default:\r\n        console.debug(`Unknown notification type ===> ${obj.notificationType}`);\r\n        break;\r\n    }\r\n  }\r\n\r\n  protected abstract dispatchRtEvent(obj: RTObjectObject): void;\r\n\r\n  private _dispatchRtEvent(obj: RTObjectObject) {\r\n    const data = JSON.parse(obj.jsonPayload);\r\n    switch (obj.rtEventType) {\r\n      case RtEventType.DeviceStatus:\r\n        this.devicesStatusChanged(DeviceStatusDto.fromJS(data));\r\n        break;\r\n\r\n      case RtEventType.DynamicPricingCondition:\r\n        datadogLogs.logger.debug(`RT - Got ${JSON.stringify(data)} event`);\r\n        this.notificationChanged(NotificationDto.fromJS(data), obj.guid);\r\n        break;\r\n\r\n      case RtEventType.Alert:\r\n      case RtEventType.LostTicket:\r\n      case RtEventType.LPRmismatch:\r\n        datadogLogs.logger.debug(`RT - Got ${JSON.stringify(data)} event`);\r\n        this.alertChanged(AlertDto.fromJS(data), obj.guid);\r\n        break;\r\n\r\n      case RtEventType.ParkState:\r\n        datadogLogs.logger.debug(`RT - Got ${JSON.stringify(data)} event`);\r\n        this.deviceActivityChanged(data);\r\n        this.parkActivityChanged(data);\r\n        break;\r\n\r\n      case RtEventType.DeviceEvent:\r\n        this.deviceEventChanged(data);\r\n        break;\r\n\r\n      case RtEventType.ServicesStatus:\r\n        this.servicesRunningStatusChanged(ServicesRunningStatusDto.fromJS(data), obj.guid);\r\n        break;\r\n\r\n      case RtEventType.Zone:\r\n        this.zoneChanged(ZoneDto.fromJS(data), obj.parkId);\r\n        break;\r\n\r\n      case RtEventType.Facility:\r\n        this.facilityChanged(FacilityDto.fromJS(data), obj.guid);\r\n        break;\r\n\r\n      case RtEventType.Occupancy:\r\n      case RtEventType.Revenue:\r\n      case RtEventType.OpenTicketTransaction:\r\n      case RtEventType.CloseTicketTransaction:\r\n      case RtEventType.MonthlyTransaction:\r\n      case RtEventType.GuestTransaction:\r\n      case RtEventType.PaymentTransaction:\r\n      case RtEventType.LPRTransaction:\r\n        this.dispatchRtEvent(obj);\r\n        break;\r\n\r\n      default:\r\n        console.debug(`Unknown event type ===> ${obj.rtEventType}`);\r\n        break;\r\n    }\r\n  }\r\n\r\n  private _connect(connection: HubConnection) {\r\n    console.debug('SignalR Establishing Connection...');\r\n    connection.start()\r\n      .then(() => {\r\n        console.debug(`SignalR Connection Established!`);\r\n        this.handleRealTimeAwaitingSubscriptions();\r\n        this.handleNotificationAwaitingSubscription();\r\n      })\r\n      .catch(async (e) => {\r\n        this.retryConnection(connection, 1);\r\n      });\r\n  }\r\n\r\n  private _disconnect(connection: HubConnection) {\r\n    console.debug('SignalR Stopping Connection...');\r\n    connection?.stop()\r\n      .then(() => {\r\n        console.debug(`SignalR Connection Stopped!`);\r\n        this.handleDisconnect();\r\n      })\r\n      .catch(async (err) => {\r\n        console.error(`Error => ${err}, Timestamp: ${new Date()}`);\r\n      });\r\n  }\r\n\r\n  private retryConnection(connection: HubConnection, retryCount: number): void {\r\n    setTimeout(() => {\r\n      console.debug(`SignalR Establishing Connection. Retry #${retryCount}. Timestamp: ${new Date()}`);\r\n      connection.start()\r\n        .then(() => {\r\n          console.debug(`SignalR Connection Established! Retry #${retryCount}`);\r\n          this.handleRealTimeAwaitingSubscriptions();\r\n          this.handleNotificationAwaitingSubscription();\r\n        })\r\n        .catch(() => {\r\n          const config = this.appConfig.getConfig();\r\n\r\n          if (retryCount <= config.signalR.maxConsecutiveFailedRetryCount) {\r\n            this.retryConnection(connection, retryCount + 1);\r\n          }\r\n        });\r\n    }, getSecondsBackoff(retryCount));\r\n  }\r\n\r\n  private handleRealTimeAwaitingSubscriptions() {\r\n    this.subscriptionQueue.forEach(awaitingSubscription => awaitingSubscription());\r\n    this.subscriptionQueue.splice(0);\r\n  }\r\n  private handleNotificationAwaitingSubscription() {\r\n    this.notificationSubscriptionQueue.forEach(awaitingSubscription => awaitingSubscription());\r\n    this.notificationSubscriptionQueue.splice(0);\r\n  }\r\n\r\n  private handleDisconnect() {\r\n    this.subscriptionQueue = [];\r\n    this.notificationSubscriptionQueue = [];\r\n    this.realtimeEventService.resetAllSubscriptions();\r\n  }\r\n\r\n  @Dispatch() devicesStatusChanged = (deviceStatus: DeviceStatusDto) =>\r\n    new DeviceStatusChangedAction(deviceStatus);\r\n  @Dispatch() facilityChanged = (data: FacilityDto, guid: string) =>\r\n    new FacilityChangedAction(data, guid);\r\n  @Dispatch() servicesRunningStatusChanged = (servicesRunningStatus: ServicesRunningStatusDto, guid: string) =>\r\n    new ServicesRunningStatusChangedAction(servicesRunningStatus, guid);\r\n  @Dispatch() parkActivityChanged = (activity: EventActivityDto) =>\r\n    new ParkActivityChangedAction(activity);\r\n  @Dispatch() deviceEventChanged = (devEvent: DeviceEventDto) =>\r\n    new DeviceEventChangedAction(devEvent);\r\n  @Dispatch() deviceActivityChanged = (eventActivity: EventActivityDto) =>\r\n    new DeviceActivityChangedAction(eventActivity);\r\n  @Dispatch() lprTransactionsChanged = (lprTrans: LprTransactionDto) =>\r\n    new LprTransactionsChangedAction(lprTrans);\r\n  @Dispatch() alertChanged = (alertDto: AlertDto, guid: string) =>\r\n    new AlertChangedAction(alertDto, guid);\r\n  @Dispatch() notificationChanged = (notificationDto: NotificationDto, guid: string) =>\r\n    new NotificationChangedAction(notificationDto, guid);\r\n  @Dispatch() handledNotification = (notificationDto: NotificationDto, guid: string) =>\r\n    new HandledNotificationAction(notificationDto, guid);\r\n  @Dispatch() handleAlerts = (alertDto: AlertDto, guid: string) =>\r\n    new HandleAlertsAction(alertDto, guid);\r\n  @Dispatch() handleNotification = (notificationDto: NotificationDto, guid: string) =>\r\n    new HandleNotificationAction(notificationDto, guid);\r\n  @Dispatch() zoneChanged = (zoneDto: ZoneDto, parkId: number) =>\r\n    new ZoneChangedAction(zoneDto, parkId);\r\n  @Dispatch() initializeSmartParkConnection = (smartpark: SmartparkDto) =>\r\n    new AddSmartparkAction(smartpark);\r\n  @Dispatch() facilityRemoteCommandExecuted = (facilityRemoteCommandEvent: FacilityRemoteCommandEvent) =>\r\n    new FacilityRemoteCommandExecutedAction(facilityRemoteCommandEvent);\r\n}\r\n\r\nexport class TibaRetryPolicy implements signalR.IRetryPolicy {\r\n\r\n  private maxConsecutiveFailedRetryCount: number;\r\n\r\n  constructor(maxConsecutiveFailedRetryCount: number) {\r\n    this.maxConsecutiveFailedRetryCount = maxConsecutiveFailedRetryCount;\r\n  }\r\n\r\n  nextRetryDelayInMilliseconds(retryContext: signalR.RetryContext): number {\r\n    let milliseconds: number = null;\r\n    const currentRetryCount = retryContext.previousRetryCount + 1;\r\n\r\n    if (currentRetryCount < this.maxConsecutiveFailedRetryCount) {\r\n      const unauthorized = retryContext.retryReason.message.includes(`Status code '${HttpStatusCode.Unauthorized}'`);\r\n\r\n      if (unauthorized) {\r\n        datadogLogs.logger.info(`TibaRetryPolicy -> unauthorized token. Message:  ${retryContext.retryReason.message}`);\r\n        this.signalRRefreshToken();\r\n      } else {\r\n        datadogLogs.logger.info(`TibaRetryPolicy -> failed negotiation #${currentRetryCount}. Message: ${retryContext.retryReason.message}`);\r\n\r\n        milliseconds = getSecondsBackoff(currentRetryCount);\r\n      }\r\n    }\r\n\r\n    return milliseconds;\r\n  }\r\n\r\n  @Dispatch() signalRRefreshToken = () => new SignalRRefreshTokenAction();\r\n}\r\n\r\nexport function getSecondsBackoff(retryCount: number): number {\r\n  const delaysTableInSeconds: { [key: number]: number[]; } = {\r\n    1: [5, 20], //5s - 20s\r\n    2: [25, 40], // 25s - 40s\r\n    3: [45, 60], // 45s - 60s\r\n    4: [65, 80], // 65s - 80s\r\n    5: [600, 900],  // 10m - 15m\r\n  };\r\n  const [minSeconds, maxSeconds] = delaysTableInSeconds[retryCount] || [0, 0];\r\n  return (Math.floor(Math.random() * (maxSeconds - minSeconds + 1)) + minSeconds) * ONE_SECOND_IN_MILLISECONDS;\r\n}\r\n"]}
@@ -92816,17 +92816,17 @@ class SignalR {
92816
92816
  this.devicesStatusChanged(DeviceStatusDto.fromJS(data));
92817
92817
  break;
92818
92818
  case RtEventType.DynamicPricingCondition:
92819
- datadogLogs.logger.info(`RT - Got ${JSON.stringify(data)} event`);
92819
+ datadogLogs.logger.debug(`RT - Got ${JSON.stringify(data)} event`);
92820
92820
  this.notificationChanged(NotificationDto.fromJS(data), obj.guid);
92821
92821
  break;
92822
92822
  case RtEventType.Alert:
92823
92823
  case RtEventType.LostTicket:
92824
92824
  case RtEventType.LPRmismatch:
92825
- datadogLogs.logger.info(`RT - Got ${JSON.stringify(data)} event`);
92825
+ datadogLogs.logger.debug(`RT - Got ${JSON.stringify(data)} event`);
92826
92826
  this.alertChanged(AlertDto$1.fromJS(data), obj.guid);
92827
92827
  break;
92828
92828
  case RtEventType.ParkState:
92829
- datadogLogs.logger.info(`RT - Got ${JSON.stringify(data)} event`);
92829
+ datadogLogs.logger.debug(`RT - Got ${JSON.stringify(data)} event`);
92830
92830
  this.deviceActivityChanged(data);
92831
92831
  this.parkActivityChanged(data);
92832
92832
  break;