dt-common-device 7.6.15 → 7.8.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (233) hide show
  1. package/dist/alerts/Alert.service.d.ts +3 -0
  2. package/dist/alerts/Alert.service.js +35 -0
  3. package/dist/alerts/alert.types.d.ts +2 -0
  4. package/dist/alerts/alert.types.js +2 -0
  5. package/dist/entities/accessGroup/AccessGroup.repository.d.ts +2 -1
  6. package/dist/entities/accessGroup/AccessGroup.repository.js +4 -1
  7. package/dist/entities/accessGroup/AccessGroup.service.d.ts +2 -1
  8. package/dist/entities/accessGroup/AccessGroup.service.js +4 -3
  9. package/dist/entities/admin/Admin.repository.d.ts +1 -1
  10. package/dist/entities/admin/Admin.repository.js +1 -1
  11. package/dist/entities/admin/Admin.service.d.ts +1 -1
  12. package/dist/entities/admin/Admin.service.js +10 -7
  13. package/dist/entities/admin/IAdmin.d.ts +4 -0
  14. package/dist/entities/guest/Guest.repository.d.ts +1 -1
  15. package/dist/entities/guest/Guest.repository.js +5 -2
  16. package/dist/entities/guest/Guest.service.d.ts +1 -1
  17. package/dist/entities/guest/Guest.service.js +4 -1
  18. package/dist/entities/schedules/Schedule.repository.d.ts +1 -1
  19. package/dist/entities/schedules/Schedule.repository.js +5 -2
  20. package/dist/entities/schedules/Schedule.service.d.ts +1 -1
  21. package/dist/entities/schedules/Schedule.service.js +4 -1
  22. package/dist/entities/user/User.repository.js +4 -1
  23. package/dist/entities/user/User.service.d.ts +1 -1
  24. package/dist/entities/user/User.service.js +4 -1
  25. package/dist/entities/zone/Zone.service.js +4 -1
  26. package/dist/issues/Issue.model.d.ts +3 -3
  27. package/dist/issues/Issue.repository.js +2 -0
  28. package/dist/issues/Issue.service.d.ts +1 -0
  29. package/dist/issues/Issue.service.js +27 -4
  30. package/dist/issues/issue.types.d.ts +2 -1
  31. package/package.json +1 -1
  32. package/dist/admin/Admin.repository.d.ts +0 -7
  33. package/dist/admin/Admin.repository.js +0 -182
  34. package/dist/admin/Admin.service.d.ts +0 -5
  35. package/dist/admin/Admin.service.js +0 -17
  36. package/dist/admin/index.d.ts +0 -1
  37. package/dist/admin/index.js +0 -17
  38. package/dist/audit/AuditProperties.d.ts +0 -16
  39. package/dist/audit/AuditProperties.js +0 -2
  40. package/dist/chronicle/IChronicle.interface.d.ts +0 -14
  41. package/dist/chronicle/IChronicle.interface.js +0 -2
  42. package/dist/chronicle/chronicle.service.d.ts +0 -4
  43. package/dist/chronicle/chronicle.service.js +0 -44
  44. package/dist/connection/Connection.repository.d.ts +0 -8
  45. package/dist/connection/Connection.repository.js +0 -92
  46. package/dist/connection/Connection.service.d.ts +0 -8
  47. package/dist/connection/Connection.service.js +0 -32
  48. package/dist/connection/IConnection.d.ts +0 -28
  49. package/dist/connection/IConnection.js +0 -16
  50. package/dist/connection/index.d.ts +0 -2
  51. package/dist/connection/index.js +0 -18
  52. package/dist/device/cloud/entities/CloudConnection.d.ts +0 -6
  53. package/dist/device/cloud/entities/CloudConnection.js +0 -6
  54. package/dist/device/cloud/entities/CloudDevice.d.ts +0 -16
  55. package/dist/device/cloud/entities/CloudDevice.js +0 -26
  56. package/dist/device/cloud/entities/CloudDeviceService.d.ts +0 -5
  57. package/dist/device/cloud/entities/CloudDeviceService.js +0 -9
  58. package/dist/device/cloud/entities/DeviceFactory.d.ts +0 -7
  59. package/dist/device/cloud/entities/DeviceFactory.js +0 -80
  60. package/dist/device/cloud/entities/index.d.ts +0 -3
  61. package/dist/device/cloud/entities/index.js +0 -19
  62. package/dist/device/cloud/interface.d.ts +0 -101
  63. package/dist/device/cloud/interface.js +0 -3
  64. package/dist/device/cloud/interfaces/ICloudConnection.d.ts +0 -5
  65. package/dist/device/cloud/interfaces/ICloudConnection.js +0 -2
  66. package/dist/device/cloud/interfaces/ICloudDevice.d.ts +0 -9
  67. package/dist/device/cloud/interfaces/ICloudDevice.js +0 -2
  68. package/dist/device/cloud/interfaces/ICloudDeviceService.d.ts +0 -4
  69. package/dist/device/cloud/interfaces/ICloudDeviceService.js +0 -2
  70. package/dist/device/cloud/interfaces/IConnectionService.d.ts +0 -7
  71. package/dist/device/cloud/interfaces/IConnectionService.js +0 -2
  72. package/dist/device/cloud/interfaces/IDeviceConnectionService.d.ts +0 -7
  73. package/dist/device/cloud/interfaces/IDeviceConnectionService.js +0 -3
  74. package/dist/device/cloud/interfaces/IDeviceFactory.d.ts +0 -4
  75. package/dist/device/cloud/interfaces/IDeviceFactory.js +0 -2
  76. package/dist/device/cloud/interfaces/IDeviceService.d.ts +0 -8
  77. package/dist/device/cloud/interfaces/IDeviceService.js +0 -2
  78. package/dist/device/cloud/interfaces/IDevicesService.d.ts +0 -9
  79. package/dist/device/cloud/interfaces/IDevicesService.js +0 -2
  80. package/dist/device/cloud/interfaces/IHubService.d.ts +0 -5
  81. package/dist/device/cloud/interfaces/IHubService.js +0 -2
  82. package/dist/device/cloud/interfaces/IRawDataTransformer.d.ts +0 -4
  83. package/dist/device/cloud/interfaces/IRawDataTransformer.js +0 -2
  84. package/dist/device/cloud/interfaces/IRawDevice.d.ts +0 -17
  85. package/dist/device/cloud/interfaces/IRawDevice.js +0 -11
  86. package/dist/device/cloud/interfaces/index.d.ts +0 -5
  87. package/dist/device/cloud/interfaces/index.js +0 -21
  88. package/dist/device/cloud/services/CloudDevice.service.d.ts +0 -5
  89. package/dist/device/cloud/services/CloudDevice.service.js +0 -9
  90. package/dist/device/cloud/services/Connection.service.d.ts +0 -8
  91. package/dist/device/cloud/services/Connection.service.js +0 -6
  92. package/dist/device/cloud/services/Device.service.d.ts +0 -39
  93. package/dist/device/cloud/services/Device.service.js +0 -9
  94. package/dist/device/cloud/services/DeviceCloudService.d.ts +0 -42
  95. package/dist/device/cloud/services/DeviceCloudService.js +0 -59
  96. package/dist/device/cloud/services/DeviceHub.service.d.ts +0 -3
  97. package/dist/device/cloud/services/DeviceHub.service.js +0 -6
  98. package/dist/device/cloud/services/Hub.service.d.ts +0 -25
  99. package/dist/device/cloud/services/Hub.service.js +0 -9
  100. package/dist/device/cloud/services/SmartThingsDeviceService.d.ts +0 -38
  101. package/dist/device/cloud/services/SmartThingsDeviceService.js +0 -52
  102. package/dist/device/cloud/services/index.d.ts +0 -2
  103. package/dist/device/cloud/services/index.js +0 -18
  104. package/dist/device/cloud/types.d.ts +0 -52
  105. package/dist/device/cloud/types.js +0 -15
  106. package/dist/device/index.d.ts +0 -4
  107. package/dist/device/index.js +0 -20
  108. package/dist/device/local/entities/AlertBuilder.d.ts +0 -87
  109. package/dist/device/local/entities/AlertBuilder.example.d.ts +0 -11
  110. package/dist/device/local/entities/AlertBuilder.example.js +0 -117
  111. package/dist/device/local/entities/AlertBuilder.js +0 -179
  112. package/dist/device/local/entities/IssueBuilder.d.ts +0 -109
  113. package/dist/device/local/entities/IssueBuilder.example.d.ts +0 -16
  114. package/dist/device/local/entities/IssueBuilder.example.js +0 -196
  115. package/dist/device/local/entities/IssueBuilder.js +0 -237
  116. package/dist/device/local/entities/index.d.ts +0 -2
  117. package/dist/device/local/entities/index.js +0 -7
  118. package/dist/device/local/events/EventHandler.d.ts +0 -11
  119. package/dist/device/local/events/EventHandler.js +0 -86
  120. package/dist/device/local/events/Events.d.ts +0 -54
  121. package/dist/device/local/events/Events.js +0 -57
  122. package/dist/device/local/events/index.d.ts +0 -2
  123. package/dist/device/local/events/index.js +0 -7
  124. package/dist/device/local/handler/EventHandler.d.ts +0 -7
  125. package/dist/device/local/handler/EventHandler.js +0 -44
  126. package/dist/device/local/interface.d.ts +0 -0
  127. package/dist/device/local/interface.js +0 -1
  128. package/dist/device/local/interfaces/IConnection.d.ts +0 -26
  129. package/dist/device/local/interfaces/IConnection.js +0 -14
  130. package/dist/device/local/interfaces/IDevice.d.ts +0 -68
  131. package/dist/device/local/interfaces/IDevice.js +0 -10
  132. package/dist/device/local/interfaces/IDtDevice.d.ts +0 -16
  133. package/dist/device/local/interfaces/IDtDevice.js +0 -2
  134. package/dist/device/local/interfaces/IHub.d.ts +0 -46
  135. package/dist/device/local/interfaces/IHub.js +0 -2
  136. package/dist/device/local/interfaces/IProperty.d.ts +0 -29
  137. package/dist/device/local/interfaces/IProperty.js +0 -2
  138. package/dist/device/local/interfaces/ISchedule.d.ts +0 -25
  139. package/dist/device/local/interfaces/ISchedule.js +0 -2
  140. package/dist/device/local/interfaces/index.d.ts +0 -3
  141. package/dist/device/local/interfaces/index.js +0 -19
  142. package/dist/device/local/models/Alert.model.d.ts +0 -28
  143. package/dist/device/local/models/Alert.model.js +0 -222
  144. package/dist/device/local/models/Issue.model.d.ts +0 -28
  145. package/dist/device/local/models/Issue.model.js +0 -260
  146. package/dist/device/local/repository/Alert.repository.d.ts +0 -106
  147. package/dist/device/local/repository/Alert.repository.js +0 -374
  148. package/dist/device/local/repository/Connection.repository.d.ts +0 -8
  149. package/dist/device/local/repository/Connection.repository.js +0 -92
  150. package/dist/device/local/repository/Device.repository.d.ts +0 -30
  151. package/dist/device/local/repository/Device.repository.js +0 -325
  152. package/dist/device/local/repository/Hub.repository.d.ts +0 -13
  153. package/dist/device/local/repository/Hub.repository.js +0 -139
  154. package/dist/device/local/repository/Issue.repository.d.ts +0 -113
  155. package/dist/device/local/repository/Issue.repository.js +0 -401
  156. package/dist/device/local/repository/Property.repository.d.ts +0 -8
  157. package/dist/device/local/repository/Property.repository.js +0 -95
  158. package/dist/device/local/repository/Schedule.repository.d.ts +0 -9
  159. package/dist/device/local/repository/Schedule.repository.js +0 -109
  160. package/dist/device/local/services/Alert.service.d.ts +0 -137
  161. package/dist/device/local/services/Alert.service.js +0 -475
  162. package/dist/device/local/services/AlertService.example.d.ts +0 -55
  163. package/dist/device/local/services/AlertService.example.js +0 -148
  164. package/dist/device/local/services/Connection.service.d.ts +0 -8
  165. package/dist/device/local/services/Connection.service.js +0 -32
  166. package/dist/device/local/services/Device.service.d.ts +0 -40
  167. package/dist/device/local/services/Device.service.js +0 -391
  168. package/dist/device/local/services/DeviceHub.service.d.ts +0 -11
  169. package/dist/device/local/services/DeviceHub.service.js +0 -40
  170. package/dist/device/local/services/Hub.service.d.ts +0 -12
  171. package/dist/device/local/services/Hub.service.js +0 -107
  172. package/dist/device/local/services/Issue.service.d.ts +0 -168
  173. package/dist/device/local/services/Issue.service.js +0 -642
  174. package/dist/device/local/services/IssueService.example.d.ts +0 -68
  175. package/dist/device/local/services/IssueService.example.js +0 -177
  176. package/dist/device/local/services/Property.service.d.ts +0 -8
  177. package/dist/device/local/services/Property.service.js +0 -36
  178. package/dist/device/local/services/Schedule.service.d.ts +0 -9
  179. package/dist/device/local/services/Schedule.service.js +0 -26
  180. package/dist/device/local/services/index.d.ts +0 -3
  181. package/dist/device/local/services/index.js +0 -19
  182. package/dist/pms/IPms.d.ts +0 -6
  183. package/dist/pms/IPms.js +0 -10
  184. package/dist/pms/index.d.ts +0 -1
  185. package/dist/pms/index.js +0 -18
  186. package/dist/pms/webhookQueue/examples/index.d.ts +0 -2
  187. package/dist/pms/webhookQueue/examples/index.js +0 -18
  188. package/dist/pms/webhookQueue/examples/pms-integration.d.ts +0 -65
  189. package/dist/pms/webhookQueue/examples/pms-integration.js +0 -254
  190. package/dist/pms/webhookQueue/examples/usage.d.ts +0 -7
  191. package/dist/pms/webhookQueue/examples/usage.js +0 -175
  192. package/dist/pms/webhookQueue/index.d.ts +0 -3
  193. package/dist/pms/webhookQueue/index.js +0 -20
  194. package/dist/pms/webhookQueue/interfaces/IWebhookQueue.d.ts +0 -33
  195. package/dist/pms/webhookQueue/interfaces/IWebhookQueue.js +0 -2
  196. package/dist/pms/webhookQueue/interfaces/IWebhookWorker.d.ts +0 -38
  197. package/dist/pms/webhookQueue/interfaces/IWebhookWorker.js +0 -2
  198. package/dist/pms/webhookQueue/interfaces/index.d.ts +0 -1
  199. package/dist/pms/webhookQueue/interfaces/index.js +0 -17
  200. package/dist/pms/webhookQueue/services/WebhookQueueFactory.d.ts +0 -38
  201. package/dist/pms/webhookQueue/services/WebhookQueueFactory.js +0 -131
  202. package/dist/pms/webhookQueue/services/WebhookQueueIntegration.d.ts +0 -70
  203. package/dist/pms/webhookQueue/services/WebhookQueueIntegration.js +0 -207
  204. package/dist/pms/webhookQueue/services/WebhookQueueService.d.ts +0 -45
  205. package/dist/pms/webhookQueue/services/WebhookQueueService.js +0 -270
  206. package/dist/pms/webhookQueue/services/WebhookWorker.d.ts +0 -37
  207. package/dist/pms/webhookQueue/services/WebhookWorker.js +0 -201
  208. package/dist/pms/webhookQueue/services/index.d.ts +0 -1
  209. package/dist/pms/webhookQueue/services/index.js +0 -17
  210. package/dist/pms/webhookQueue/types/index.d.ts +0 -1
  211. package/dist/pms/webhookQueue/types/index.js +0 -17
  212. package/dist/pms/webhookQueue/types/webhook.types.d.ts +0 -39
  213. package/dist/pms/webhookQueue/types/webhook.types.js +0 -2
  214. package/dist/property/IProperty.d.ts +0 -29
  215. package/dist/property/IProperty.js +0 -2
  216. package/dist/property/Property.repository.d.ts +0 -8
  217. package/dist/property/Property.repository.js +0 -109
  218. package/dist/property/Property.service.d.ts +0 -8
  219. package/dist/property/Property.service.js +0 -124
  220. package/dist/property/index.d.ts +0 -2
  221. package/dist/property/index.js +0 -18
  222. package/dist/queue/interfaces/IHttpRequestJob.d.ts +0 -9
  223. package/dist/queue/interfaces/IHttpRequestJob.js +0 -2
  224. package/dist/types/alert.types.d.ts +0 -57
  225. package/dist/types/alert.types.js +0 -22
  226. package/dist/types/config.types.d.ts +0 -19
  227. package/dist/types/config.types.js +0 -2
  228. package/dist/types/index.d.ts +0 -3
  229. package/dist/types/index.js +0 -19
  230. package/dist/types/issue.types.d.ts +0 -90
  231. package/dist/types/issue.types.js +0 -40
  232. package/dist/utils/http-utils.d.ts +0 -13
  233. package/dist/utils/http-utils.js +0 -117
