dt-common-device 7.10.1 → 7.10.3

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 (226) hide show
  1. package/dist/alerts/Alert.service.d.ts +5 -0
  2. package/dist/alerts/Alert.service.js +22 -6
  3. package/dist/entities/accessGroup/AccessGroup.repository.d.ts +2 -1
  4. package/dist/entities/accessGroup/AccessGroup.repository.js +4 -1
  5. package/dist/entities/accessGroup/AccessGroup.service.d.ts +2 -1
  6. package/dist/entities/accessGroup/AccessGroup.service.js +4 -3
  7. package/dist/entities/device/local/repository/DeviceProfile.repository.d.ts +5 -0
  8. package/dist/{device/cloud/entities/DeviceFactory.js → entities/device/local/repository/DeviceProfile.repository.js} +12 -27
  9. package/dist/entities/device/local/services/Device.service.js +4 -21
  10. package/dist/entities/guest/Guest.repository.d.ts +1 -1
  11. package/dist/entities/guest/Guest.repository.js +5 -2
  12. package/dist/entities/guest/Guest.service.d.ts +1 -1
  13. package/dist/entities/guest/Guest.service.js +4 -1
  14. package/dist/entities/schedules/Schedule.repository.d.ts +1 -1
  15. package/dist/entities/schedules/Schedule.repository.js +5 -2
  16. package/dist/entities/schedules/Schedule.service.d.ts +1 -1
  17. package/dist/entities/schedules/Schedule.service.js +4 -1
  18. package/dist/entities/user/User.repository.js +4 -1
  19. package/dist/entities/user/User.service.d.ts +1 -1
  20. package/dist/entities/user/User.service.js +4 -1
  21. package/dist/entities/zone/Zone.service.js +4 -1
  22. package/dist/events/InternalEventSubscription.js +3 -0
  23. package/dist/issues/Issue.service.d.ts +4 -0
  24. package/dist/issues/Issue.service.js +8 -8
  25. package/package.json +1 -1
  26. package/dist/admin/Admin.repository.d.ts +0 -7
  27. package/dist/admin/Admin.repository.js +0 -182
  28. package/dist/admin/Admin.service.d.ts +0 -5
  29. package/dist/admin/Admin.service.js +0 -17
  30. package/dist/admin/index.d.ts +0 -1
  31. package/dist/admin/index.js +0 -17
  32. package/dist/audit/AuditProperties.d.ts +0 -16
  33. package/dist/audit/AuditProperties.js +0 -2
  34. package/dist/chronicle/IChronicle.interface.d.ts +0 -14
  35. package/dist/chronicle/IChronicle.interface.js +0 -2
  36. package/dist/chronicle/chronicle.service.d.ts +0 -4
  37. package/dist/chronicle/chronicle.service.js +0 -44
  38. package/dist/connection/Connection.repository.d.ts +0 -8
  39. package/dist/connection/Connection.repository.js +0 -92
  40. package/dist/connection/Connection.service.d.ts +0 -8
  41. package/dist/connection/Connection.service.js +0 -32
  42. package/dist/connection/IConnection.d.ts +0 -28
  43. package/dist/connection/IConnection.js +0 -16
  44. package/dist/connection/index.d.ts +0 -2
  45. package/dist/connection/index.js +0 -18
  46. package/dist/device/cloud/entities/CloudConnection.d.ts +0 -6
  47. package/dist/device/cloud/entities/CloudConnection.js +0 -6
  48. package/dist/device/cloud/entities/CloudDevice.d.ts +0 -16
  49. package/dist/device/cloud/entities/CloudDevice.js +0 -26
  50. package/dist/device/cloud/entities/CloudDeviceService.d.ts +0 -5
  51. package/dist/device/cloud/entities/CloudDeviceService.js +0 -9
  52. package/dist/device/cloud/entities/DeviceFactory.d.ts +0 -7
  53. package/dist/device/cloud/entities/index.d.ts +0 -3
  54. package/dist/device/cloud/entities/index.js +0 -19
  55. package/dist/device/cloud/interface.d.ts +0 -101
  56. package/dist/device/cloud/interface.js +0 -3
  57. package/dist/device/cloud/interfaces/ICloudConnection.d.ts +0 -5
  58. package/dist/device/cloud/interfaces/ICloudConnection.js +0 -2
  59. package/dist/device/cloud/interfaces/ICloudDevice.d.ts +0 -9
  60. package/dist/device/cloud/interfaces/ICloudDevice.js +0 -2
  61. package/dist/device/cloud/interfaces/ICloudDeviceService.d.ts +0 -4
  62. package/dist/device/cloud/interfaces/ICloudDeviceService.js +0 -2
  63. package/dist/device/cloud/interfaces/IConnectionService.d.ts +0 -7
  64. package/dist/device/cloud/interfaces/IConnectionService.js +0 -2
  65. package/dist/device/cloud/interfaces/IDeviceConnectionService.d.ts +0 -7
  66. package/dist/device/cloud/interfaces/IDeviceConnectionService.js +0 -3
  67. package/dist/device/cloud/interfaces/IDeviceFactory.d.ts +0 -4
  68. package/dist/device/cloud/interfaces/IDeviceFactory.js +0 -2
  69. package/dist/device/cloud/interfaces/IDeviceService.d.ts +0 -8
  70. package/dist/device/cloud/interfaces/IDeviceService.js +0 -2
  71. package/dist/device/cloud/interfaces/IDevicesService.d.ts +0 -9
  72. package/dist/device/cloud/interfaces/IDevicesService.js +0 -2
  73. package/dist/device/cloud/interfaces/IHubService.d.ts +0 -5
  74. package/dist/device/cloud/interfaces/IHubService.js +0 -2
  75. package/dist/device/cloud/interfaces/IRawDataTransformer.d.ts +0 -4
  76. package/dist/device/cloud/interfaces/IRawDataTransformer.js +0 -2
  77. package/dist/device/cloud/interfaces/IRawDevice.d.ts +0 -17
  78. package/dist/device/cloud/interfaces/IRawDevice.js +0 -11
  79. package/dist/device/cloud/interfaces/index.d.ts +0 -5
  80. package/dist/device/cloud/interfaces/index.js +0 -21
  81. package/dist/device/cloud/services/CloudDevice.service.d.ts +0 -5
  82. package/dist/device/cloud/services/CloudDevice.service.js +0 -9
  83. package/dist/device/cloud/services/Connection.service.d.ts +0 -8
  84. package/dist/device/cloud/services/Connection.service.js +0 -6
  85. package/dist/device/cloud/services/Device.service.d.ts +0 -39
  86. package/dist/device/cloud/services/Device.service.js +0 -9
  87. package/dist/device/cloud/services/DeviceCloudService.d.ts +0 -42
  88. package/dist/device/cloud/services/DeviceCloudService.js +0 -59
  89. package/dist/device/cloud/services/DeviceHub.service.d.ts +0 -3
  90. package/dist/device/cloud/services/DeviceHub.service.js +0 -6
  91. package/dist/device/cloud/services/Hub.service.d.ts +0 -25
  92. package/dist/device/cloud/services/Hub.service.js +0 -9
  93. package/dist/device/cloud/services/SmartThingsDeviceService.d.ts +0 -38
  94. package/dist/device/cloud/services/SmartThingsDeviceService.js +0 -52
  95. package/dist/device/cloud/services/index.d.ts +0 -2
  96. package/dist/device/cloud/services/index.js +0 -18
  97. package/dist/device/cloud/types.d.ts +0 -52
  98. package/dist/device/cloud/types.js +0 -15
  99. package/dist/device/index.d.ts +0 -4
  100. package/dist/device/index.js +0 -20
  101. package/dist/device/local/entities/AlertBuilder.d.ts +0 -87
  102. package/dist/device/local/entities/AlertBuilder.example.d.ts +0 -11
  103. package/dist/device/local/entities/AlertBuilder.example.js +0 -117
  104. package/dist/device/local/entities/AlertBuilder.js +0 -179
  105. package/dist/device/local/entities/IssueBuilder.d.ts +0 -109
  106. package/dist/device/local/entities/IssueBuilder.example.d.ts +0 -16
  107. package/dist/device/local/entities/IssueBuilder.example.js +0 -196
  108. package/dist/device/local/entities/IssueBuilder.js +0 -237
  109. package/dist/device/local/entities/index.d.ts +0 -2
  110. package/dist/device/local/entities/index.js +0 -7
  111. package/dist/device/local/events/EventHandler.d.ts +0 -11
  112. package/dist/device/local/events/EventHandler.js +0 -86
  113. package/dist/device/local/events/Events.d.ts +0 -54
  114. package/dist/device/local/events/Events.js +0 -57
  115. package/dist/device/local/events/index.d.ts +0 -2
  116. package/dist/device/local/events/index.js +0 -7
  117. package/dist/device/local/handler/EventHandler.d.ts +0 -7
  118. package/dist/device/local/handler/EventHandler.js +0 -44
  119. package/dist/device/local/interface.d.ts +0 -0
  120. package/dist/device/local/interface.js +0 -1
  121. package/dist/device/local/interfaces/IConnection.d.ts +0 -26
  122. package/dist/device/local/interfaces/IConnection.js +0 -14
  123. package/dist/device/local/interfaces/IDevice.d.ts +0 -68
  124. package/dist/device/local/interfaces/IDevice.js +0 -10
  125. package/dist/device/local/interfaces/IDtDevice.d.ts +0 -16
  126. package/dist/device/local/interfaces/IDtDevice.js +0 -2
  127. package/dist/device/local/interfaces/IHub.d.ts +0 -46
  128. package/dist/device/local/interfaces/IHub.js +0 -2
  129. package/dist/device/local/interfaces/IProperty.d.ts +0 -29
  130. package/dist/device/local/interfaces/IProperty.js +0 -2
  131. package/dist/device/local/interfaces/ISchedule.d.ts +0 -25
  132. package/dist/device/local/interfaces/ISchedule.js +0 -2
  133. package/dist/device/local/interfaces/index.d.ts +0 -3
  134. package/dist/device/local/interfaces/index.js +0 -19
  135. package/dist/device/local/models/Alert.model.d.ts +0 -28
  136. package/dist/device/local/models/Alert.model.js +0 -222
  137. package/dist/device/local/models/Issue.model.d.ts +0 -28
  138. package/dist/device/local/models/Issue.model.js +0 -260
  139. package/dist/device/local/repository/Alert.repository.d.ts +0 -106
  140. package/dist/device/local/repository/Alert.repository.js +0 -374
  141. package/dist/device/local/repository/Connection.repository.d.ts +0 -8
  142. package/dist/device/local/repository/Connection.repository.js +0 -92
  143. package/dist/device/local/repository/Device.repository.d.ts +0 -30
  144. package/dist/device/local/repository/Device.repository.js +0 -325
  145. package/dist/device/local/repository/Hub.repository.d.ts +0 -13
  146. package/dist/device/local/repository/Hub.repository.js +0 -139
  147. package/dist/device/local/repository/Issue.repository.d.ts +0 -113
  148. package/dist/device/local/repository/Issue.repository.js +0 -401
  149. package/dist/device/local/repository/Property.repository.d.ts +0 -8
  150. package/dist/device/local/repository/Property.repository.js +0 -95
  151. package/dist/device/local/repository/Schedule.repository.d.ts +0 -9
  152. package/dist/device/local/repository/Schedule.repository.js +0 -109
  153. package/dist/device/local/services/Alert.service.d.ts +0 -137
  154. package/dist/device/local/services/Alert.service.js +0 -475
  155. package/dist/device/local/services/AlertService.example.d.ts +0 -55
  156. package/dist/device/local/services/AlertService.example.js +0 -148
  157. package/dist/device/local/services/Connection.service.d.ts +0 -8
  158. package/dist/device/local/services/Connection.service.js +0 -32
  159. package/dist/device/local/services/Device.service.d.ts +0 -40
  160. package/dist/device/local/services/Device.service.js +0 -391
  161. package/dist/device/local/services/DeviceHub.service.d.ts +0 -11
  162. package/dist/device/local/services/DeviceHub.service.js +0 -40
  163. package/dist/device/local/services/Hub.service.d.ts +0 -12
  164. package/dist/device/local/services/Hub.service.js +0 -107
  165. package/dist/device/local/services/Issue.service.d.ts +0 -168
  166. package/dist/device/local/services/Issue.service.js +0 -642
  167. package/dist/device/local/services/IssueService.example.d.ts +0 -68
  168. package/dist/device/local/services/IssueService.example.js +0 -177
  169. package/dist/device/local/services/Property.service.d.ts +0 -8
  170. package/dist/device/local/services/Property.service.js +0 -36
  171. package/dist/device/local/services/Schedule.service.d.ts +0 -9
  172. package/dist/device/local/services/Schedule.service.js +0 -26
  173. package/dist/device/local/services/index.d.ts +0 -3
  174. package/dist/device/local/services/index.js +0 -19
  175. package/dist/pms/IPms.d.ts +0 -6
  176. package/dist/pms/IPms.js +0 -10
  177. package/dist/pms/index.d.ts +0 -1
  178. package/dist/pms/index.js +0 -18
  179. package/dist/pms/webhookQueue/examples/index.d.ts +0 -2
  180. package/dist/pms/webhookQueue/examples/index.js +0 -18
  181. package/dist/pms/webhookQueue/examples/pms-integration.d.ts +0 -65
  182. package/dist/pms/webhookQueue/examples/pms-integration.js +0 -254
  183. package/dist/pms/webhookQueue/examples/usage.d.ts +0 -7
  184. package/dist/pms/webhookQueue/examples/usage.js +0 -175
  185. package/dist/pms/webhookQueue/index.d.ts +0 -3
  186. package/dist/pms/webhookQueue/index.js +0 -20
  187. package/dist/pms/webhookQueue/interfaces/IWebhookQueue.d.ts +0 -33
  188. package/dist/pms/webhookQueue/interfaces/IWebhookQueue.js +0 -2
  189. package/dist/pms/webhookQueue/interfaces/IWebhookWorker.d.ts +0 -38
  190. package/dist/pms/webhookQueue/interfaces/IWebhookWorker.js +0 -2
  191. package/dist/pms/webhookQueue/interfaces/index.d.ts +0 -1
  192. package/dist/pms/webhookQueue/interfaces/index.js +0 -17
  193. package/dist/pms/webhookQueue/services/WebhookQueueFactory.d.ts +0 -38
  194. package/dist/pms/webhookQueue/services/WebhookQueueFactory.js +0 -131
  195. package/dist/pms/webhookQueue/services/WebhookQueueIntegration.d.ts +0 -70
  196. package/dist/pms/webhookQueue/services/WebhookQueueIntegration.js +0 -207
  197. package/dist/pms/webhookQueue/services/WebhookQueueService.d.ts +0 -45
  198. package/dist/pms/webhookQueue/services/WebhookQueueService.js +0 -270
  199. package/dist/pms/webhookQueue/services/WebhookWorker.d.ts +0 -37
  200. package/dist/pms/webhookQueue/services/WebhookWorker.js +0 -201
  201. package/dist/pms/webhookQueue/services/index.d.ts +0 -1
  202. package/dist/pms/webhookQueue/services/index.js +0 -17
  203. package/dist/pms/webhookQueue/types/index.d.ts +0 -1
  204. package/dist/pms/webhookQueue/types/index.js +0 -17
  205. package/dist/pms/webhookQueue/types/webhook.types.d.ts +0 -39
  206. package/dist/pms/webhookQueue/types/webhook.types.js +0 -2
  207. package/dist/property/IProperty.d.ts +0 -29
  208. package/dist/property/IProperty.js +0 -2
  209. package/dist/property/Property.repository.d.ts +0 -8
  210. package/dist/property/Property.repository.js +0 -109
  211. package/dist/property/Property.service.d.ts +0 -8
  212. package/dist/property/Property.service.js +0 -124
  213. package/dist/property/index.d.ts +0 -2
  214. package/dist/property/index.js +0 -18
  215. package/dist/queue/interfaces/IHttpRequestJob.d.ts +0 -9
  216. package/dist/queue/interfaces/IHttpRequestJob.js +0 -2
  217. package/dist/types/alert.types.d.ts +0 -57
  218. package/dist/types/alert.types.js +0 -22
  219. package/dist/types/config.types.d.ts +0 -19
  220. package/dist/types/config.types.js +0 -2
  221. package/dist/types/index.d.ts +0 -3
  222. package/dist/types/index.js +0 -19
  223. package/dist/types/issue.types.d.ts +0 -90
  224. package/dist/types/issue.types.js +0 -40
  225. package/dist/utils/http-utils.d.ts +0 -13
  226. package/dist/utils/http-utils.js +0 -117
