dt-common-device 11.2.1 → 12.0.1

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 (238) 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/ConnectionProviders.d.ts +0 -1
  5. package/dist/constants/ConnectionProviders.js +0 -1
  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/admin/Admin.repository.d.ts +1 -2
  11. package/dist/entities/admin/Admin.repository.js +19 -15
  12. package/dist/entities/admin/Admin.service.d.ts +1 -1
  13. package/dist/entities/admin/Admin.service.js +2 -2
  14. package/dist/entities/connection/Connection.repository.d.ts +1 -0
  15. package/dist/entities/connection/Connection.repository.js +22 -0
  16. package/dist/entities/connection/Connection.service.d.ts +1 -0
  17. package/dist/entities/connection/Connection.service.js +3 -0
  18. package/dist/entities/guest/Guest.repository.d.ts +1 -1
  19. package/dist/entities/guest/Guest.repository.js +5 -2
  20. package/dist/entities/guest/Guest.service.d.ts +1 -1
  21. package/dist/entities/guest/Guest.service.js +4 -1
  22. package/dist/entities/schedules/Schedule.repository.d.ts +1 -1
  23. package/dist/entities/schedules/Schedule.repository.js +5 -2
  24. package/dist/entities/schedules/Schedule.service.d.ts +1 -1
  25. package/dist/entities/schedules/Schedule.service.js +4 -1
  26. package/dist/entities/user/User.repository.js +4 -1
  27. package/dist/entities/user/User.service.d.ts +1 -1
  28. package/dist/entities/user/User.service.js +4 -1
  29. package/dist/entities/zone/Zone.service.js +4 -1
  30. package/dist/issues/Issue.service.js +1 -1
  31. package/dist/queue/utils/rateLimit.utils.js +0 -6
  32. package/package.json +1 -1
  33. package/dist/admin/Admin.repository.d.ts +0 -7
  34. package/dist/admin/Admin.repository.js +0 -182
  35. package/dist/admin/Admin.service.d.ts +0 -5
  36. package/dist/admin/Admin.service.js +0 -17
  37. package/dist/admin/index.d.ts +0 -1
  38. package/dist/admin/index.js +0 -17
  39. package/dist/audit/AuditProperties.d.ts +0 -16
  40. package/dist/audit/AuditProperties.js +0 -2
  41. package/dist/chronicle/IChronicle.interface.d.ts +0 -14
  42. package/dist/chronicle/IChronicle.interface.js +0 -2
  43. package/dist/chronicle/chronicle.service.d.ts +0 -4
  44. package/dist/chronicle/chronicle.service.js +0 -44
  45. package/dist/connection/Connection.repository.d.ts +0 -8
  46. package/dist/connection/Connection.repository.js +0 -92
  47. package/dist/connection/Connection.service.d.ts +0 -8
  48. package/dist/connection/Connection.service.js +0 -32
  49. package/dist/connection/IConnection.d.ts +0 -28
  50. package/dist/connection/IConnection.js +0 -16
  51. package/dist/connection/index.d.ts +0 -2
  52. package/dist/connection/index.js +0 -18
  53. package/dist/copilotQueue/examples/CopilotQueue.example.d.ts +0 -37
  54. package/dist/copilotQueue/examples/CopilotQueue.example.js +0 -140
  55. package/dist/copilotQueue/examples/index.d.ts +0 -1
  56. package/dist/copilotQueue/examples/index.js +0 -17
  57. package/dist/device/cloud/entities/CloudConnection.d.ts +0 -6
  58. package/dist/device/cloud/entities/CloudConnection.js +0 -6
  59. package/dist/device/cloud/entities/CloudDevice.d.ts +0 -16
  60. package/dist/device/cloud/entities/CloudDevice.js +0 -26
  61. package/dist/device/cloud/entities/CloudDeviceService.d.ts +0 -5
  62. package/dist/device/cloud/entities/CloudDeviceService.js +0 -9
  63. package/dist/device/cloud/entities/DeviceFactory.d.ts +0 -7
  64. package/dist/device/cloud/entities/DeviceFactory.js +0 -80
  65. package/dist/device/cloud/entities/index.d.ts +0 -3
  66. package/dist/device/cloud/entities/index.js +0 -19
  67. package/dist/device/cloud/interface.d.ts +0 -101
  68. package/dist/device/cloud/interface.js +0 -3
  69. package/dist/device/cloud/interfaces/ICloudConnection.d.ts +0 -5
  70. package/dist/device/cloud/interfaces/ICloudConnection.js +0 -2
  71. package/dist/device/cloud/interfaces/ICloudDevice.d.ts +0 -9
  72. package/dist/device/cloud/interfaces/ICloudDevice.js +0 -2
  73. package/dist/device/cloud/interfaces/ICloudDeviceService.d.ts +0 -4
  74. package/dist/device/cloud/interfaces/ICloudDeviceService.js +0 -2
  75. package/dist/device/cloud/interfaces/IConnectionService.d.ts +0 -7
  76. package/dist/device/cloud/interfaces/IConnectionService.js +0 -2
  77. package/dist/device/cloud/interfaces/IDeviceConnectionService.d.ts +0 -7
  78. package/dist/device/cloud/interfaces/IDeviceConnectionService.js +0 -3
  79. package/dist/device/cloud/interfaces/IDeviceFactory.d.ts +0 -4
  80. package/dist/device/cloud/interfaces/IDeviceFactory.js +0 -2
  81. package/dist/device/cloud/interfaces/IDeviceService.d.ts +0 -8
  82. package/dist/device/cloud/interfaces/IDeviceService.js +0 -2
  83. package/dist/device/cloud/interfaces/IDevicesService.d.ts +0 -9
  84. package/dist/device/cloud/interfaces/IDevicesService.js +0 -2
  85. package/dist/device/cloud/interfaces/IHubService.d.ts +0 -5
  86. package/dist/device/cloud/interfaces/IHubService.js +0 -2
  87. package/dist/device/cloud/interfaces/IRawDataTransformer.d.ts +0 -4
  88. package/dist/device/cloud/interfaces/IRawDataTransformer.js +0 -2
  89. package/dist/device/cloud/interfaces/IRawDevice.d.ts +0 -17
  90. package/dist/device/cloud/interfaces/IRawDevice.js +0 -11
  91. package/dist/device/cloud/interfaces/index.d.ts +0 -5
  92. package/dist/device/cloud/interfaces/index.js +0 -21
  93. package/dist/device/cloud/services/CloudDevice.service.d.ts +0 -5
  94. package/dist/device/cloud/services/CloudDevice.service.js +0 -9
  95. package/dist/device/cloud/services/Connection.service.d.ts +0 -8
  96. package/dist/device/cloud/services/Connection.service.js +0 -6
  97. package/dist/device/cloud/services/Device.service.d.ts +0 -39
  98. package/dist/device/cloud/services/Device.service.js +0 -9
  99. package/dist/device/cloud/services/DeviceCloudService.d.ts +0 -42
  100. package/dist/device/cloud/services/DeviceCloudService.js +0 -59
  101. package/dist/device/cloud/services/DeviceHub.service.d.ts +0 -3
  102. package/dist/device/cloud/services/DeviceHub.service.js +0 -6
  103. package/dist/device/cloud/services/Hub.service.d.ts +0 -25
  104. package/dist/device/cloud/services/Hub.service.js +0 -9
  105. package/dist/device/cloud/services/SmartThingsDeviceService.d.ts +0 -38
  106. package/dist/device/cloud/services/SmartThingsDeviceService.js +0 -52
  107. package/dist/device/cloud/services/index.d.ts +0 -2
  108. package/dist/device/cloud/services/index.js +0 -18
  109. package/dist/device/cloud/types.d.ts +0 -52
  110. package/dist/device/cloud/types.js +0 -15
  111. package/dist/device/index.d.ts +0 -4
  112. package/dist/device/index.js +0 -20
  113. package/dist/device/local/entities/AlertBuilder.d.ts +0 -87
  114. package/dist/device/local/entities/AlertBuilder.example.d.ts +0 -11
  115. package/dist/device/local/entities/AlertBuilder.example.js +0 -117
  116. package/dist/device/local/entities/AlertBuilder.js +0 -179
  117. package/dist/device/local/entities/IssueBuilder.d.ts +0 -109
  118. package/dist/device/local/entities/IssueBuilder.example.d.ts +0 -16
  119. package/dist/device/local/entities/IssueBuilder.example.js +0 -196
  120. package/dist/device/local/entities/IssueBuilder.js +0 -237
  121. package/dist/device/local/entities/index.d.ts +0 -2
  122. package/dist/device/local/entities/index.js +0 -7
  123. package/dist/device/local/events/EventHandler.d.ts +0 -11
  124. package/dist/device/local/events/EventHandler.js +0 -86
  125. package/dist/device/local/events/Events.d.ts +0 -54
  126. package/dist/device/local/events/Events.js +0 -57
  127. package/dist/device/local/events/index.d.ts +0 -2
  128. package/dist/device/local/events/index.js +0 -7
  129. package/dist/device/local/handler/EventHandler.d.ts +0 -7
  130. package/dist/device/local/handler/EventHandler.js +0 -44
  131. package/dist/device/local/interface.d.ts +0 -0
  132. package/dist/device/local/interface.js +0 -1
  133. package/dist/device/local/interfaces/IConnection.d.ts +0 -26
  134. package/dist/device/local/interfaces/IConnection.js +0 -14
  135. package/dist/device/local/interfaces/IDevice.d.ts +0 -68
  136. package/dist/device/local/interfaces/IDevice.js +0 -10
  137. package/dist/device/local/interfaces/IDtDevice.d.ts +0 -16
  138. package/dist/device/local/interfaces/IDtDevice.js +0 -2
  139. package/dist/device/local/interfaces/IHub.d.ts +0 -46
  140. package/dist/device/local/interfaces/IHub.js +0 -2
  141. package/dist/device/local/interfaces/IProperty.d.ts +0 -29
  142. package/dist/device/local/interfaces/IProperty.js +0 -2
  143. package/dist/device/local/interfaces/ISchedule.d.ts +0 -25
  144. package/dist/device/local/interfaces/ISchedule.js +0 -2
  145. package/dist/device/local/interfaces/index.d.ts +0 -3
  146. package/dist/device/local/interfaces/index.js +0 -19
  147. package/dist/device/local/models/Alert.model.d.ts +0 -28
  148. package/dist/device/local/models/Alert.model.js +0 -222
  149. package/dist/device/local/models/Issue.model.d.ts +0 -28
  150. package/dist/device/local/models/Issue.model.js +0 -260
  151. package/dist/device/local/repository/Alert.repository.d.ts +0 -106
  152. package/dist/device/local/repository/Alert.repository.js +0 -374
  153. package/dist/device/local/repository/Connection.repository.d.ts +0 -8
  154. package/dist/device/local/repository/Connection.repository.js +0 -92
  155. package/dist/device/local/repository/Device.repository.d.ts +0 -30
  156. package/dist/device/local/repository/Device.repository.js +0 -325
  157. package/dist/device/local/repository/Hub.repository.d.ts +0 -13
  158. package/dist/device/local/repository/Hub.repository.js +0 -139
  159. package/dist/device/local/repository/Issue.repository.d.ts +0 -113
  160. package/dist/device/local/repository/Issue.repository.js +0 -401
  161. package/dist/device/local/repository/Property.repository.d.ts +0 -8
  162. package/dist/device/local/repository/Property.repository.js +0 -95
  163. package/dist/device/local/repository/Schedule.repository.d.ts +0 -9
  164. package/dist/device/local/repository/Schedule.repository.js +0 -109
  165. package/dist/device/local/services/Alert.service.d.ts +0 -137
  166. package/dist/device/local/services/Alert.service.js +0 -475
  167. package/dist/device/local/services/AlertService.example.d.ts +0 -55
  168. package/dist/device/local/services/AlertService.example.js +0 -148
  169. package/dist/device/local/services/Connection.service.d.ts +0 -8
  170. package/dist/device/local/services/Connection.service.js +0 -32
  171. package/dist/device/local/services/Device.service.d.ts +0 -40
  172. package/dist/device/local/services/Device.service.js +0 -391
  173. package/dist/device/local/services/DeviceHub.service.d.ts +0 -11
  174. package/dist/device/local/services/DeviceHub.service.js +0 -40
  175. package/dist/device/local/services/Hub.service.d.ts +0 -12
  176. package/dist/device/local/services/Hub.service.js +0 -107
  177. package/dist/device/local/services/Issue.service.d.ts +0 -168
  178. package/dist/device/local/services/Issue.service.js +0 -642
  179. package/dist/device/local/services/IssueService.example.d.ts +0 -68
  180. package/dist/device/local/services/IssueService.example.js +0 -177
  181. package/dist/device/local/services/Property.service.d.ts +0 -8
  182. package/dist/device/local/services/Property.service.js +0 -36
  183. package/dist/device/local/services/Schedule.service.d.ts +0 -9
  184. package/dist/device/local/services/Schedule.service.js +0 -26
  185. package/dist/device/local/services/index.d.ts +0 -3
  186. package/dist/device/local/services/index.js +0 -19
  187. package/dist/pms/IPms.d.ts +0 -6
  188. package/dist/pms/IPms.js +0 -10
  189. package/dist/pms/index.d.ts +0 -1
  190. package/dist/pms/index.js +0 -18
  191. package/dist/pms/webhookQueue/examples/index.d.ts +0 -2
  192. package/dist/pms/webhookQueue/examples/index.js +0 -18
  193. package/dist/pms/webhookQueue/examples/pms-integration.d.ts +0 -65
  194. package/dist/pms/webhookQueue/examples/pms-integration.js +0 -254
  195. package/dist/pms/webhookQueue/examples/usage.d.ts +0 -7
  196. package/dist/pms/webhookQueue/examples/usage.js +0 -175
  197. package/dist/pms/webhookQueue/index.d.ts +0 -3
  198. package/dist/pms/webhookQueue/index.js +0 -20
  199. package/dist/pms/webhookQueue/interfaces/IWebhookQueue.d.ts +0 -33
  200. package/dist/pms/webhookQueue/interfaces/IWebhookQueue.js +0 -2
  201. package/dist/pms/webhookQueue/interfaces/IWebhookWorker.d.ts +0 -38
  202. package/dist/pms/webhookQueue/interfaces/IWebhookWorker.js +0 -2
  203. package/dist/pms/webhookQueue/interfaces/index.d.ts +0 -1
  204. package/dist/pms/webhookQueue/interfaces/index.js +0 -17
  205. package/dist/pms/webhookQueue/services/WebhookQueueFactory.d.ts +0 -38
  206. package/dist/pms/webhookQueue/services/WebhookQueueFactory.js +0 -131
  207. package/dist/pms/webhookQueue/services/WebhookQueueIntegration.d.ts +0 -70
  208. package/dist/pms/webhookQueue/services/WebhookQueueIntegration.js +0 -207
  209. package/dist/pms/webhookQueue/services/WebhookQueueService.d.ts +0 -45
  210. package/dist/pms/webhookQueue/services/WebhookQueueService.js +0 -270
  211. package/dist/pms/webhookQueue/services/WebhookWorker.d.ts +0 -37
  212. package/dist/pms/webhookQueue/services/WebhookWorker.js +0 -201
  213. package/dist/pms/webhookQueue/services/index.d.ts +0 -1
  214. package/dist/pms/webhookQueue/services/index.js +0 -17
  215. package/dist/pms/webhookQueue/types/index.d.ts +0 -1
  216. package/dist/pms/webhookQueue/types/index.js +0 -17
  217. package/dist/pms/webhookQueue/types/webhook.types.d.ts +0 -39
  218. package/dist/pms/webhookQueue/types/webhook.types.js +0 -2
  219. package/dist/property/IProperty.d.ts +0 -29
  220. package/dist/property/IProperty.js +0 -2
  221. package/dist/property/Property.repository.d.ts +0 -8
  222. package/dist/property/Property.repository.js +0 -109
  223. package/dist/property/Property.service.d.ts +0 -8
  224. package/dist/property/Property.service.js +0 -124
  225. package/dist/property/index.d.ts +0 -2
  226. package/dist/property/index.js +0 -18
  227. package/dist/queue/interfaces/IHttpRequestJob.d.ts +0 -9
  228. package/dist/queue/interfaces/IHttpRequestJob.js +0 -2
  229. package/dist/types/alert.types.d.ts +0 -57
  230. package/dist/types/alert.types.js +0 -22
  231. package/dist/types/config.types.d.ts +0 -19
  232. package/dist/types/config.types.js +0 -2
  233. package/dist/types/index.d.ts +0 -3
  234. package/dist/types/index.js +0 -19
  235. package/dist/types/issue.types.d.ts +0 -90
  236. package/dist/types/issue.types.js +0 -40
  237. package/dist/utils/http-utils.d.ts +0 -13
  238. 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;