@@ -32,6 +32,8 @@ export declare class AlertService {
32
32
  */
33
33
  raiseDeviceOnlineAlert(device: IDevice, source: Source): Promise<IAlertDocument | null>;
34
34
  raiseLockAccessEmergencyCodeAlert(device: IDevice, zone: any, source: Source): Promise<IAlertDocument | null>;
35
+ raiseLockAccessEmergencyRfidAlert(device: IDevice, zone: any, source: Source): Promise<IAlertDocument | null>;
36
+ raiseLockAccessMasterRfidAlert(device: IDevice, zone: any, source: Source): Promise<IAlertDocument | null>;
35
37
  raiseLockAccessMasterCodeAlert(device: IDevice, zone: any, source: Source): Promise<IAlertDocument | null>;
36
38
  raiseSpecificDoorAccessAlert(userName: string, device: IDevice, zone: any, source: Source): Promise<IAlertDocument | null>;
37
39
  raiseGuestLockFirstAccessAlert(userName: string, device: IDevice, zone: any, source: Source): Promise<IAlertDocument | null>;
@@ -48,6 +50,7 @@ export declare class AlertService {
48
50
  * Get all alerts with business logic filtering
49
51
  */
50
52
  queryAlerts(filters?: IAlertQuery): Promise<IAlertDocument[]>;
53
+ alertCount(filters: IAlertQuery): Promise<number>;
51
54
  /**
52
55
  * Update an alert with business logic validation
53
56
  */
@@ -253,6 +253,36 @@ let AlertService = (() => {
253
253
  type: alert_types_1.AlertType.LOCK_ACCESS_EMERGENCY_CODE,
254
254
  });
255
255
  }
256
+ async raiseLockAccessEmergencyRfidAlert(device, zone, source) {
257
+ return await this.createAlert({
258
+ entityId: device.deviceId,
259
+ entityType: alert_types_1.EntityType.DEVICE,
260
+ entitySubType: device.deviceType.type,
261
+ propertyId: device.propertyId,
262
+ zoneId: device.zoneId,
263
+ title: "Emergency RFID Card Used",
264
+ description: `${zone?.name} has been accessed using the emergency RFID card.`,
265
+ createdBy: source,
266
+ category: alert_types_1.AlertCategory.SECURITY,
267
+ severity: alert_types_1.AlertSeverity.HIGH,
268
+ type: alert_types_1.AlertType.LOCK_ACCESS_EMERGENCY_RFID,
269
+ });
270
+ }
271
+ async raiseLockAccessMasterRfidAlert(device, zone, source) {
272
+ return await this.createAlert({
273
+ entityId: device.deviceId,
274
+ entityType: alert_types_1.EntityType.DEVICE,
275
+ entitySubType: device.deviceType.type,
276
+ propertyId: device.propertyId,
277
+ zoneId: device.zoneId,
278
+ title: "Master RFID Card Used",
279
+ description: `${zone?.name} has been accessed using the master RFID card.`,
280
+ createdBy: source,
281
+ category: alert_types_1.AlertCategory.SECURITY,
282
+ severity: alert_types_1.AlertSeverity.HIGH,
283
+ type: alert_types_1.AlertType.LOCK_ACCESS_MASTER_RFID,
284
+ });
285
+ }
256
286
  async raiseLockAccessMasterCodeAlert(device, zone, source) {
257
287
  return await this.createAlert({
258
288
  entityId: device.deviceId,
@@ -404,6 +434,11 @@ let AlertService = (() => {
404
434
  const enhancedFilters = this.applyBusinessRules(filters);
405
435
  return await this.alertRepository.query(enhancedFilters);
406
436
  }
437
+ async alertCount(filters) {
438
+ // Business logic: Apply business rules to filters
439
+ const enhancedFilters = this.applyBusinessRules(filters);
440
+ return await this.alertRepository.count(enhancedFilters);
441
+ }
407
442
  /**
408
443
  * Update an alert with business logic validation
409
444
  */
@@ -19,6 +19,8 @@ export declare enum AlertType {
19
19
  DOOR_OPEN_OUTSIDE_BIZ_HOURS = "DOOR_OPEN_OUTSIDE_BIZ_HOURS",
20
20
  LOCK_ACCESS_EMERGENCY_CODE = "LOCK_ACCESS_EMERGENCY_CODE",
21
21
  LOCK_ACCESS_MASTER_CODE = "LOCK_ACCESS_MASTER_CODE",
22
+ LOCK_ACCESS_EMERGENCY_RFID = "LOCK_ACCESS_EMERGENCY_RFID",
23
+ LOCK_ACCESS_MASTER_RFID = "LOCK_ACCESS_MASTER_RFID",
22
24
  SPECIFIC_DOOR_ACCESS = "SPECIFIC_DOOR_ACCESS",
23
25
  GUEST_LOCK_FIRST_ACCESS = "GUEST_LOCK_FIRST_ACCESS",
24
26
  DEVICE_ONLINE = "DEVICE_ONLINE"
@@ -24,6 +24,8 @@ var AlertType;
24
24
  AlertType["DOOR_OPEN_OUTSIDE_BIZ_HOURS"] = "DOOR_OPEN_OUTSIDE_BIZ_HOURS";
25
25
  AlertType["LOCK_ACCESS_EMERGENCY_CODE"] = "LOCK_ACCESS_EMERGENCY_CODE";
26
26
  AlertType["LOCK_ACCESS_MASTER_CODE"] = "LOCK_ACCESS_MASTER_CODE";
27
+ AlertType["LOCK_ACCESS_EMERGENCY_RFID"] = "LOCK_ACCESS_EMERGENCY_RFID";
28
+ AlertType["LOCK_ACCESS_MASTER_RFID"] = "LOCK_ACCESS_MASTER_RFID";
27
29
  AlertType["SPECIFIC_DOOR_ACCESS"] = "SPECIFIC_DOOR_ACCESS";
28
30
  AlertType["GUEST_LOCK_FIRST_ACCESS"] = "GUEST_LOCK_FIRST_ACCESS";
29
31
  AlertType["DEVICE_ONLINE"] = "DEVICE_ONLINE";
@@ -1,5 +1,6 @@
1
+ import { IAccessGroup } from "./IAccessGroup";
1
2
  export declare class AccessGroupRepository {
2
3
  private readonly postgres;
3
4
  constructor();
4
- getAccessGroup(accessGroupId: string): Promise<any>;
5
+ getAccessGroup(accessGroupId: string): Promise<IAccessGroup | null>;
5
6
  }
@@ -56,7 +56,10 @@ let AccessGroupRepository = (() => {
56
56
  WHERE "id" = $1
57
57
  `;
58
58
  const result = await this.postgres.query(query, [accessGroupId]);
59
- return result.rows[0];
59
+ if (result.rows.length > 0) {
60
+ return result.rows[0];
61
+ }
62
+ return null;
60
63
  }
61
64
  };
62
65
  __setFunctionName(_classThis, "AccessGroupRepository");
@@ -1,5 +1,6 @@
1
+ import { IAccessGroup } from "./IAccessGroup";
1
2
  export declare class AccessGroupService {
2
3
  private readonly accessGroupRepository;
3
4
  constructor();
4
- getAccessGroup(accessGroupId: string): Promise<any>;
5
+ getAccessGroup(accessGroupId: string): Promise<IAccessGroup | null>;
5
6
  }
@@ -87,7 +87,10 @@ let AccessGroupService = (() => {
87
87
  if (!accessGroupId) {
88
88
  throw new Error("Access Group ID is required");
89
89
  }
90
- return await this.accessGroupRepository.getAccessGroup(accessGroupId);
90
+ const accessGroup = await this.accessGroupRepository.getAccessGroup(accessGroupId);
91
+ if (!accessGroup)
92
+ return null;
93
+ return accessGroup;
91
94
  }
92
95
  };
93
96
  __setFunctionName(_classThis, "AccessGroupService");
@@ -101,5 +104,3 @@ let AccessGroupService = (() => {
101
104
  return AccessGroupService = _classThis;
102
105
  })();
103
106
  exports.AccessGroupService = AccessGroupService;
104
- // Accessgroup.getAccessGroup(accessGroupId)
105
- // GetAccessGroup()
@@ -6,7 +6,7 @@ export declare class AdminRepository {
6
6
  getZonesByAccessGroupIds(accessGroupIds: string[]): Promise<any[]>;
7
7
  getZonesByAccessGroups(accessGroupIds: string[]): Promise<any[]>;
8
8
  getAccessGroup(accessGroupId: string): Promise<IAccessGroup | null>;
9
- getZoneAccessGroupByZoneId(zoneId: string): Promise<IZoneAccessGroup | null>;
9
+ getZoneAccessGroupByZoneId(zoneId: string): Promise<IZoneAccessGroup[] | null>;
10
10
  getZone(zoneId: string): Promise<IZone | null>;
11
11
  getUser(userId: string): Promise<IUser | null>;
12
12
  }
@@ -215,7 +215,7 @@ let AdminRepository = (() => {
215
215
  `;
216
216
  const result = await this.postgres.query(query, [zoneId]);
217
217
  if (result.rows.length > 0) {
218
- return result.rows[0];
218
+ return result.rows;
219
219
  }
220
220
  return null;
221
221
  }
@@ -6,7 +6,7 @@ export declare class AdminService {
6
6
  getZonesByAccessGroupIds(accessGroupIds: string[]): Promise<any[] | undefined>;
7
7
  getZonesByAccessGroups(accessGroupIds: string[]): Promise<any[] | undefined>;
8
8
  getAccessGroup(accessGroupId: string): Promise<IAccessGroup | null>;
9
- getAccessGroupByZoneId(zoneId: string): Promise<IAccessGroup | null>;
9
+ getAccessGroupByZoneId(zoneId: string): Promise<IAccessGroup[] | []>;
10
10
  getZone(zoneId: string): Promise<IZone | null>;
11
11
  getUser(userId: string): Promise<IUser | null>;
12
12
  }
@@ -114,13 +114,16 @@ let AdminService = (() => {
114
114
  if (!zoneId) {
115
115
  throw new Error("Zone ID is required");
116
116
  }
117
- const zoneAccessGroup = await this.adminRepository.getZoneAccessGroupByZoneId(zoneId);
118
- if (!zoneAccessGroup)
119
- return null;
120
- const accessGroup = await this.adminRepository.getAccessGroup(zoneAccessGroup.collectionId);
121
- if (!accessGroup)
122
- return null;
123
- return accessGroup;
117
+ const zoneAccessGroups = await this.adminRepository.getZoneAccessGroupByZoneId(zoneId);
118
+ if (!zoneAccessGroups?.length)
119
+ return [];
120
+ const accessGroups = [];
121
+ for (const zoneAccessGroup of zoneAccessGroups) {
122
+ const accessGroup = await this.adminRepository.getAccessGroup(zoneAccessGroup.collectionId);
123
+ if (accessGroup)
124
+ accessGroups.push(accessGroup);
125
+ }
126
+ return accessGroups;
124
127
  }
125
128
  async getZone(zoneId) {
126
129
  if (!zoneId) {
@@ -23,6 +23,10 @@ export interface IZone {
23
23
  propertyId: string;
24
24
  parentId?: string;
25
25
  zoneTypeId: string;
26
+ zoneType: {
27
+ id: string;
28
+ name: string;
29
+ };
26
30
  deviceHiveNetworkId?: string;
27
31
  createdAt: string;
28
32
  updatedAt: string;
@@ -2,5 +2,5 @@ import { IGuest } from "./IGuest";
2
2
  export declare class GuestRepository {
3
3
  private readonly pmsPostgres;
4
4
  constructor();
5
- getGuest(guestId: string): Promise<IGuest>;
5
+ getGuest(guestId: string): Promise<IGuest | null>;
6
6
  }
@@ -52,8 +52,11 @@ let GuestRepository = (() => {
52
52
  }
53
53
  async getGuest(guestId) {
54
54
  try {
55
- const guest = await this.pmsPostgres.query(`SELECT * FROM dt_guests WHERE "id" = $1`, [guestId]);
56
- return guest.rows[0];
55
+ const guest = await this.pmsPostgres.query(`SELECT * FROM dt_guest WHERE "id" = $1`, [guestId]);
56
+ if (guest.rows.length > 0) {
57
+ return guest.rows[0];
58
+ }
59
+ return null;
57
60
  }
58
61
  catch (error) {
59
62
  console.error("Error in getGuest:", error);
@@ -2,5 +2,5 @@ import { IGuest } from "./IGuest";
2
2
  export declare class GuestService {
3
3
  private readonly guestRepository;
4
4
  constructor();
5
- getGuest(guestId: string): Promise<IGuest>;
5
+ getGuest(guestId: string): Promise<IGuest | null>;
6
6
  }
@@ -88,7 +88,10 @@ let GuestService = (() => {
88
88
  if (!guestId) {
89
89
  throw new Error("Guest ID is required");
90
90
  }
91
- return await this.guestRepository.getGuest(guestId);
91
+ const guest = await this.guestRepository.getGuest(guestId);
92
+ if (!guest)
93
+ return null;
94
+ return guest;
92
95
  }
93
96
  };
94
97
  __setFunctionName(_classThis, "GuestService");
@@ -2,5 +2,5 @@ import { ISchedule } from "./ISchedule";
2
2
  export declare class ScheduleRepository {
3
3
  private readonly pmsPostgres;
4
4
  constructor();
5
- getSchedule(scheduleId: string): Promise<ISchedule>;
5
+ getSchedule(scheduleId: string): Promise<ISchedule | null>;
6
6
  }
@@ -52,8 +52,11 @@ let ScheduleRepository = (() => {
52
52
  }
53
53
  async getSchedule(scheduleId) {
54
54
  try {
55
- const schedule = await this.pmsPostgres.query(`SELECT * FROM dt_schedules WHERE "id" = $1`, [scheduleId]);
56
- return schedule.rows[0];
55
+ const schedule = await this.pmsPostgres.query(`SELECT * FROM dt_schedule WHERE "id" = $1`, [scheduleId]);
56
+ if (schedule.rows.length > 0) {
57
+ return schedule.rows[0];
58
+ }
59
+ return null;
57
60
  }
58
61
  catch (error) {
59
62
  console.error("Error in getSchedule:", error);
@@ -2,5 +2,5 @@ import { ISchedule } from "./ISchedule";
2
2
  export declare class ScheduleService {
3
3
  private readonly scheduleRepository;
4
4
  constructor();
5
- getSchedule(scheduleId: string): Promise<ISchedule>;
5
+ getSchedule(scheduleId: string): Promise<ISchedule | null>;
6
6
  }
@@ -88,7 +88,10 @@ let ScheduleService = (() => {
88
88
  if (!scheduleId) {
89
89
  throw new Error("Schedule ID is required");
90
90
  }
91
- return await this.scheduleRepository.getSchedule(scheduleId);
91
+ const schedule = await this.scheduleRepository.getSchedule(scheduleId);
92
+ if (!schedule)
93
+ return null;
94
+ return schedule;
92
95
  }
93
96
  };
94
97
  __setFunctionName(_classThis, "ScheduleService");
@@ -52,7 +52,10 @@ let UserRepository = (() => {
52
52
  }
53
53
  async getUser(userId) {
54
54
  const user = await this.postgres.query(`SELECT * FROM dt_users WHERE "id" = $1`, [userId]);
55
- return user.rows[0];
55
+ if (user.rows.length > 0) {
56
+ return user.rows[0];
57
+ }
58
+ return null;
56
59
  }
57
60
  };
58
61
  __setFunctionName(_classThis, "UserRepository");
@@ -2,5 +2,5 @@ import { IUser } from "./IUser";
2
2
  export declare class UserService {
3
3
  private readonly userRepository;
4
4
  constructor();
5
- getUser(userId: string): Promise<IUser>;
5
+ getUser(userId: string): Promise<IUser | null>;
6
6
  }
@@ -87,7 +87,10 @@ let UserService = (() => {
87
87
  if (!userId) {
88
88
  throw new Error("User ID is required");
89
89
  }
90
- return await this.userRepository.getUser(userId);
90
+ const user = await this.userRepository.getUser(userId);
91
+ if (!user)
92
+ return null;
93
+ return user;
91
94
  }
92
95
  };
93
96
  __setFunctionName(_classThis, "UserService");
@@ -88,7 +88,10 @@ let ZoneService = (() => {
88
88
  if (!zoneId) {
89
89
  throw new Error("Zone ID is required");
90
90
  }
91
- return await this.zoneRepository.getZone(zoneId);
91
+ const zone = await this.zoneRepository.getZone(zoneId);
92
+ if (!zone)
93
+ return null;
94
+ return zone;
92
95
  }
93
96
  };
94
97
  __setFunctionName(_classThis, "ZoneService");
@@ -14,9 +14,9 @@ interface IIssueModel extends Model<IIssueDocument, {}, IIssueMethods> {
14
14
  findOverdue(includeDeleted?: boolean): Promise<IIssueDocument[]>;
15
15
  findUpcoming(days?: number, includeDeleted?: boolean): Promise<IIssueDocument[]>;
16
16
  }
17
- declare const IssueSchema: mongoose.Schema<IIssueDocument, IIssueModel, IIssueMethods, {}, {}, {}, mongoose.DefaultSchemaOptions, IIssueDocument, mongoose.Document<unknown, {}, mongoose.FlatRecord<IIssueDocument>, {}, mongoose.ResolveSchemaOptions<mongoose.DefaultSchemaOptions>> & Omit<mongoose.FlatRecord<IIssueDocument> & Required<{
18
- _id: string;
19
- }> & {
17
+ declare const IssueSchema: mongoose.Schema<IIssueDocument, IIssueModel, IIssueMethods, {}, {}, {}, mongoose.DefaultSchemaOptions, IIssueDocument, mongoose.Document<unknown, {}, mongoose.FlatRecord<IIssueDocument>, {}, mongoose.ResolveSchemaOptions<mongoose.DefaultSchemaOptions>> & Omit<mongoose.FlatRecord<IIssueDocument> & {
18
+ _id: mongoose.Types.ObjectId;
19
+ } & {
20
20
  __v: number;
21
21
  }, keyof IIssueMethods> & IIssueMethods>;
22
22
  export declare const IssueModel: IIssueModel;
@@ -50,6 +50,8 @@ let IssueRepository = (() => {
50
50
  var IssueRepository = _classThis = class {
51
51
  buildQuery(filters) {
52
52
  const query = {};
53
+ if (filters.id)
54
+ query._id = filters.id;
53
55
  if (filters.propertyId)
54
56
  query.propertyId = filters.propertyId;
55
57
  if (filters.zoneId)
@@ -76,6 +76,7 @@ export declare class IssueService {
76
76
  * Get all issues with business logic filtering
77
77
  */
78
78
  query(filters: IIssueQuery): Promise<IIssueDocument[]>;
79
+ issueCount(filters: IIssueQuery): Promise<number>;
79
80
  /**
80
81
  * Update an issue with business logic validation
81
82
  */
@@ -478,6 +478,11 @@ let IssueService = (() => {
478
478
  const enhancedFilters = this.applyBusinessRules(filters);
479
479
  return await this.issueRepository.query(enhancedFilters);
480
480
  }
481
+ async issueCount(filters) {
482
+ // Business logic: Apply business rules to filters
483
+ const enhancedFilters = this.applyBusinessRules(filters);
484
+ return await this.issueRepository.count(enhancedFilters);
485
+ }
481
486
  /**
482
487
  * Update an issue with business logic validation
483
488
  */
@@ -699,37 +704,45 @@ let IssueService = (() => {
699
704
  updatedBy,
700
705
  updatedAt: new Date(),
701
706
  };
707
+ let auditType = "";
702
708
  switch (action) {
703
709
  case "in_progress":
704
710
  newStatus = issue_types_1.IssueStatus.IN_PROGRESS;
711
+ auditType = constants_1.DT_EVENT_TYPES.ISSUE.IN_PROGRESS.SUCCESS;
705
712
  break;
706
713
  case "resolve":
707
714
  newStatus = issue_types_1.IssueStatus.RESOLVED;
708
715
  updateData.resolvedAt = new Date();
716
+ auditType = constants_1.DT_EVENT_TYPES.ISSUE.RESOLVE.SUCCESS;
709
717
  break;
710
718
  case "close":
711
719
  newStatus = issue_types_1.IssueStatus.CLOSED;
720
+ auditType = constants_1.DT_EVENT_TYPES.ISSUE.CLOSE.SUCCESS;
712
721
  break;
713
722
  case "cancel":
714
723
  newStatus = issue_types_1.IssueStatus.CANCELLED;
724
+ auditType = constants_1.DT_EVENT_TYPES.ISSUE.CANCEL.SUCCESS;
715
725
  break;
716
726
  case "on_hold":
717
727
  newStatus = issue_types_1.IssueStatus.ON_HOLD;
728
+ auditType = constants_1.DT_EVENT_TYPES.ISSUE.ON_HOLD.SUCCESS;
718
729
  break;
719
730
  case "ignore":
720
731
  newStatus = issue_types_1.IssueStatus.IGNORED;
732
+ auditType = constants_1.DT_EVENT_TYPES.ISSUE.IGNORE.SUCCESS;
721
733
  break;
722
734
  default:
723
735
  throw new Error("Invalid action. Must be 'cancel', 'close', or 'resolve'");
724
736
  }
725
737
  updateData.status = newStatus;
726
738
  // Update the issue
727
- const updatedIssue = await this.updateIssue(issue._id, updateData);
739
+ const updatedIssue = await this.updateIssue(issue.id, updateData);
728
740
  if (updatedIssue) {
729
741
  // Log the action for audit purposes
730
- console.log(`Issue ${issue._id} has been ${action}ed by ${updatedBy}`);
742
+ console.log(`Issue ${issue.id} has been ${action}ed by ${updatedBy}`);
743
+ await dt_pub_sub_1.eventDispatcher.publishEvent(auditType, updatedIssue, "dt-common-device");
731
744
  await (0, audit_1.pushAudit)({
732
- auditType: constants_1.DT_EVENT_TYPES.ISSUE.UPDATE.SUCCESS,
745
+ auditType: auditType,
733
746
  auditData: {
734
747
  resource: audit_1.Resource.ISSUE,
735
748
  source: Service_1.Source.USER,
@@ -757,6 +770,8 @@ let IssueService = (() => {
757
770
  error: error,
758
771
  updatedBy,
759
772
  updatedAt: new Date(),
773
+ actionPayload: query,
774
+ action,
760
775
  },
761
776
  });
762
777
  throw error;
@@ -889,12 +904,15 @@ let IssueService = (() => {
889
904
  const validTransitions = {
890
905
  [issue_types_1.IssueStatus.PENDING]: [
891
906
  issue_types_1.IssueStatus.IN_PROGRESS,
907
+ issue_types_1.IssueStatus.RESOLVED,
908
+ issue_types_1.IssueStatus.CLOSED,
892
909
  issue_types_1.IssueStatus.CANCELLED,
893
910
  issue_types_1.IssueStatus.ON_HOLD,
894
911
  issue_types_1.IssueStatus.IGNORED,
895
912
  ],
896
913
  [issue_types_1.IssueStatus.IN_PROGRESS]: [
897
914
  issue_types_1.IssueStatus.RESOLVED,
915
+ issue_types_1.IssueStatus.CLOSED,
898
916
  issue_types_1.IssueStatus.CANCELLED,
899
917
  issue_types_1.IssueStatus.ON_HOLD,
900
918
  issue_types_1.IssueStatus.IGNORED,
@@ -932,7 +950,12 @@ let IssueService = (() => {
932
950
  // Always exclude cancelled, resolved, and closed issues unless explicitly requested
933
951
  if (!enhancedFilters.status) {
934
952
  enhancedFilters.status = {
935
- $nin: [issue_types_1.IssueStatus.CANCELLED, issue_types_1.IssueStatus.RESOLVED, issue_types_1.IssueStatus.CLOSED],
953
+ $nin: [
954
+ issue_types_1.IssueStatus.CANCELLED,
955
+ issue_types_1.IssueStatus.RESOLVED,
956
+ issue_types_1.IssueStatus.CLOSED,
957
+ issue_types_1.IssueStatus.IGNORED,
958
+ ],
936
959
  };
937
960
  }
938
961
  return enhancedFilters;
@@ -57,7 +57,7 @@ export declare enum IssueType {
57
57
  DEVICE_MALFUNCTION = "DEVICE_MALFUNCTION"
58
58
  }
59
59
  export interface IssueDocument {
60
- _id: string;
60
+ id: string;
61
61
  category: IssuesCategory;
62
62
  propertyId: string;
63
63
  zoneId?: string;
@@ -118,6 +118,7 @@ export interface AddCommentData {
118
118
  content: string;
119
119
  }
120
120
  export interface IIssueQuery {
121
+ id?: string;
121
122
  propertyId?: string;
122
123
  zoneId?: string;
123
124
  zoneName?: string;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "dt-common-device",
3
- "version": "7.6.15",
3
+ "version": "7.8.0",
4
4
  "main": "dist/index.js",
5
5
  "types": "dist/index.d.ts",
6
6
  "files": [
@@ -1,7 +0,0 @@
1
- export declare class AdminRepository {
2
- private readonly axiosInstance;
3
- private readonly deviceRepository;
4
- private readonly postgres;
5
- constructor();
6
- getZonesByAccessGroupIds(accessGroupIds: string[]): Promise<any[]>;
7
- }