dt-common-device 11.1.7 → 11.1.9

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 (237) 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 +2 -0
  5. package/dist/constants/ConnectionProviders.js +2 -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/admin/Admin.repository.d.ts +1 -1
  11. package/dist/entities/admin/Admin.repository.js +9 -2
  12. package/dist/entities/admin/Admin.service.d.ts +1 -1
  13. package/dist/entities/admin/Admin.service.js +3 -3
  14. package/dist/entities/guest/Guest.repository.d.ts +1 -1
  15. package/dist/entities/guest/Guest.repository.js +5 -2
  16. package/dist/entities/guest/Guest.service.d.ts +1 -1
  17. package/dist/entities/guest/Guest.service.js +4 -1
  18. package/dist/entities/pms/IPms.d.ts +3 -1
  19. package/dist/entities/pms/IPms.js +2 -0
  20. package/dist/entities/schedules/Schedule.repository.d.ts +1 -1
  21. package/dist/entities/schedules/Schedule.repository.js +5 -2
  22. package/dist/entities/schedules/Schedule.service.d.ts +1 -1
  23. package/dist/entities/schedules/Schedule.service.js +4 -1
  24. package/dist/entities/user/User.repository.js +4 -1
  25. package/dist/entities/user/User.service.d.ts +1 -1
  26. package/dist/entities/user/User.service.js +4 -1
  27. package/dist/entities/zone/Zone.service.js +4 -1
  28. package/dist/issues/issue.types.d.ts +2 -0
  29. package/dist/issues/issue.types.js +2 -0
  30. package/dist/queue/utils/rateLimit.utils.js +12 -0
  31. package/package.json +1 -1
  32. package/dist/admin/Admin.repository.d.ts +0 -7
  33. package/dist/admin/Admin.repository.js +0 -182
  34. package/dist/admin/Admin.service.d.ts +0 -5
  35. package/dist/admin/Admin.service.js +0 -17
  36. package/dist/admin/index.d.ts +0 -1
  37. package/dist/admin/index.js +0 -17
  38. package/dist/audit/AuditProperties.d.ts +0 -16
  39. package/dist/audit/AuditProperties.js +0 -2
  40. package/dist/chronicle/IChronicle.interface.d.ts +0 -14
  41. package/dist/chronicle/IChronicle.interface.js +0 -2
  42. package/dist/chronicle/chronicle.service.d.ts +0 -4
  43. package/dist/chronicle/chronicle.service.js +0 -44
  44. package/dist/connection/Connection.repository.d.ts +0 -8
  45. package/dist/connection/Connection.repository.js +0 -92
  46. package/dist/connection/Connection.service.d.ts +0 -8
  47. package/dist/connection/Connection.service.js +0 -32
  48. package/dist/connection/IConnection.d.ts +0 -28
  49. package/dist/connection/IConnection.js +0 -16
  50. package/dist/connection/index.d.ts +0 -2
  51. package/dist/connection/index.js +0 -18
  52. package/dist/copilotQueue/examples/CopilotQueue.example.d.ts +0 -37
  53. package/dist/copilotQueue/examples/CopilotQueue.example.js +0 -140
  54. package/dist/copilotQueue/examples/index.d.ts +0 -1
  55. package/dist/copilotQueue/examples/index.js +0 -17
  56. package/dist/device/cloud/entities/CloudConnection.d.ts +0 -6
  57. package/dist/device/cloud/entities/CloudConnection.js +0 -6
  58. package/dist/device/cloud/entities/CloudDevice.d.ts +0 -16
  59. package/dist/device/cloud/entities/CloudDevice.js +0 -26
  60. package/dist/device/cloud/entities/CloudDeviceService.d.ts +0 -5
  61. package/dist/device/cloud/entities/CloudDeviceService.js +0 -9
  62. package/dist/device/cloud/entities/DeviceFactory.d.ts +0 -7
  63. package/dist/device/cloud/entities/DeviceFactory.js +0 -80
  64. package/dist/device/cloud/entities/index.d.ts +0 -3
  65. package/dist/device/cloud/entities/index.js +0 -19
  66. package/dist/device/cloud/interface.d.ts +0 -101
  67. package/dist/device/cloud/interface.js +0 -3
  68. package/dist/device/cloud/interfaces/ICloudConnection.d.ts +0 -5
  69. package/dist/device/cloud/interfaces/ICloudConnection.js +0 -2
  70. package/dist/device/cloud/interfaces/ICloudDevice.d.ts +0 -9
  71. package/dist/device/cloud/interfaces/ICloudDevice.js +0 -2
  72. package/dist/device/cloud/interfaces/ICloudDeviceService.d.ts +0 -4
  73. package/dist/device/cloud/interfaces/ICloudDeviceService.js +0 -2
  74. package/dist/device/cloud/interfaces/IConnectionService.d.ts +0 -7
  75. package/dist/device/cloud/interfaces/IConnectionService.js +0 -2
  76. package/dist/device/cloud/interfaces/IDeviceConnectionService.d.ts +0 -7
  77. package/dist/device/cloud/interfaces/IDeviceConnectionService.js +0 -3
  78. package/dist/device/cloud/interfaces/IDeviceFactory.d.ts +0 -4
  79. package/dist/device/cloud/interfaces/IDeviceFactory.js +0 -2
  80. package/dist/device/cloud/interfaces/IDeviceService.d.ts +0 -8
  81. package/dist/device/cloud/interfaces/IDeviceService.js +0 -2
  82. package/dist/device/cloud/interfaces/IDevicesService.d.ts +0 -9
  83. package/dist/device/cloud/interfaces/IDevicesService.js +0 -2
  84. package/dist/device/cloud/interfaces/IHubService.d.ts +0 -5
  85. package/dist/device/cloud/interfaces/IHubService.js +0 -2
  86. package/dist/device/cloud/interfaces/IRawDataTransformer.d.ts +0 -4
  87. package/dist/device/cloud/interfaces/IRawDataTransformer.js +0 -2
  88. package/dist/device/cloud/interfaces/IRawDevice.d.ts +0 -17
  89. package/dist/device/cloud/interfaces/IRawDevice.js +0 -11
  90. package/dist/device/cloud/interfaces/index.d.ts +0 -5
  91. package/dist/device/cloud/interfaces/index.js +0 -21
  92. package/dist/device/cloud/services/CloudDevice.service.d.ts +0 -5
  93. package/dist/device/cloud/services/CloudDevice.service.js +0 -9
  94. package/dist/device/cloud/services/Connection.service.d.ts +0 -8
  95. package/dist/device/cloud/services/Connection.service.js +0 -6
  96. package/dist/device/cloud/services/Device.service.d.ts +0 -39
  97. package/dist/device/cloud/services/Device.service.js +0 -9
  98. package/dist/device/cloud/services/DeviceCloudService.d.ts +0 -42
  99. package/dist/device/cloud/services/DeviceCloudService.js +0 -59
  100. package/dist/device/cloud/services/DeviceHub.service.d.ts +0 -3
  101. package/dist/device/cloud/services/DeviceHub.service.js +0 -6
  102. package/dist/device/cloud/services/Hub.service.d.ts +0 -25
  103. package/dist/device/cloud/services/Hub.service.js +0 -9
  104. package/dist/device/cloud/services/SmartThingsDeviceService.d.ts +0 -38
  105. package/dist/device/cloud/services/SmartThingsDeviceService.js +0 -52
  106. package/dist/device/cloud/services/index.d.ts +0 -2
  107. package/dist/device/cloud/services/index.js +0 -18
  108. package/dist/device/cloud/types.d.ts +0 -52
  109. package/dist/device/cloud/types.js +0 -15
  110. package/dist/device/index.d.ts +0 -4
  111. package/dist/device/index.js +0 -20
  112. package/dist/device/local/entities/AlertBuilder.d.ts +0 -87
  113. package/dist/device/local/entities/AlertBuilder.example.d.ts +0 -11
  114. package/dist/device/local/entities/AlertBuilder.example.js +0 -117
  115. package/dist/device/local/entities/AlertBuilder.js +0 -179
  116. package/dist/device/local/entities/IssueBuilder.d.ts +0 -109
  117. package/dist/device/local/entities/IssueBuilder.example.d.ts +0 -16
  118. package/dist/device/local/entities/IssueBuilder.example.js +0 -196
  119. package/dist/device/local/entities/IssueBuilder.js +0 -237
  120. package/dist/device/local/entities/index.d.ts +0 -2
  121. package/dist/device/local/entities/index.js +0 -7
  122. package/dist/device/local/events/EventHandler.d.ts +0 -11
  123. package/dist/device/local/events/EventHandler.js +0 -86
  124. package/dist/device/local/events/Events.d.ts +0 -54
  125. package/dist/device/local/events/Events.js +0 -57
  126. package/dist/device/local/events/index.d.ts +0 -2
  127. package/dist/device/local/events/index.js +0 -7
  128. package/dist/device/local/handler/EventHandler.d.ts +0 -7
  129. package/dist/device/local/handler/EventHandler.js +0 -44
  130. package/dist/device/local/interface.d.ts +0 -0
  131. package/dist/device/local/interface.js +0 -1
  132. package/dist/device/local/interfaces/IConnection.d.ts +0 -26
  133. package/dist/device/local/interfaces/IConnection.js +0 -14
  134. package/dist/device/local/interfaces/IDevice.d.ts +0 -68
  135. package/dist/device/local/interfaces/IDevice.js +0 -10
  136. package/dist/device/local/interfaces/IDtDevice.d.ts +0 -16
  137. package/dist/device/local/interfaces/IDtDevice.js +0 -2
  138. package/dist/device/local/interfaces/IHub.d.ts +0 -46
  139. package/dist/device/local/interfaces/IHub.js +0 -2
  140. package/dist/device/local/interfaces/IProperty.d.ts +0 -29
  141. package/dist/device/local/interfaces/IProperty.js +0 -2
  142. package/dist/device/local/interfaces/ISchedule.d.ts +0 -25
  143. package/dist/device/local/interfaces/ISchedule.js +0 -2
  144. package/dist/device/local/interfaces/index.d.ts +0 -3
  145. package/dist/device/local/interfaces/index.js +0 -19
  146. package/dist/device/local/models/Alert.model.d.ts +0 -28
  147. package/dist/device/local/models/Alert.model.js +0 -222
  148. package/dist/device/local/models/Issue.model.d.ts +0 -28
  149. package/dist/device/local/models/Issue.model.js +0 -260
  150. package/dist/device/local/repository/Alert.repository.d.ts +0 -106
  151. package/dist/device/local/repository/Alert.repository.js +0 -374
  152. package/dist/device/local/repository/Connection.repository.d.ts +0 -8
  153. package/dist/device/local/repository/Connection.repository.js +0 -92
  154. package/dist/device/local/repository/Device.repository.d.ts +0 -30
  155. package/dist/device/local/repository/Device.repository.js +0 -325
  156. package/dist/device/local/repository/Hub.repository.d.ts +0 -13
  157. package/dist/device/local/repository/Hub.repository.js +0 -139
  158. package/dist/device/local/repository/Issue.repository.d.ts +0 -113
  159. package/dist/device/local/repository/Issue.repository.js +0 -401
  160. package/dist/device/local/repository/Property.repository.d.ts +0 -8
  161. package/dist/device/local/repository/Property.repository.js +0 -95
  162. package/dist/device/local/repository/Schedule.repository.d.ts +0 -9
  163. package/dist/device/local/repository/Schedule.repository.js +0 -109
  164. package/dist/device/local/services/Alert.service.d.ts +0 -137
  165. package/dist/device/local/services/Alert.service.js +0 -475
  166. package/dist/device/local/services/AlertService.example.d.ts +0 -55
  167. package/dist/device/local/services/AlertService.example.js +0 -148
  168. package/dist/device/local/services/Connection.service.d.ts +0 -8
  169. package/dist/device/local/services/Connection.service.js +0 -32
  170. package/dist/device/local/services/Device.service.d.ts +0 -40
  171. package/dist/device/local/services/Device.service.js +0 -391
  172. package/dist/device/local/services/DeviceHub.service.d.ts +0 -11
  173. package/dist/device/local/services/DeviceHub.service.js +0 -40
  174. package/dist/device/local/services/Hub.service.d.ts +0 -12
  175. package/dist/device/local/services/Hub.service.js +0 -107
  176. package/dist/device/local/services/Issue.service.d.ts +0 -168
  177. package/dist/device/local/services/Issue.service.js +0 -642
  178. package/dist/device/local/services/IssueService.example.d.ts +0 -68
  179. package/dist/device/local/services/IssueService.example.js +0 -177
  180. package/dist/device/local/services/Property.service.d.ts +0 -8
  181. package/dist/device/local/services/Property.service.js +0 -36
  182. package/dist/device/local/services/Schedule.service.d.ts +0 -9
  183. package/dist/device/local/services/Schedule.service.js +0 -26
  184. package/dist/device/local/services/index.d.ts +0 -3
  185. package/dist/device/local/services/index.js +0 -19
  186. package/dist/pms/IPms.d.ts +0 -6
  187. package/dist/pms/IPms.js +0 -10
  188. package/dist/pms/index.d.ts +0 -1
  189. package/dist/pms/index.js +0 -18
  190. package/dist/pms/webhookQueue/examples/index.d.ts +0 -2
  191. package/dist/pms/webhookQueue/examples/index.js +0 -18
  192. package/dist/pms/webhookQueue/examples/pms-integration.d.ts +0 -65
  193. package/dist/pms/webhookQueue/examples/pms-integration.js +0 -254
  194. package/dist/pms/webhookQueue/examples/usage.d.ts +0 -7
  195. package/dist/pms/webhookQueue/examples/usage.js +0 -175
  196. package/dist/pms/webhookQueue/index.d.ts +0 -3
  197. package/dist/pms/webhookQueue/index.js +0 -20
  198. package/dist/pms/webhookQueue/interfaces/IWebhookQueue.d.ts +0 -33
  199. package/dist/pms/webhookQueue/interfaces/IWebhookQueue.js +0 -2
  200. package/dist/pms/webhookQueue/interfaces/IWebhookWorker.d.ts +0 -38
  201. package/dist/pms/webhookQueue/interfaces/IWebhookWorker.js +0 -2
  202. package/dist/pms/webhookQueue/interfaces/index.d.ts +0 -1
  203. package/dist/pms/webhookQueue/interfaces/index.js +0 -17
  204. package/dist/pms/webhookQueue/services/WebhookQueueFactory.d.ts +0 -38
  205. package/dist/pms/webhookQueue/services/WebhookQueueFactory.js +0 -131
  206. package/dist/pms/webhookQueue/services/WebhookQueueIntegration.d.ts +0 -70
  207. package/dist/pms/webhookQueue/services/WebhookQueueIntegration.js +0 -207
  208. package/dist/pms/webhookQueue/services/WebhookQueueService.d.ts +0 -45
  209. package/dist/pms/webhookQueue/services/WebhookQueueService.js +0 -270
  210. package/dist/pms/webhookQueue/services/WebhookWorker.d.ts +0 -37
  211. package/dist/pms/webhookQueue/services/WebhookWorker.js +0 -201
  212. package/dist/pms/webhookQueue/services/index.d.ts +0 -1
  213. package/dist/pms/webhookQueue/services/index.js +0 -17
  214. package/dist/pms/webhookQueue/types/index.d.ts +0 -1
  215. package/dist/pms/webhookQueue/types/index.js +0 -17
  216. package/dist/pms/webhookQueue/types/webhook.types.d.ts +0 -39
  217. package/dist/pms/webhookQueue/types/webhook.types.js +0 -2
  218. package/dist/property/IProperty.d.ts +0 -29
  219. package/dist/property/IProperty.js +0 -2
  220. package/dist/property/Property.repository.d.ts +0 -8
  221. package/dist/property/Property.repository.js +0 -109
  222. package/dist/property/Property.service.d.ts +0 -8
  223. package/dist/property/Property.service.js +0 -124
  224. package/dist/property/index.d.ts +0 -2
  225. package/dist/property/index.js +0 -18
  226. package/dist/queue/interfaces/IHttpRequestJob.d.ts +0 -9
  227. package/dist/queue/interfaces/IHttpRequestJob.js +0 -2
  228. package/dist/types/alert.types.d.ts +0 -57
  229. package/dist/types/alert.types.js +0 -22
  230. package/dist/types/config.types.d.ts +0 -19
  231. package/dist/types/config.types.js +0 -2
  232. package/dist/types/index.d.ts +0 -3
  233. package/dist/types/index.js +0 -19
  234. package/dist/types/issue.types.d.ts +0 -90
  235. package/dist/types/issue.types.js +0 -40
  236. package/dist/utils/http-utils.d.ts +0 -13
  237. 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;
