dt-common-device 8.0.6 → 8.0.8

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/chronicle/Cronicle.service.d.ts +6 -2
  2. package/dist/chronicle/Cronicle.service.js +19 -2
  3. package/dist/chronicle/ICronicle.interface.d.ts +1 -0
  4. package/dist/constants/Event.d.ts +1 -0
  5. package/dist/constants/Event.js +1 -0
  6. package/dist/entities/accessGroup/AccessGroup.repository.d.ts +2 -1
  7. package/dist/entities/accessGroup/AccessGroup.repository.js +4 -1
  8. package/dist/entities/accessGroup/AccessGroup.service.d.ts +2 -1
  9. package/dist/entities/accessGroup/AccessGroup.service.js +4 -3
  10. package/dist/entities/device/local/interfaces/ISchedule.d.ts +3 -0
  11. package/dist/entities/guest/Guest.repository.d.ts +1 -1
  12. package/dist/entities/guest/Guest.repository.js +5 -2
  13. package/dist/entities/guest/Guest.service.d.ts +1 -1
  14. package/dist/entities/guest/Guest.service.js +4 -1
  15. package/dist/entities/schedules/Schedule.repository.d.ts +1 -1
  16. package/dist/entities/schedules/Schedule.repository.js +5 -2
  17. package/dist/entities/schedules/Schedule.service.d.ts +1 -1
  18. package/dist/entities/schedules/Schedule.service.js +4 -1
  19. package/dist/entities/user/User.repository.js +4 -1
  20. package/dist/entities/user/User.service.d.ts +1 -1
  21. package/dist/entities/user/User.service.js +4 -1
  22. package/dist/entities/zone/Zone.service.js +4 -1
  23. package/dist/issues/Issue.service.js +3 -3
  24. package/package.json +1 -1
  25. package/dist/admin/Admin.repository.d.ts +0 -7
  26. package/dist/admin/Admin.repository.js +0 -182
  27. package/dist/admin/Admin.service.d.ts +0 -5
  28. package/dist/admin/Admin.service.js +0 -17
  29. package/dist/admin/index.d.ts +0 -1
  30. package/dist/admin/index.js +0 -17
  31. package/dist/audit/AuditProperties.d.ts +0 -16
  32. package/dist/audit/AuditProperties.js +0 -2
  33. package/dist/chronicle/IChronicle.interface.d.ts +0 -14
  34. package/dist/chronicle/IChronicle.interface.js +0 -2
  35. package/dist/chronicle/chronicle.service.d.ts +0 -4
  36. package/dist/chronicle/chronicle.service.js +0 -44
  37. package/dist/connection/Connection.repository.d.ts +0 -8
  38. package/dist/connection/Connection.repository.js +0 -92
  39. package/dist/connection/Connection.service.d.ts +0 -8
  40. package/dist/connection/Connection.service.js +0 -32
  41. package/dist/connection/IConnection.d.ts +0 -28
  42. package/dist/connection/IConnection.js +0 -16
  43. package/dist/connection/index.d.ts +0 -2
  44. package/dist/connection/index.js +0 -18
  45. package/dist/device/cloud/entities/CloudConnection.d.ts +0 -6
  46. package/dist/device/cloud/entities/CloudConnection.js +0 -6
  47. package/dist/device/cloud/entities/CloudDevice.d.ts +0 -16
  48. package/dist/device/cloud/entities/CloudDevice.js +0 -26
  49. package/dist/device/cloud/entities/CloudDeviceService.d.ts +0 -5
  50. package/dist/device/cloud/entities/CloudDeviceService.js +0 -9
  51. package/dist/device/cloud/entities/DeviceFactory.d.ts +0 -7
  52. package/dist/device/cloud/entities/DeviceFactory.js +0 -80
  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
@@ -1,9 +1,13 @@
1
1
  import { ICronicle } from "./ICronicle.interface";
2
2
  export declare class CronicleService {
3
- private cronicleEndpoint;
4
- private cronicleApiKey;
3
+ private readonly cronicleEndpoint;
4
+ private readonly cronicleApiKey;
5
5
  constructor();
6
6
  registerJob(payload: ICronicle): Promise<void>;
7
7
  getJob(jobId: string): Promise<any>;
8
+ getSchedules(filter: {
9
+ offset: number;
10
+ limit: number;
11
+ }): Promise<any>;
8
12
  deleteJob(jobId: string): Promise<void>;
9
13
  }
@@ -12,12 +12,12 @@ class CronicleService {
12
12
  this.cronicleApiKey = process.env.CRONICLE_API_KEY || "";
13
13
  }