@@ -19,11 +19,16 @@ export declare class AlertService {
19
19
  * Create a hub-specific alert using AlertBuilder
20
20
  */
21
21
  raiseHubAlert(data: CreateAlertData): Promise<IAlertDocument | null>;
22
+ raiseDeviceTamperAttemptAlert(device: IDevice, zone: any, source: Source): Promise<IAlertDocument | null>;
22
23
  raiseDoorLeftOpenAlert(device: IDevice, zone: any, openThreshold: number, source: Source): Promise<IAlertDocument | null>;
23
24
  raiseNewDeviceAlert(device: {
24
25
  deviceId: string;
25
26
  deviceType: string;
26
27
  name: string;
28
+ }, connection: {
29
+ id: string;
30
+ provider: string;
31
+ type?: string;
27
32
  }, propertyId: string, source: Source): Promise<IAlertDocument | null>;
28
33
  raiseDoorOpenFrequentAlert(device: IDevice, zone: any, accessTimes: number, openThreshold: number, source: Source): Promise<IAlertDocument | null>;
29
34
  raiseDoorOpenOutsideBusinessHoursAlert(device: IDevice, zone: any, source: Source): Promise<IAlertDocument | null>;
@@ -162,6 +162,21 @@ let AlertService = (() => {
162
162
  alertBuilder.setEntitySubType(data.entitySubType);
163
163
  return await this.createAlert(alertBuilder);
164
164
  }
165
+ async raiseDeviceTamperAttemptAlert(device, zone, source) {
166
+ return await this.createAlert({
167
+ entityId: device.deviceId,
168
+ entityType: alert_types_1.EntityType.DEVICE,
169
+ entitySubType: device.deviceType.type,
170
+ propertyId: device.propertyId,
171
+ zoneId: device.zoneId,
172
+ title: "Device Tamper Attempt",
173
+ description: `System detected a tamper attempt on ${device.name}.`,
174
+ createdBy: source,
175
+ category: alert_types_1.AlertCategory.SECURITY,
176
+ severity: alert_types_1.AlertSeverity.CRITICAL,
177
+ type: alert_types_1.AlertType.DEVICE_TAMPER_ATTEMPT,
178
+ });
179
+ }
165
180
  async raiseDoorLeftOpenAlert(device, zone, openThreshold, source) {
166
181
  return await this.createAlert({
167
182
  entityId: device.deviceId,
@@ -177,14 +192,14 @@ let AlertService = (() => {
177
192
  type: alert_types_1.AlertType.DOOR_LEFT_OPEN,
178
193
  });
179
194
  }
180
- async raiseNewDeviceAlert(device, propertyId, source) {
195
+ async raiseNewDeviceAlert(device, connection, propertyId, source) {
181
196
  return await this.createAlert({
182
- entityId: device.deviceId,
183
- entityType: alert_types_1.EntityType.DEVICE,
184
- entitySubType: device?.deviceType,
197
+ entityId: connection.id,
198
+ entityType: alert_types_1.EntityType.CLOUD_DEVICE_ACCOUNT,
199
+ entitySubType: connection.provider,
185
200
  propertyId: propertyId,
186
201
  title: "New Device Detected",
187
- description: `New device ${device.name} has been detected.`,
202
+ description: `New device ${device.name} has been detected on the ${connection.provider} account.`,
188
203
  createdBy: source,
189
204
  category: alert_types_1.AlertCategory.OPERATIONS,
190
205
  severity: alert_types_1.AlertSeverity.INFO,
@@ -333,10 +348,11 @@ let AlertService = (() => {
333
348
  return await this.createAlert({
334
349
  zoneId: zone.zoneId,
335
350
  propertyId: zone.propertyId,
351
+ entityId: zone.zoneId,
336
352
  entityType: alert_types_1.EntityType.ZONE,
337
353
  entitySubType: issues_1.EntitySubType.ZONE,
338
354
  title: `Zone Not Mapped to Access Group`,
339
- description: `${zone?.name} is not mapped to any access group. Only Emergency Codes Generated. Add to an Access group to generate Guest and Staff Modes`,
355
+ description: `${zone?.name} is not mapped to any access group. Only Emergency Access Modes Generated. Add to an Access group to generate Guest and Staff Access Modes!`,
340
356
  createdBy: source,
341
357
  category: alert_types_1.AlertCategory.OPERATIONS,
342
358
  severity: alert_types_1.AlertSeverity.INFO,
@@ -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()
@@ -0,0 +1,5 @@
1
+ export declare class DeviceProfileRepository {
2
+ private readonly axiosInstance;
3
+ constructor();
4
+ getDeviceBaseLine(deviceId: string): Promise<void>;
5
+ }
@@ -37,44 +37,29 @@ var __setFunctionName = (this && this.__setFunctionName) || function (f, name, p
37
37
  if (typeof name === "symbol") name = name.description ? "[".concat(name.description, "]") : "";
38
38
  return Object.defineProperty(f, "name", { configurable: true, value: prefix ? "".concat(prefix, " ", name) : name });
39
39
  };
40
- var __importDefault = (this && this.__importDefault) || function (mod) {
41
- return (mod && mod.__esModule) ? mod : { "default": mod };
42
- };
43
40
  Object.defineProperty(exports, "__esModule", { value: true });
44
- exports.DeviceFactory = void 0;
45
- const Device_service_1 = require("../../local/services/Device.service");
46
- const typedi_1 = __importDefault(require("typedi"));
47
- const typedi_2 = require("typedi");
48
- let DeviceFactory = (() => {
49
- let _classDecorators = [(0, typedi_2.Service)()];
41
+ exports.DeviceProfileRepository = void 0;
42
+ const typedi_1 = require("typedi");
43
+ const utils_1 = require("../../../../utils");
44
+ let DeviceProfileRepository = (() => {
45
+ let _classDecorators = [(0, typedi_1.Service)()];
50
46
  let _classDescriptor;
51
47
  let _classExtraInitializers = [];
52
48
  let _classThis;
53
- var DeviceFactory = _classThis = class {
49
+ var DeviceProfileRepository = _classThis = class {
54
50
  constructor() {
55
- // Use dependency injection instead of creating new instance
56
- this.localDeviceService = typedi_1.default.get(Device_service_1.LocalDeviceService);
57
- }
58
- async getDevice(deviceId) {
59
- try {
60
- return await this.localDeviceService.getDevice(deviceId);
61
- }
62
- catch (error) {
63
- // Log the error for debugging purposes
64
- console.error(`DeviceFactory: Failed to get device ${deviceId}:`, error);
65
- // Re-throw the error with additional context
66
- throw new Error(`DeviceFactory: Unable to retrieve device ${deviceId}. ${error instanceof Error ? error.message : "Unknown error occurred"}`);
67
- }
51
+ this.axiosInstance = (0, utils_1.getDeviceServiceAxiosInstance)();
68
52
  }
53
+ async getDeviceBaseLine(deviceId) { }
69
54
  };
70
- __setFunctionName(_classThis, "DeviceFactory");
55
+ __setFunctionName(_classThis, "DeviceProfileRepository");
71
56
  (() => {
72
57
  const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(null) : void 0;
73
58
  __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
74
- DeviceFactory = _classThis = _classDescriptor.value;
59
+ DeviceProfileRepository = _classThis = _classDescriptor.value;
75
60
  if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
76
61
  __runInitializers(_classThis, _classExtraInitializers);
77
62
  })();
78
- return DeviceFactory = _classThis;
63
+ return DeviceProfileRepository = _classThis;
79
64
  })();
80
- exports.DeviceFactory = DeviceFactory;
65
+ exports.DeviceProfileRepository = DeviceProfileRepository;
@@ -142,20 +142,9 @@ let LocalDeviceService = (() => {
142
142
  if (body.state?.batteryPercentage?.value) {
143
143
  await this.setBatteryLevel(deviceId, body.state?.batteryPercentage?.value, auditBody?.source || Service_1.Source.SYSTEM, auditBody);
144
144
  }
145
- (0, audit_1.pushAudit)({
146
- auditType,
147
- auditData: {
148
- deviceId,
149
- zoneId: device.zoneId,
150
- deviceType: device.deviceType,
151
- deviceName: device.name,
152
- deviceStatus: device.status,
153
- ...auditBody,
154
- oldStatus: device.status,
155
- newStatus: body.status,
156
- },
157
- });
158
145
  }
146
+ delete body.state?.batteryPercentage;
147
+ delete body.status;
159
148
  await this.deviceRepository.updateDevice(deviceId, body);
160
149
  return await this.eventHandler.onDeviceUpdate(deviceId, body, auditBody);
161
150
  }
@@ -278,6 +267,7 @@ let LocalDeviceService = (() => {
278
267
  await this.eventHandler.onStatusChangeMany(query, newStatus, auditBody, eventType);
279
268
  }
280
269
  async handleOfflineStatus(device, oldStatus, newStatus, source, auditBody, reason, currentTime) {
270
+ currentTime = currentTime ?? new Date().toISOString();
281
271
  const isExistingStatusOnline = oldStatus?.liveStatus === "ONLINE";
282
272
  const isExistingStatusOffline = oldStatus?.liveStatus === "OFFLINE";
283
273
  if (isExistingStatusOnline) {
@@ -317,6 +307,7 @@ let LocalDeviceService = (() => {
317
307
  }
318
308
  }
319
309
  async handleOnlineStatus(device, oldStatus, newStatus, source, auditBody, reason, currentTime) {
310
+ currentTime = currentTime ?? new Date().toISOString();
320
311
  const isExistingStatusOnline = oldStatus?.online === true;
321
312
  const isExistingStatusOffline = oldStatus?.online === false;
322
313
  if (isExistingStatusOnline) {
@@ -333,14 +324,6 @@ let LocalDeviceService = (() => {
333
324
  newStatus.error = {}; // Clear the error
334
325
  await this.deviceRepository.setStatus(device.deviceId, newStatus);
335
326
  await this.eventHandler.onStatusChange(device.deviceId, newStatus, auditBody, constants_1.DT_EVENT_TYPES.DEVICE.STATUS.ONLINE);
336
- // Resolve issue if exists
337
- await this.issueService.performIssueAction({
338
- entityId: device.deviceId,
339
- entityType: issue_types_1.EntityType.DEVICE,
340
- type: issue_types_1.IssueType.DEVICE_OFFLINE,
341
- propertyId: device.propertyId,
342
- zoneId: device.zoneId,
343
- }, "resolve", source);
344
327
  }
345
328
  }
346
329
  else if (isExistingStatusOffline) {
@@ -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");
@@ -27,6 +27,9 @@ class InternalEventSubscription {
27
27
  try {
28
28
  const eventType = message["detail-type"];
29
29
  const eventData = message.detail;
30
+ //TODO: To be sent with event data, to delete the message if processing is failed!
31
+ const eventToken = message.receiptHandle;
32
+ console.log('eventToken', eventToken);
30
33
  this.logger.info(`Received internal event: ${eventType} ${eventData}`);
31
34
  switch (eventType) {
32
35
  case InternalEventType.HEARTBEAT:
@@ -42,6 +42,10 @@ export declare class IssueService {
42
42
  deviceId: string;
43
43
  deviceType: string;
44
44
  name: string;
45
+ }, connection: {
46
+ id: string;
47
+ provider: string;
48
+ type?: string;
45
49
  }, propertyId: string, source: Source): Promise<IIssueDocument | null>;
46
50
  createAccountUnauthorizedIssue(account: {
47
51
  accountId: string;
@@ -266,14 +266,14 @@ let IssueService = (() => {
266
266
  type: issue_types_1.IssueType.BATTERY_LOW,
267
267
  });
268
268
  }
269
- async createAccountMissingDeviceIssue(device, propertyId, source) {
269
+ async createAccountMissingDeviceIssue(device, connection, propertyId, source) {
270
270
  return await this.createIssue({
271
- entityId: device.deviceId,
272
- entityType: issue_types_1.EntityType.DEVICE,
273
- entitySubType: device.deviceType,
271
+ entityId: connection.id,
272
+ entityType: issue_types_1.EntityType.CLOUD_DEVICE_ACCOUNT,
273
+ entitySubType: connection.provider,
274
274
  propertyId: propertyId,
275
275
  title: "Device Missing",
276
- description: `${device.name} is missing from the account. Requires Attention.`,
276
+ description: `${device.name} is missing from the ${connection.provider} account.`,
277
277
  createdBy: source,
278
278
  category: issue_types_1.IssuesCategory.OPERATIONS,
279
279
  priority: issue_types_1.IssuePriority.CRITICAL,
@@ -401,7 +401,7 @@ let IssueService = (() => {
401
401
  type: processedIssueData.type,
402
402
  });
403
403
  if (existingIssue.length > 0) {
404
- await (0, audit_1.pushAudit)({
404
+ (0, audit_1.pushAudit)({
405
405
  auditType: constants_1.DT_EVENT_TYPES.ISSUE.CREATE.SKIPPED,
406
406
  auditData: {
407
407
  reason: "Issue already exists",
@@ -417,7 +417,7 @@ let IssueService = (() => {
417
417
  return null;
418
418
  }
419
419
  const issue = await this.issueRepository.create(processedIssueData);
420
- await (0, audit_1.pushAudit)({
420
+ (0, audit_1.pushAudit)({
421
421
  auditType: constants_1.DT_EVENT_TYPES.ISSUE.CREATE.SUCCESS,
422
422
  auditData: {
423
423
  resource: audit_1.Resource.ISSUE,
@@ -436,7 +436,7 @@ let IssueService = (() => {
436
436
  return issue;
437
437
  }
438
438
  catch (error) {
439
- await (0, audit_1.pushAudit)({
439
+ (0, audit_1.pushAudit)({
440
440
  auditType: constants_1.DT_EVENT_TYPES.ISSUE.CREATE.FAILED,
441
441
  auditData: {
442
442
  resource: audit_1.Resource.ISSUE,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "dt-common-device",
3
- "version": "7.10.1",
3
+ "version": "7.10.3",
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
- }
@@ -1,182 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __esDecorate = (this && this.__esDecorate) || function (ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {
19
- function accept(f) { if (f !== void 0 && typeof f !== "function") throw new TypeError("Function expected"); return f; }
20
- var kind = contextIn.kind, key = kind === "getter" ? "get" : kind === "setter" ? "set" : "value";
21
- var target = !descriptorIn && ctor ? contextIn["static"] ? ctor : ctor.prototype : null;
22
- var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});
23
- var _, done = false;
24
- for (var i = decorators.length - 1; i >= 0; i--) {
25
- var context = {};
26
- for (var p in contextIn) context[p] = p === "access" ? {} : contextIn[p];
27
- for (var p in contextIn.access) context.access[p] = contextIn.access[p];
28
- context.addInitializer = function (f) { if (done) throw new TypeError("Cannot add initializers after decoration has completed"); extraInitializers.push(accept(f || null)); };
29
- var result = (0, decorators[i])(kind === "accessor" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);
30
- if (kind === "accessor") {
31
- if (result === void 0) continue;
32
- if (result === null || typeof result !== "object") throw new TypeError("Object expected");
33
- if (_ = accept(result.get)) descriptor.get = _;
34
- if (_ = accept(result.set)) descriptor.set = _;
35
- if (_ = accept(result.init)) initializers.unshift(_);
36
- }
37
- else if (_ = accept(result)) {
38
- if (kind === "field") initializers.unshift(_);
39
- else descriptor[key] = _;
40
- }
41
- }
42
- if (target) Object.defineProperty(target, contextIn.name, descriptor);
43
- done = true;
44
- };
45
- var __runInitializers = (this && this.__runInitializers) || function (thisArg, initializers, value) {
46
- var useValue = arguments.length > 2;
47
- for (var i = 0; i < initializers.length; i++) {
48
- value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);
49
- }
50
- return useValue ? value : void 0;
51
- };
52
- var __importStar = (this && this.__importStar) || (function () {
53
- var ownKeys = function(o) {
54
- ownKeys = Object.getOwnPropertyNames || function (o) {
55
- var ar = [];
56
- for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
57
- return ar;
58
- };
59
- return ownKeys(o);
60
- };
61
- return function (mod) {
62
- if (mod && mod.__esModule) return mod;
63
- var result = {};
64
- if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
65
- __setModuleDefault(result, mod);
66
- return result;
67
- };
68
- })();
69
- var __setFunctionName = (this && this.__setFunctionName) || function (f, name, prefix) {
70
- if (typeof name === "symbol") name = name.description ? "[".concat(name.description, "]") : "";
71
- return Object.defineProperty(f, "name", { configurable: true, value: prefix ? "".concat(prefix, " ", name) : name });
72
- };
73
- Object.defineProperty(exports, "__esModule", { value: true });
74
- exports.AdminRepository = void 0;
75
- const typedi_1 = __importStar(require("typedi"));
76
- const utils_1 = require("../utils");
77
- const Device_repository_1 = require("../device/local/repository/Device.repository");
78
- const db_1 = require("../db/db");
79
- const interfaces_1 = require("../device/cloud/interfaces");
80
- let AdminRepository = (() => {
81
- let _classDecorators = [(0, typedi_1.Service)()];
82
- let _classDescriptor;
83
- let _classExtraInitializers = [];
84
- let _classThis;
85
- var AdminRepository = _classThis = class {
86
- constructor() {
87
- this.axiosInstance = (0, utils_1.getCloudServiceAxiosInstance)();
88
- this.deviceRepository = typedi_1.default.get(Device_repository_1.DeviceRepository);
89
- this.postgres = (0, db_1.getPostgresClient)();
90
- }
91
- async getZonesByAccessGroupIds(accessGroupIds) {
92
- const result = await this.postgres.query(`SELECT "zc".*, "z"."id", "z"."name"
93
- FROM "dt_zones_collection_map" "zc"
94
- INNER JOIN "dt_zones" "z" ON "zc"."zoneId" = "z"."id"
95
- WHERE "zc"."collectionId" = ANY($1)`, [accessGroupIds]);
96
- const response = result.rows;
97
- const _zones = (nestedZones, allzones = []) => {
98
- nestedZones.forEach((z) => {
99
- const onlyZone = { ...z };
100
- delete onlyZone.childZones;
101
- allzones.push(onlyZone);
102
- if (!Array.isArray(z.childZones)) {
103
- if (z.childZones.id)
104
- z.childZones = [z.childZones];
105
- }
106
- if (z.childZones.length) {
107
- _zones(z.childZones, allzones);
108
- }
109
- });
110
- return allzones.map((e) => e.id);
111
- };
112
- // const zones = _zones(response);
113
- const zoneIds = response.map((el) => el.id);
114
- const collectionZone = [];
115
- for (let i = 0; i < response.length; i++) {
116
- let zoneIds = [];
117
- const zones = await this.axiosInstance.get(`/zones/child?zoneId=${response[i].zoneId}`);
118
- zoneIds.push(response[i].zoneId);
119
- if (zones.childZones?.length > 0) {
120
- const nestedZoneIds = new Set(_zones(zones.childZones));
121
- zoneIds = [...zoneIds, ...nestedZoneIds];
122
- }
123
- if (collectionZone.length == 0) {
124
- const obj = {
125
- collectionId: response[i].collectionId,
126
- zoneIds,
127
- };
128
- collectionZone.push(obj);
129
- }
130
- else {
131
- const obj = collectionZone.find((e) => e.collectionId == response[i].collectionId);
132
- if (obj) {
133
- obj.zoneIds = [...obj.zoneIds, ...zoneIds];
134
- }
135
- else {
136
- collectionZone.push({
137
- collectionId: response[i].collectionId,
138
- zoneIds,
139
- });
140
- }
141
- }
142
- }
143
- let _zoneIds = collectionZone.flatMap((e) => {
144
- return e.zoneIds.map((z) => z);
145
- });
146
- if (_zoneIds.length === 0)
147
- return [];
148
- const deviecDetail = await this.deviceRepository.queryDevices({
149
- zoneIds: _zoneIds,
150
- excludeDeviceType: interfaces_1.DeviceType.HUB
151
- });
152
- const _collectionZone = collectionZone.map((e) => {
153
- const zones = e.zoneIds;
154
- let devices = [];
155
- zones.forEach((element) => {
156
- const device = deviecDetail.filter((d) => d.zoneId == element);
157
- // Add collectionId to each device
158
- device.forEach((dev) => {
159
- dev.collectionId = e.collectionId;
160
- });
161
- const _devices = devices.concat(device);
162
- devices = _devices;
163
- });
164
- e.devices = devices;
165
- e.parentZone = response;
166
- return e;
167
- });
168
- const collectionZoneDevices = Array.from(new Set(_collectionZone));
169
- return collectionZoneDevices;
170
- }
171
- };
172
- __setFunctionName(_classThis, "AdminRepository");
173
- (() => {
174
- const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(null) : void 0;
175
- __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
176
- AdminRepository = _classThis = _classDescriptor.value;
177
- if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
178
- __runInitializers(_classThis, _classExtraInitializers);
179
- })();
180
- return AdminRepository = _classThis;
181
- })();
182
- exports.AdminRepository = AdminRepository;