@@ -18,5 +18,4 @@ export declare const CONNECTION_PROVIDERS: {
18
18
  readonly DORMAKABA: "Dormakaba";
19
19
  readonly DUSAW: "Dusaw";
20
20
  readonly LOCKLY: "Lockly";
21
- readonly CHECKFRONT: "Checkfront";
22
21
  };
@@ -24,5 +24,4 @@ exports.CONNECTION_PROVIDERS = {
24
24
  DORMAKABA: "Dormakaba",
25
25
  DUSAW: "Dusaw",
26
26
  LOCKLY: "Lockly",
27
- CHECKFRONT: "Checkfront",
28
27
  };
@@ -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()
@@ -3,9 +3,8 @@ export declare class AdminRepository {
3
3
  private readonly deviceRepository;
4
4
  private readonly postgres;
5
5
  private readonly localDeviceService;
6
- private readonly redisUtils;
7
6
  constructor();
8
- getZonesByAccessGroupIds(accessGroupIds: string[], propertyId: string): Promise<any[]>;
7
+ getZonesByAccessGroupIds(accessGroupIds: string[]): Promise<any[]>;
9
8
  getZonesByAccessGroups(accessGroupIds: string[]): Promise<any[]>;
10
9
  getAccessGroup(accessGroupId: string, propertyId?: string): Promise<IAccessGroup | null>;
11
10
  getZoneAccessGroupByZoneId(zoneId: string): Promise<IZoneAccessGroup[] | null>;
@@ -78,7 +78,6 @@ const Device_repository_1 = require("../device/local/repository/Device.repositor
78
78
  const db_1 = require("../../db/db");
79
79
  const interfaces_1 = require("../device/cloud/interfaces");
80
80
  const services_1 = require("../device/local/services");
81
- const config_1 = require("../../config/config");
82
81
  let AdminRepository = (() => {
83
82
  let _classDecorators = [(0, typedi_1.Service)()];
84
83
  let _classDescriptor;
@@ -89,9 +88,25 @@ let AdminRepository = (() => {
89
88
  this.deviceRepository = typedi_1.default.get(Device_repository_1.DeviceRepository);
90
89
  this.postgres = (0, db_1.getPostgresClient)();
91
90
  this.localDeviceService = typedi_1.default.get(services_1.LocalDeviceService);
92
- this.redisUtils = typedi_1.default.get(utils_1.RedisUtils);
93
91
  }
94
- async getZonesByAccessGroupIds(accessGroupIds, propertyId) {
92
+ async getZonesByAccessGroupIds(accessGroupIds) {
93
+ // // Get propertyId from any of the accessGroupIds
94
+ // const accessGroupIdsResult = await this.postgres.query(
95
+ // `SELECT "propertyId" FROM dt_collections WHERE "id" = ANY($1) LIMIT 1`,
96
+ // [accessGroupIds]
97
+ // );
98
+ // const propertyId = accessGroupIdsResult.rows[0].propertyId;
99
+ // const sortedAccessGroupIds = [...accessGroupIds].sort((a, b) =>
100
+ // a.localeCompare(b)
101
+ // );
102
+ // // Check if the result is already cached
103
+ // const redisKey = `${propertyId}:zonesAndDevicesByAccessGroupIds:${sortedAccessGroupIds.join(
104
+ // ","
105
+ // )}`;
106
+ // const cachedResult = await this.redisUtils.get(redisKey);
107
+ // if (cachedResult) {
108
+ // return JSON.parse(cachedResult);
109
+ // }
95
110
  // If not cached, get the result from the database
96
111
  const result = await this.postgres.query(`SELECT
97
112
  "zc"."id" AS "zoneCollectionMapId",
@@ -125,18 +140,7 @@ let AdminRepository = (() => {
125
140
  const collectionZone = [];
126
141
  for (let zone of response) {
127
142
  let zoneIds = [];
128
- let zones = null;
129
- const redisKey = `${propertyId}:childZones:${zone.zoneId}`;
130
- const zonesCache = await this.redisUtils.get(redisKey);
131
- if (zonesCache !== null && zonesCache !== undefined) {
132
- (0, config_1.getLogger)().info(`Got child zones from redis`);
133
- zones = JSON.parse(zonesCache);
134
- }
135
- else {
136
- const response = await (0, utils_1.getAdminServiceAxiosInstance)().get(`/zones/child?zoneId=${zone.zoneId}`);
137
- zones = response?.data?.data;
138
- await this.redisUtils.set(redisKey, JSON.stringify(zones), 86400);
139
- }
143
+ const zones = (await (0, utils_1.getAdminServiceAxiosInstance)().get(`/zones/child?zoneId=${zone.zoneId}`))?.data?.data;
140
144
  zoneIds.push(zone.zoneId);
141
145
  if (zones.childZones?.length > 0) {
142
146
  const nestedZoneIds = new Set(_zones(zones.childZones));
@@ -3,7 +3,7 @@ export declare class AdminService {
3
3
  private readonly adminRepository;
4
4
  private readonly redisUtils;
5
5
  constructor();
6
- getZonesByAccessGroupIds(accessGroupIds: string[], propertyId: string): Promise<any[] | undefined>;
6
+ getZonesByAccessGroupIds(accessGroupIds: string[]): Promise<any[] | undefined>;
7
7
  getZonesByAccessGroups(accessGroupIds: string[]): Promise<any[] | undefined>;
8
8
  getAccessGroup(accessGroupId: string, propertyId?: string): Promise<IAccessGroup | null>;
9
9
  getAccessGroupByZoneId(zoneId: string): Promise<IAccessGroup[] | []>;
@@ -85,9 +85,9 @@ let AdminService = (() => {
85
85
  this.adminRepository = typedi_1.default.get(Admin_repository_1.AdminRepository);
86
86
  this.redisUtils = typedi_1.default.get(redis_utils_1.RedisUtils);
87
87
  }
88
- async getZonesByAccessGroupIds(accessGroupIds, propertyId) {
88
+ async getZonesByAccessGroupIds(accessGroupIds) {
89
89
  try {
90
- return await this.adminRepository.getZonesByAccessGroupIds(accessGroupIds, propertyId);
90
+ return await this.adminRepository.getZonesByAccessGroupIds(accessGroupIds);
91
91
  }
92
92
  catch (error) {
93
93
  console.log(error);
@@ -4,5 +4,6 @@ export declare class ConnectionRepository {
4
4
  constructor();
5
5
  createConnection(data: Partial<IConnection>): Promise<IConnection>;
6
6
  getConnectionById(connectionId: string): Promise<IConnection>;
7
+ queryConnections(query: Partial<IConnection>): Promise<IConnection[]>;
7
8
  updateConnection(connectionId: string, data: Partial<IConnection>): Promise<any>;
8
9
  }
@@ -69,6 +69,28 @@ let ConnectionRepository = (() => {
69
69
  const result = await this.pool.query("SELECT * FROM dt_connections WHERE id = $1", [connectionId]);
70
70
  return result.rows[0];
71
71
  }
72
+ async queryConnections(query) {
73
+ // Filter out undefined/null values and build WHERE clause
74
+ const conditions = [];
75
+ const values = [];
76
+ let paramIndex = 1;
77
+ // Build conditions dynamically based on provided query parameters
78
+ Object.keys(query).forEach((key) => {
79
+ const value = query[key];
80
+ if (value !== undefined && value !== null) {
81
+ conditions.push(`"${key}" = $${paramIndex}`);
82
+ values.push(value);
83
+ paramIndex++;
84
+ }
85
+ });
86
+ // Build the SQL query
87
+ let sql = "SELECT * FROM dt_connections";
88
+ if (conditions.length > 0) {
89
+ sql += ` WHERE ${conditions.join(" AND ")}`;
90
+ }
91
+ const result = await this.pool.query(sql, values);
92
+ return result.rows;
93
+ }
72
94
  async updateConnection(connectionId, data) {
73
95
  // Build dynamic SET clause with quoted column names
74
96
  const setClause = Object.keys(data)
@@ -4,5 +4,6 @@ export declare class LocalConnectionService {
4
4
  constructor();
5
5
  createConnection(data: Partial<IConnection>): Promise<IConnection>;
6
6
  getConnection(connectionId: string): Promise<IConnection>;
7
+ queryConnections(query: Partial<IConnection>): Promise<IConnection[]>;
7
8
  updateConnection(connectionId: string, data: Partial<IConnection>): Promise<IConnection>;
8
9
  }
@@ -22,6 +22,9 @@ class LocalConnectionService {
22
22
  }
23
23
  return await this.connectionRepository.getConnectionById(connectionId);
24
24
  }
25
+ async queryConnections(query) {
26
+ return await this.connectionRepository.queryConnections(query);
27
+ }
25
28
  async updateConnection(connectionId, data) {
26
29
  if (!connectionId) {
27
30
  throw new Error("Connection ID is required");
@@ -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");
@@ -239,7 +239,7 @@ let IssueService = (() => {
239
239
  title: device.deviceType.type.toLowerCase() === "hub"
240
240
  ? "Hub Offline"
241
241
  : "Device Offline",
242
- description: `${device.name} has gone offline. ${reason ? `Reason: ${reason}.` : ""}`,
242
+ description: `${device.name} has gone offline ${reason ? `Reason: ${reason}` : ""}.`,
243
243
  createdBy: source,
244
244
  category: issue_types_1.IssuesCategory.OPERATIONS,
245
245
  priority: issue_types_1.IssuePriority.CRITICAL,
@@ -123,12 +123,6 @@ class RateLimitUtils {
123
123
  provider: constants_1.CONNECTION_PROVIDERS.WEBREZPRO,
124
124
  maxTimeoutWindowMs: 120000,
125
125
  });
126
- configs.set(constants_1.CONNECTION_PROVIDERS.CHECKFRONT, {
127
- maxRequests: 10,
128
- windowMs: 60000,
129
- provider: constants_1.CONNECTION_PROVIDERS.CHECKFRONT,
130
- maxTimeoutWindowMs: 120000,
131
- });
132
126
  return configs;
133
127
  }
134
128
  static async isRateLimitAllowed(connectionId, provider, rateLimitConfigs) {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "dt-common-device",
3
- "version": "11.2.1",
3
+ "version": "12.0.1",
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;