14
14
  async registerJob(payload) {
15
- const { name, apiUrl, method, schedule, cronJobId, target } = payload;
15
+ const { name, apiUrl, method, schedule, cronJobId, target, category } = payload;
16
16
  try {
17
17
  await axios_1.default.post(`${this.cronicleEndpoint}/create_event/v1`, {
18
18
  id: cronJobId,
19
19
  title: name,
20
- category: "general",
20
+ category: category ?? "general",
21
21
  plugin: "urlplug",
22
22
  timeZone: "UTC",
23
23
  enabled: 1,
@@ -48,6 +48,8 @@ class CronicleService {
48
48
  }
49
49
  async getJob(jobId) {
50
50
  try {
51
+ (0, config_1.getConfig)().LOGGER.info(`Getting job: ${jobId}`);
52
+ (0, config_1.getConfig)().LOGGER.info(`Cronicle endpoint: ${this.cronicleEndpoint}/get_event/v1`);
51
53
  const res = await axios_1.default.post(`${this.cronicleEndpoint}/get_event/v1`, {
52
54
  id: jobId,
53
55
  api_key: this.cronicleApiKey,
@@ -55,6 +57,21 @@ class CronicleService {
55
57
  return res.data;
56
58
  }
57
59
  catch (error) {
60
+ (0, config_1.getConfig)().LOGGER.error(`Failed to get job: ${error.message}`);
61
+ return;
62
+ }
63
+ }
64
+ async getSchedules(filter) {
65
+ try {
66
+ const res = await axios_1.default.post(`${this.cronicleEndpoint}/get_schedule/v1`, {
67
+ api_key: this.cronicleApiKey,
68
+ offset: filter.offset ?? 0,
69
+ limit: filter.limit ?? 100,
70
+ });
71
+ return res.data;
72
+ }
73
+ catch (error) {
74
+ (0, config_1.getConfig)().LOGGER.error(`Failed to get schedules: ${error.message}`);
58
75
  return;
59
76
  }
60
77
  }
@@ -1,6 +1,7 @@
1
1
  export interface ICronicle {
2
2
  name: string;
3
3
  cronJobId: string;
4
+ category?: "heartbeat" | "replenish_codes" | "sync_reservations" | "delete_reservations" | "deliver_codes" | "daily_summary" | "battery_report";
4
5
  apiUrl: string;
5
6
  method: "POST";
6
7
  target: string;
@@ -257,6 +257,7 @@ export declare const DT_EVENT_TYPES: {
257
257
  SCHEDULE_CODES: string;
258
258
  MARKED_TO_DELETE_CODES: string;
259
259
  UNSET_CODES: string;
260
+ ORPHANED_GUEST_CODES: string;
260
261
  };
261
262
  STOPPED: string;
262
263
  COMPLETED: string;
@@ -260,6 +260,7 @@ exports.DT_EVENT_TYPES = {
260
260
  SCHEDULE_CODES: "heartbeat.lock.schedule_codes",
261
261
  MARKED_TO_DELETE_CODES: "heartbeat.lock.marked_to_delete_codes",
262
262
  UNSET_CODES: "heartbeat.lock.unset_codes",
263
+ ORPHANED_GUEST_CODES: "heartbeat.lock.orphaned_guest_codes",
263
264
  },
264
265
  STOPPED: "heartbeat.stopped",
265
266
  COMPLETED: "heartbeat.completed",
@@ -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()
@@ -21,6 +21,9 @@ export interface ISchedule {
21
21
  timezone: string;
22
22
  scheduleInheritedFrom?: "zone" | "device";
23
23
  zoneId: string;
24
+ reservationId?: string;
25
+ accessGroupId?: string;
26
+ type: "ON" | "OFF";
24
27
  userId?: string;
25
28
  status: "SET" | "UNSET";
26
29
  }
@@ -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");
@@ -764,7 +764,7 @@ let IssueService = (() => {
764
764
  const updatedIssue = await this.updateIssue(issue.id, updateData);
765
765
  if (updatedIssue) {
766
766
  // Log the action for audit purposes
767
- console.log(`Issue ${issue.id} has been ${action}ed by ${updatedBy}`);
767
+ //console.log(`Issue ${issue.id} has been ${action}ed by ${updatedBy}`);
768
768
  await dt_pub_sub_1.eventDispatcher.publishEvent(auditType, updatedIssue, "dt-common-device");
769
769
  await (0, audit_1.pushAudit)({
770
770
  auditType: auditType,
@@ -837,8 +837,8 @@ let IssueService = (() => {
837
837
  const responseTime = this.calculateAverageResponseTime(stats);
838
838
  const resolutionRate = this.calculateResolutionRate(stats);
839
839
  // Log resolution rate for monitoring
840
- console.log(`Resolution rate: ${resolutionRate.toFixed(2)}%`);
841
- console.log(`Response time: ${responseTime.toFixed(2)} days`);
840
+ // console.log(`Resolution rate: ${resolutionRate.toFixed(2)}%`);
841
+ // console.log(`Response time: ${responseTime.toFixed(2)} days`);
842
842
  // Business logic: Add alerts for critical metrics
843
843
  if (stats.overdue > 0) {
844
844
  console.warn(`Alert: ${stats.overdue} overdue issues detected`);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "dt-common-device",
3
- "version": "8.0.6",
3
+ "version": "8.0.8",
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;
@@ -1,5 +0,0 @@
1
- export declare class AdminService {
2
- private readonly adminRepository;
3
- constructor();
4
- getZonesByAccessGroupIds(accessGroupIds: string[]): Promise<any[]>;
5
- }
@@ -1,17 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.AdminService = void 0;
7
- const typedi_1 = __importDefault(require("typedi"));
8
- const Admin_repository_1 = require("./Admin.repository");
9
- class AdminService {
10
- constructor() {
11
- this.adminRepository = typedi_1.default.get(Admin_repository_1.AdminRepository);
12
- }
13
- async getZonesByAccessGroupIds(accessGroupIds) {
14
- return await this.adminRepository.getZonesByAccessGroupIds(accessGroupIds);
15
- }
16
- }
17
- exports.AdminService = AdminService;
@@ -1 +0,0 @@
1
- export * from "./Admin.service";
@@ -1,17 +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 __exportStar = (this && this.__exportStar) || function(m, exports) {
14
- for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
- };
16
- Object.defineProperty(exports, "__esModule", { value: true });
17
- __exportStar(require("./Admin.service"), exports);
@@ -1,16 +0,0 @@
1
- export interface AuditProperties {
2
- resource: string;
3
- propertyId: string;
4
- propertyName?: string;
5
- userId?: string;
6
- userName?: string;
7
- deviceId?: string;
8
- deviceName?: string;
9
- zoneId?: string;
10
- zoneName?: string;
11
- accessGroupId?: string;
12
- accessGroupName?: string;
13
- scheduleId?: string;
14
- scheduleName?: string;
15
- [key: string]: any;
16
- }
@@ -1,2 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
@@ -1,14 +0,0 @@
1
- export interface ICronicle {
2
- name: string;
3
- cronJobId: string;
4
- apiUrl: string;
5
- method: "POST";
6
- target: string;
7
- schedule: {
8
- minutes?: string;
9
- hours?: string;
10
- dom?: string;
11
- month?: string;
12
- dow?: string;
13
- };
14
- }
@@ -1,2 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
@@ -1,4 +0,0 @@
1
- import { ICronicle } from "./IChronicle.interface";
2
- export declare class ChronicleClass {
3
- registerJob(payload: ICronicle): Promise<void>;
4
- }
@@ -1,44 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.ChronicleClass = void 0;
7
- const config_1 = require("../config/config");
8
- const axios_1 = __importDefault(require("axios"));
9
- class ChronicleClass {
10
- async registerJob(payload) {
11
- const { name, apiUrl, method, schedule, cronJobId, target } = payload;
12
- try {
13
- const cronicleEndpoint = process.env.CRONICLE_ENDPOINT;
14
- const cronicleApiKey = process.env.CRONICLE_API_KEY;
15
- await axios_1.default.post(`${cronicleEndpoint}/create_event`, {
16
- id: cronJobId,
17
- title: name,
18
- category: "general",
19
- plugin: "urlplug",
20
- timeZone: "UTC",
21
- enabled: 1,
22
- params: {
23
- url: apiUrl,
24
- method,
25
- headers: `dt-cronicle-api-key: ${cronicleApiKey}`,
26
- },
27
- data: payload,
28
- target: target,
29
- timing: {
30
- minutes: schedule.minutes ?? "0",
31
- hours: schedule.hours ?? "*",
32
- dom: schedule.dom ?? "*",
33
- month: schedule.month ?? "*",
34
- dow: schedule.dow ?? "*",
35
- },
36
- });
37
- (0, config_1.getConfig)().LOGGER.info(`Successfully registered chronicle job: ${name} with ID: ${cronJobId}`);
38
- }
39
- catch (error) {
40
- (0, config_1.getConfig)().LOGGER.error(`Failed to create device: ${error.message}`);
41
- }
42
- }
43
- }
44
- exports.ChronicleClass = ChronicleClass;