@@ -4,6 +4,8 @@ export declare const CONNECTION_PROVIDERS: {
4
4
  readonly STAYNTOUCH: "Stayntouch";
5
5
  readonly HOTELKEY: "Hotelkey";
6
6
  readonly YANOLJA: "Yanolja";
7
+ readonly SMOOBU: "Smoobu";
8
+ readonly WEBREZPRO: "Webrezpro";
7
9
  readonly SENSIBO: "Sensibo";
8
10
  readonly VERDANT: "Verdant";
9
11
  readonly SALTOKS: "SaltoKS";
@@ -8,6 +8,8 @@ exports.CONNECTION_PROVIDERS = {
8
8
  STAYNTOUCH: "Stayntouch",
9
9
  HOTELKEY: "Hotelkey",
10
10
  YANOLJA: "Yanolja",
11
+ SMOOBU: "Smoobu",
12
+ WEBREZPRO: "Webrezpro",
11
13
  // THERMOSTATS
12
14
  SENSIBO: "Sensibo",
13
15
  VERDANT: "Verdant",
@@ -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()
@@ -8,7 +8,7 @@ export declare class AdminRepository {
8
8
  getZonesByAccessGroups(accessGroupIds: string[]): Promise<any[]>;
9
9
  getAccessGroup(accessGroupId: string): Promise<IAccessGroup | null>;
10
10
  getZoneAccessGroupByZoneId(zoneId: string): Promise<IZoneAccessGroup[] | null>;
11
- getZone(zoneId: string): Promise<IZone | null>;
11
+ getZone(zoneId: string, propertyId?: string): Promise<IZone | null>;
12
12
  getUser(userId: string): Promise<IUser | null>;
13
13
  getZoneByDeviceId(deviceId: string): Promise<IZone | null>;
14
14
  getAccessGroups(propertyId: string, accessibleBy?: string): Promise<IAccessGroup[]>;
@@ -267,9 +267,16 @@ let AdminRepository = (() => {
267
267
  }
268
268
  return null;
269
269
  }
270
- async getZone(zoneId) {
270
+ async getZone(zoneId, propertyId) {
271
271
  try {
272
- const zone = await this.postgres.query(`SELECT * FROM dt_zones WHERE "id" = $1`, [zoneId]);
272
+ let query;
273
+ if (propertyId) {
274
+ query = `SELECT * FROM dt_zones WHERE "id" = $1 AND "propertyId" = $2`;
275
+ }
276
+ else {
277
+ query = `SELECT * FROM dt_zones WHERE "id" = $1`;
278
+ }
279
+ const zone = await this.postgres.query(query, [zoneId]);
273
280
  if (zone.rows.length > 0) {
274
281
  const zoneData = zone.rows[0];
275
282
  const zoneType = await this.postgres.query(`SELECT * FROM "dt_zoneTypes" WHERE "id" = $1`, [zoneData.zoneTypeId]);
@@ -7,7 +7,7 @@ export declare class AdminService {
7
7
  getZonesByAccessGroups(accessGroupIds: string[]): Promise<any[] | undefined>;
8
8
  getAccessGroup(accessGroupId: string): Promise<IAccessGroup | null>;
9
9
  getAccessGroupByZoneId(zoneId: string): Promise<IAccessGroup[] | []>;
10
- getZone(zoneId: string): Promise<IZone | null>;
10
+ getZone(zoneId: string, propertyId?: string): Promise<IZone | null>;
11
11
  getUser(userId: string): Promise<IUser | null>;
12
12
  getZoneByDeviceId(deviceId: string): Promise<IZone | null>;
13
13
  getAccessGroups(propertyId: string, accessibleBy?: string): Promise<IAccessGroup[]>;
@@ -125,17 +125,17 @@ let AdminService = (() => {
125
125
  }
126
126
  return accessGroups;
127
127
  }
128
- async getZone(zoneId) {
128
+ async getZone(zoneId, propertyId) {
129
129
  if (!zoneId) {
130
130
  throw new Error("Zone ID is required");
131
131
  }
132
132
  const cachedZone = await this.redisUtils.get(`zone:${zoneId}`);
133
133
  if (cachedZone)
134
134
  return JSON.parse(cachedZone);
135
- // Do Not Cache Zone if not found in Redis Here! Its being cached in Smart-Cloud
136
- const zone = await this.adminRepository.getZone(zoneId);
135
+ const zone = await this.adminRepository.getZone(zoneId, propertyId);
137
136
  if (!zone)
138
137
  return null;
138
+ await this.redisUtils.set(`zone:${zoneId}`, JSON.stringify(zone), 86400);
139
139
  return zone;
140
140
  }
141
141
  async getUser(userId) {
@@ -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,7 +2,9 @@ export declare enum PmsProvider {
2
2
  Cloudbeds = "Cloudbeds",
3
3
  StayNTouch = "StayNTouch",
4
4
  HotelKey = "HotelKey",
5
- Yanolja = "Yanolja"
5
+ Yanolja = "Yanolja",
6
+ SMOOBU = "Smoobu",
7
+ WEBREZPRO = "Webrezpro"
6
8
  }
7
9
  export interface IPmsSchedule {
8
10
  id: string;
@@ -7,4 +7,6 @@ var PmsProvider;
7
7
  PmsProvider["StayNTouch"] = "StayNTouch";
8
8
  PmsProvider["HotelKey"] = "HotelKey";
9
9
  PmsProvider["Yanolja"] = "Yanolja";
10
+ PmsProvider["SMOOBU"] = "Smoobu";
11
+ PmsProvider["WEBREZPRO"] = "Webrezpro";
10
12
  })(PmsProvider || (exports.PmsProvider = PmsProvider = {}));
@@ -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");
@@ -33,6 +33,8 @@ export declare enum EntitySubType {
33
33
  HOTELKEY = "HOTELKEY",
34
34
  YANOLJA = "YANOLJA",
35
35
  SKYTOUCH = "SKYTOUCH",
36
+ SMOOBU = "SMOOBU",
37
+ WEBREZPRO = "WEBREZPRO",
36
38
  SMARTTHINGS = "SMARTTHINGS",
37
39
  TTLOCK = "TTLOCK",
38
40
  TUYA = "TUYA",
@@ -42,6 +42,8 @@ var EntitySubType;
42
42
  EntitySubType["HOTELKEY"] = "HOTELKEY";
43
43
  EntitySubType["YANOLJA"] = "YANOLJA";
44
44
  EntitySubType["SKYTOUCH"] = "SKYTOUCH";
45
+ EntitySubType["SMOOBU"] = "SMOOBU";
46
+ EntitySubType["WEBREZPRO"] = "WEBREZPRO";
45
47
  // DEVICE PROVIDERS
46
48
  EntitySubType["SMARTTHINGS"] = "SMARTTHINGS";
47
49
  EntitySubType["TTLOCK"] = "TTLOCK";
@@ -111,6 +111,18 @@ class RateLimitUtils {
111
111
  provider: constants_1.CONNECTION_PROVIDERS.VERDANT,
112
112
  maxTimeoutWindowMs: 120000,
113
113
  });
114
+ configs.set(constants_1.CONNECTION_PROVIDERS.SMOOBU, {
115
+ maxRequests: 1000,
116
+ windowMs: 60000,
117
+ provider: constants_1.CONNECTION_PROVIDERS.SMOOBU,
118
+ maxTimeoutWindowMs: 120000,
119
+ });
120
+ configs.set(constants_1.CONNECTION_PROVIDERS.WEBREZPRO, {
121
+ maxRequests: 10,
122
+ windowMs: 60000,
123
+ provider: constants_1.CONNECTION_PROVIDERS.WEBREZPRO,
124
+ maxTimeoutWindowMs: 120000,
125
+ });
114
126
  return configs;
115
127
  }
116
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.1.7",
3
+ "version": "11.1.9",
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);