dt-common-device 4.0.8 → 5.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (232) hide show
  1. package/dist/alerts/Alert.service.d.ts +1 -1
  2. package/dist/audit/AuditUtils.d.ts +26 -2
  3. package/dist/audit/AuditUtils.js +255 -32
  4. package/dist/audit/IAuditProperties.d.ts +32 -0
  5. package/dist/audit/IAuditProperties.js +13 -0
  6. package/dist/audit/PushAudit.d.ts +5 -0
  7. package/dist/audit/PushAudit.js +16 -0
  8. package/dist/audit/index.d.ts +2 -0
  9. package/dist/audit/index.js +18 -0
  10. package/dist/config/config.d.ts +10 -3
  11. package/dist/config/config.js +120 -47
  12. package/dist/config/config.types.d.ts +1 -8
  13. package/dist/config/constants.d.ts +49 -0
  14. package/dist/config/constants.js +64 -0
  15. package/dist/db/db.d.ts +2 -0
  16. package/dist/db/db.js +23 -1
  17. package/dist/entities/accessGroup/AccessGroup.repository.d.ts +5 -0
  18. package/dist/{device/local/repository/Connection.repository.js → entities/accessGroup/AccessGroup.repository.js} +15 -35
  19. package/dist/entities/accessGroup/AccessGroup.service.d.ts +5 -0
  20. package/dist/entities/accessGroup/AccessGroup.service.js +105 -0
  21. package/dist/entities/accessGroup/IAccessGroup.d.ts +14 -0
  22. package/dist/entities/accessGroup/index.d.ts +2 -0
  23. package/dist/entities/accessGroup/index.js +18 -0
  24. package/dist/{admin → entities/admin}/Admin.repository.js +4 -4
  25. package/dist/{connection → entities/connection}/Connection.repository.js +1 -1
  26. package/dist/{device → entities/device}/local/repository/Device.repository.js +3 -3
  27. package/dist/{device → entities/device}/local/repository/Hub.repository.js +3 -3
  28. package/dist/{device → entities/device}/local/repository/Schedule.repository.js +2 -2
  29. package/dist/{device → entities/device}/local/services/Device.service.d.ts +9 -9
  30. package/dist/{device → entities/device}/local/services/Device.service.js +4 -4
  31. package/dist/entities/guest/Guest.repository.d.ts +6 -0
  32. package/dist/entities/guest/Guest.repository.js +74 -0
  33. package/dist/entities/guest/Guest.service.d.ts +6 -0
  34. package/dist/entities/guest/Guest.service.js +104 -0
  35. package/dist/entities/guest/IGuest.d.ts +12 -0
  36. package/dist/entities/guest/index.d.ts +2 -0
  37. package/dist/entities/guest/index.js +18 -0
  38. package/dist/{property → entities/property}/Property.repository.js +1 -1
  39. package/dist/entities/schedules/ISchedule.d.ts +14 -0
  40. package/dist/entities/schedules/Schedule.repository.d.ts +6 -0
  41. package/dist/entities/schedules/Schedule.repository.js +74 -0
  42. package/dist/entities/schedules/Schedule.service.d.ts +6 -0
  43. package/dist/entities/schedules/Schedule.service.js +104 -0
  44. package/dist/entities/schedules/index.d.ts +2 -0
  45. package/dist/entities/schedules/index.js +18 -0
  46. package/dist/entities/user/IUser.d.ts +15 -0
  47. package/dist/entities/user/User.repository.d.ts +5 -0
  48. package/dist/entities/user/User.repository.js +68 -0
  49. package/dist/entities/user/User.service.d.ts +6 -0
  50. package/dist/entities/user/User.service.js +103 -0
  51. package/dist/entities/zone/IZone.d.ts +10 -0
  52. package/dist/entities/zone/Zone.repository.d.ts +6 -0
  53. package/dist/{device/local/repository/Property.repository.js → entities/zone/Zone.repository.js} +14 -32
  54. package/dist/entities/zone/Zone.service.d.ts +6 -0
  55. package/dist/entities/zone/Zone.service.js +104 -0
  56. package/dist/entities/zone/index.d.ts +2 -0
  57. package/dist/entities/zone/index.js +18 -0
  58. package/dist/events/BaseEventHandler.d.ts +3 -3
  59. package/dist/events/BaseEventHandler.js +1 -1
  60. package/dist/events/DeviceEventHandler.d.ts +1 -1
  61. package/dist/events/DeviceEventHandler.js +4 -3
  62. package/dist/events/EventHandler.d.ts +10 -9
  63. package/dist/events/EventHandler.js +50 -9
  64. package/dist/events/InternalEventSubscription.js +1 -1
  65. package/dist/index.d.ts +9 -8
  66. package/dist/index.js +10 -8
  67. package/dist/issues/Issue.service.d.ts +1 -1
  68. package/dist/microservice/MicroServiceFactory.d.ts +1 -1
  69. package/dist/microservice/MicroServiceFactory.js +1 -1
  70. package/dist/utils/http.utils.d.ts +1 -2
  71. package/dist/utils/http.utils.js +5 -28
  72. package/package.json +1 -1
  73. package/dist/audit/AuditProperties.d.ts +0 -16
  74. package/dist/device/cloud/entities/CloudConnection.d.ts +0 -6
  75. package/dist/device/cloud/entities/CloudConnection.js +0 -6
  76. package/dist/device/cloud/interface.d.ts +0 -101
  77. package/dist/device/cloud/interface.js +0 -3
  78. package/dist/device/cloud/interfaces/ICloudConnection.d.ts +0 -5
  79. package/dist/device/cloud/interfaces/IConnectionService.d.ts +0 -7
  80. package/dist/device/cloud/interfaces/IDeviceConnectionService.d.ts +0 -7
  81. package/dist/device/cloud/interfaces/IDeviceConnectionService.js +0 -3
  82. package/dist/device/cloud/interfaces/IDeviceService.d.ts +0 -8
  83. package/dist/device/cloud/interfaces/IDevicesService.d.ts +0 -9
  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/services/CloudDevice.service.d.ts +0 -5
  87. package/dist/device/cloud/services/CloudDevice.service.js +0 -9
  88. package/dist/device/cloud/services/Connection.service.d.ts +0 -8
  89. package/dist/device/cloud/services/Connection.service.js +0 -6
  90. package/dist/device/cloud/services/Device.service.d.ts +0 -39
  91. package/dist/device/cloud/services/Device.service.js +0 -9
  92. package/dist/device/cloud/services/DeviceCloudService.d.ts +0 -42
  93. package/dist/device/cloud/services/DeviceCloudService.js +0 -59
  94. package/dist/device/cloud/services/DeviceHub.service.d.ts +0 -3
  95. package/dist/device/cloud/services/DeviceHub.service.js +0 -6
  96. package/dist/device/cloud/services/Hub.service.d.ts +0 -25
  97. package/dist/device/cloud/services/Hub.service.js +0 -9
  98. package/dist/device/cloud/services/SmartThingsDeviceService.d.ts +0 -38
  99. package/dist/device/cloud/services/SmartThingsDeviceService.js +0 -52
  100. package/dist/device/cloud/services/index.d.ts +0 -2
  101. package/dist/device/cloud/services/index.js +0 -18
  102. package/dist/device/cloud/types.d.ts +0 -52
  103. package/dist/device/cloud/types.js +0 -15
  104. package/dist/device/index.d.ts +0 -4
  105. package/dist/device/index.js +0 -20
  106. package/dist/device/local/entities/AlertBuilder.d.ts +0 -87
  107. package/dist/device/local/entities/AlertBuilder.example.d.ts +0 -11
  108. package/dist/device/local/entities/AlertBuilder.example.js +0 -117
  109. package/dist/device/local/entities/AlertBuilder.js +0 -179
  110. package/dist/device/local/entities/IssueBuilder.d.ts +0 -109
  111. package/dist/device/local/entities/IssueBuilder.example.d.ts +0 -16
  112. package/dist/device/local/entities/IssueBuilder.example.js +0 -196
  113. package/dist/device/local/entities/IssueBuilder.js +0 -237
  114. package/dist/device/local/entities/index.d.ts +0 -2
  115. package/dist/device/local/entities/index.js +0 -7
  116. package/dist/device/local/events/EventHandler.d.ts +0 -11
  117. package/dist/device/local/events/EventHandler.js +0 -86
  118. package/dist/device/local/events/Events.d.ts +0 -54
  119. package/dist/device/local/events/Events.js +0 -57
  120. package/dist/device/local/events/index.d.ts +0 -2
  121. package/dist/device/local/events/index.js +0 -7
  122. package/dist/device/local/handler/EventHandler.d.ts +0 -7
  123. package/dist/device/local/handler/EventHandler.js +0 -44
  124. package/dist/device/local/interface.d.ts +0 -0
  125. package/dist/device/local/interface.js +0 -1
  126. package/dist/device/local/interfaces/IConnection.d.ts +0 -26
  127. package/dist/device/local/interfaces/IConnection.js +0 -14
  128. package/dist/device/local/interfaces/IHub.d.ts +0 -46
  129. package/dist/device/local/interfaces/IHub.js +0 -2
  130. package/dist/device/local/models/Alert.model.d.ts +0 -28
  131. package/dist/device/local/models/Alert.model.js +0 -222
  132. package/dist/device/local/models/Issue.model.d.ts +0 -28
  133. package/dist/device/local/models/Issue.model.js +0 -260
  134. package/dist/device/local/repository/Alert.repository.d.ts +0 -106
  135. package/dist/device/local/repository/Alert.repository.js +0 -374
  136. package/dist/device/local/repository/Connection.repository.d.ts +0 -8
  137. package/dist/device/local/repository/Issue.repository.d.ts +0 -113
  138. package/dist/device/local/repository/Issue.repository.js +0 -401
  139. package/dist/device/local/repository/Property.repository.d.ts +0 -8
  140. package/dist/device/local/services/Alert.service.d.ts +0 -137
  141. package/dist/device/local/services/Alert.service.js +0 -475
  142. package/dist/device/local/services/AlertService.example.d.ts +0 -55
  143. package/dist/device/local/services/AlertService.example.js +0 -148
  144. package/dist/device/local/services/Connection.service.d.ts +0 -8
  145. package/dist/device/local/services/Connection.service.js +0 -32
  146. package/dist/device/local/services/DeviceHub.service.d.ts +0 -11
  147. package/dist/device/local/services/DeviceHub.service.js +0 -40
  148. package/dist/device/local/services/Issue.service.d.ts +0 -168
  149. package/dist/device/local/services/Issue.service.js +0 -642
  150. package/dist/device/local/services/IssueService.example.d.ts +0 -68
  151. package/dist/device/local/services/IssueService.example.js +0 -177
  152. package/dist/device/local/services/Property.service.d.ts +0 -8
  153. package/dist/device/local/services/Property.service.js +0 -36
  154. package/dist/property/IProperty.d.ts +0 -29
  155. package/dist/property/IProperty.js +0 -2
  156. package/dist/queue/interfaces/IHttpRequestJob.d.ts +0 -9
  157. package/dist/queue/interfaces/IHttpRequestJob.js +0 -2
  158. package/dist/types/alert.types.d.ts +0 -57
  159. package/dist/types/alert.types.js +0 -22
  160. package/dist/types/config.types.d.ts +0 -19
  161. package/dist/types/config.types.js +0 -2
  162. package/dist/types/index.d.ts +0 -3
  163. package/dist/types/index.js +0 -19
  164. package/dist/types/issue.types.d.ts +0 -90
  165. package/dist/types/issue.types.js +0 -40
  166. package/dist/utils/http-utils.d.ts +0 -13
  167. package/dist/utils/http-utils.js +0 -117
  168. /package/dist/{audit/AuditProperties.js → entities/accessGroup/IAccessGroup.js} +0 -0
  169. /package/dist/{admin → entities/admin}/Admin.repository.d.ts +0 -0
  170. /package/dist/{admin → entities/admin}/Admin.service.d.ts +0 -0
  171. /package/dist/{admin → entities/admin}/Admin.service.js +0 -0
  172. /package/dist/{admin → entities/admin}/index.d.ts +0 -0
  173. /package/dist/{admin → entities/admin}/index.js +0 -0
  174. /package/dist/{connection → entities/connection}/Connection.repository.d.ts +0 -0
  175. /package/dist/{connection → entities/connection}/Connection.service.d.ts +0 -0
  176. /package/dist/{connection → entities/connection}/Connection.service.js +0 -0
  177. /package/dist/{connection → entities/connection}/IConnection.d.ts +0 -0
  178. /package/dist/{connection → entities/connection}/IConnection.js +0 -0
  179. /package/dist/{connection → entities/connection}/index.d.ts +0 -0
  180. /package/dist/{connection → entities/connection}/index.js +0 -0
  181. /package/dist/{device → entities/device}/cloud/entities/CloudDevice.d.ts +0 -0
  182. /package/dist/{device → entities/device}/cloud/entities/CloudDevice.js +0 -0
  183. /package/dist/{device → entities/device}/cloud/entities/CloudDeviceService.d.ts +0 -0
  184. /package/dist/{device → entities/device}/cloud/entities/CloudDeviceService.js +0 -0
  185. /package/dist/{device → entities/device}/cloud/entities/DeviceFactory.d.ts +0 -0
  186. /package/dist/{device → entities/device}/cloud/entities/DeviceFactory.js +0 -0
  187. /package/dist/{device → entities/device}/cloud/entities/index.d.ts +0 -0
  188. /package/dist/{device → entities/device}/cloud/entities/index.js +0 -0
  189. /package/dist/{device → entities/device}/cloud/interfaces/ICloudDevice.d.ts +0 -0
  190. /package/dist/{device → entities/device}/cloud/interfaces/ICloudDevice.js +0 -0
  191. /package/dist/{device → entities/device}/cloud/interfaces/ICloudDeviceService.d.ts +0 -0
  192. /package/dist/{device → entities/device}/cloud/interfaces/ICloudDeviceService.js +0 -0
  193. /package/dist/{device → entities/device}/cloud/interfaces/IDeviceFactory.d.ts +0 -0
  194. /package/dist/{device → entities/device}/cloud/interfaces/IDeviceFactory.js +0 -0
  195. /package/dist/{device → entities/device}/cloud/interfaces/IRawDataTransformer.d.ts +0 -0
  196. /package/dist/{device → entities/device}/cloud/interfaces/IRawDataTransformer.js +0 -0
  197. /package/dist/{device → entities/device}/cloud/interfaces/IRawDevice.d.ts +0 -0
  198. /package/dist/{device → entities/device}/cloud/interfaces/IRawDevice.js +0 -0
  199. /package/dist/{device → entities/device}/cloud/interfaces/index.d.ts +0 -0
  200. /package/dist/{device → entities/device}/cloud/interfaces/index.js +0 -0
  201. /package/dist/{device → entities/device}/local/interfaces/IDevice.d.ts +0 -0
  202. /package/dist/{device → entities/device}/local/interfaces/IDevice.js +0 -0
  203. /package/dist/{device → entities/device}/local/interfaces/IDtDevice.d.ts +0 -0
  204. /package/dist/{device → entities/device}/local/interfaces/IDtDevice.js +0 -0
  205. /package/dist/{device → entities/device}/local/interfaces/ISchedule.d.ts +0 -0
  206. /package/dist/{device → entities/device}/local/interfaces/ISchedule.js +0 -0
  207. /package/dist/{device → entities/device}/local/interfaces/index.d.ts +0 -0
  208. /package/dist/{device → entities/device}/local/interfaces/index.js +0 -0
  209. /package/dist/{device → entities/device}/local/repository/Device.repository.d.ts +0 -0
  210. /package/dist/{device → entities/device}/local/repository/Hub.repository.d.ts +0 -0
  211. /package/dist/{device → entities/device}/local/repository/Schedule.repository.d.ts +0 -0
  212. /package/dist/{device → entities/device}/local/services/Hub.service.d.ts +0 -0
  213. /package/dist/{device → entities/device}/local/services/Hub.service.js +0 -0
  214. /package/dist/{device → entities/device}/local/services/Schedule.service.d.ts +0 -0
  215. /package/dist/{device → entities/device}/local/services/Schedule.service.js +0 -0
  216. /package/dist/{device → entities/device}/local/services/index.d.ts +0 -0
  217. /package/dist/{device → entities/device}/local/services/index.js +0 -0
  218. /package/dist/{device/cloud/interfaces/ICloudConnection.js → entities/guest/IGuest.js} +0 -0
  219. /package/dist/{pms → entities/pms}/IPms.d.ts +0 -0
  220. /package/dist/{pms → entities/pms}/IPms.js +0 -0
  221. /package/dist/{pms → entities/pms}/index.d.ts +0 -0
  222. /package/dist/{pms → entities/pms}/index.js +0 -0
  223. /package/dist/{device/local/interfaces → entities/property}/IProperty.d.ts +0 -0
  224. /package/dist/{device/local/interfaces → entities/property}/IProperty.js +0 -0
  225. /package/dist/{property → entities/property}/Property.repository.d.ts +0 -0
  226. /package/dist/{property → entities/property}/Property.service.d.ts +0 -0
  227. /package/dist/{property → entities/property}/Property.service.js +0 -0
  228. /package/dist/{property → entities/property}/index.d.ts +0 -0
  229. /package/dist/{property → entities/property}/index.js +0 -0
  230. /package/dist/{device/cloud/interfaces/IConnectionService.js → entities/schedules/ISchedule.js} +0 -0
  231. /package/dist/{device/cloud/interfaces/IDeviceService.js → entities/user/IUser.js} +0 -0
  232. /package/dist/{device/cloud/interfaces/IDevicesService.js → entities/zone/IZone.js} +0 -0
@@ -1,374 +0,0 @@
1
- "use strict";
2
- var __esDecorate = (this && this.__esDecorate) || function (ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {
3
- function accept(f) { if (f !== void 0 && typeof f !== "function") throw new TypeError("Function expected"); return f; }
4
- var kind = contextIn.kind, key = kind === "getter" ? "get" : kind === "setter" ? "set" : "value";
5
- var target = !descriptorIn && ctor ? contextIn["static"] ? ctor : ctor.prototype : null;
6
- var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});
7
- var _, done = false;
8
- for (var i = decorators.length - 1; i >= 0; i--) {
9
- var context = {};
10
- for (var p in contextIn) context[p] = p === "access" ? {} : contextIn[p];
11
- for (var p in contextIn.access) context.access[p] = contextIn.access[p];
12
- context.addInitializer = function (f) { if (done) throw new TypeError("Cannot add initializers after decoration has completed"); extraInitializers.push(accept(f || null)); };
13
- var result = (0, decorators[i])(kind === "accessor" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);
14
- if (kind === "accessor") {
15
- if (result === void 0) continue;
16
- if (result === null || typeof result !== "object") throw new TypeError("Object expected");
17
- if (_ = accept(result.get)) descriptor.get = _;
18
- if (_ = accept(result.set)) descriptor.set = _;
19
- if (_ = accept(result.init)) initializers.unshift(_);
20
- }
21
- else if (_ = accept(result)) {
22
- if (kind === "field") initializers.unshift(_);
23
- else descriptor[key] = _;
24
- }
25
- }
26
- if (target) Object.defineProperty(target, contextIn.name, descriptor);
27
- done = true;
28
- };
29
- var __runInitializers = (this && this.__runInitializers) || function (thisArg, initializers, value) {
30
- var useValue = arguments.length > 2;
31
- for (var i = 0; i < initializers.length; i++) {
32
- value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);
33
- }
34
- return useValue ? value : void 0;
35
- };
36
- var __setFunctionName = (this && this.__setFunctionName) || function (f, name, prefix) {
37
- if (typeof name === "symbol") name = name.description ? "[".concat(name.description, "]") : "";
38
- return Object.defineProperty(f, "name", { configurable: true, value: prefix ? "".concat(prefix, " ", name) : name });
39
- };
40
- Object.defineProperty(exports, "__esModule", { value: true });
41
- exports.AlertRepository = void 0;
42
- const typedi_1 = require("typedi");
43
- const Alert_model_1 = require("../models/Alert.model");
44
- const alert_types_1 = require("../../../types/alert.types");
45
- let AlertRepository = (() => {
46
- let _classDecorators = [(0, typedi_1.Service)()];
47
- let _classDescriptor;
48
- let _classExtraInitializers = [];
49
- let _classThis;
50
- var AlertRepository = _classThis = class {
51
- /**
52
- * Create a new alert
53
- */
54
- async create(alertData) {
55
- try {
56
- const alert = new Alert_model_1.AlertModel({
57
- ...alertData,
58
- severity: alertData.severity || alert_types_1.AlertSeverity.MEDIUM,
59
- isRead: false,
60
- isActive: true,
61
- isDeleted: false,
62
- });
63
- return await alert.save();
64
- }
65
- catch (error) {
66
- throw new Error(`Failed to create alert: ${error instanceof Error ? error.message : "Unknown error"}`);
67
- }
68
- }
69
- /**
70
- * Find alert by ID
71
- */
72
- async findById(id, includeDeleted = false) {
73
- try {
74
- const query = { _id: id };
75
- if (!includeDeleted) {
76
- query.isDeleted = false;
77
- }
78
- return await Alert_model_1.AlertModel.findOne(query);
79
- }
80
- catch (error) {
81
- throw new Error(`Failed to find alert by ID: ${error instanceof Error ? error.message : "Unknown error"}`);
82
- }
83
- }
84
- /**
85
- * Find all alerts with filters
86
- */
87
- async findAll(filters = {}) {
88
- try {
89
- const query = {};
90
- if (filters.propertyId)
91
- query.propertyId = filters.propertyId;
92
- if (filters.category)
93
- query.category = filters.category;
94
- if (filters.severity)
95
- query.severity = filters.severity;
96
- if (filters.entityType)
97
- query.entityType = filters.entityType;
98
- if (filters.entityId)
99
- query.entityId = filters.entityId;
100
- if (filters.isActive !== undefined)
101
- query.isActive = filters.isActive;
102
- if (filters.isRead !== undefined)
103
- query.isRead = filters.isRead;
104
- if (!filters.includeDeleted)
105
- query.isDeleted = false;
106
- const queryBuilder = Alert_model_1.AlertModel.find(query);
107
- if (filters.sort) {
108
- queryBuilder.sort(filters.sort);
109
- }
110
- else {
111
- queryBuilder.sort({ severity: -1, createdAt: -1 });
112
- }
113
- if (filters.skip)
114
- queryBuilder.skip(filters.skip);
115
- if (filters.limit)
116
- queryBuilder.limit(filters.limit);
117
- return await queryBuilder.exec();
118
- }
119
- catch (error) {
120
- throw new Error(`Failed to find alerts: ${error instanceof Error ? error.message : "Unknown error"}`);
121
- }
122
- }
123
- /**
124
- * Update an alert
125
- */
126
- async update(id, updateData) {
127
- try {
128
- return await Alert_model_1.AlertModel.findByIdAndUpdate(id, { ...updateData, updatedAt: new Date() }, { new: true, runValidators: true });
129
- }
130
- catch (error) {
131
- throw new Error(`Failed to update alert: ${error instanceof Error ? error.message : "Unknown error"}`);
132
- }
133
- }
134
- /**
135
- * Soft delete an alert
136
- */
137
- async softDelete(id, deletedBy) {
138
- try {
139
- const result = await Alert_model_1.AlertModel.findByIdAndUpdate(id, {
140
- isDeleted: true,
141
- updatedBy: deletedBy,
142
- updatedAt: new Date(),
143
- });
144
- return !!result;
145
- }
146
- catch (error) {
147
- throw new Error(`Failed to soft delete alert: ${error instanceof Error ? error.message : "Unknown error"}`);
148
- }
149
- }
150
- /**
151
- * Permanently delete an alert
152
- */
153
- async hardDelete(id) {
154
- try {
155
- const result = await Alert_model_1.AlertModel.findByIdAndDelete(id);
156
- return !!result;
157
- }
158
- catch (error) {
159
- throw new Error(`Failed to permanently delete alert: ${error instanceof Error ? error.message : "Unknown error"}`);
160
- }
161
- }
162
- /**
163
- * Count alerts with filters
164
- */
165
- async count(filters = {}) {
166
- try {
167
- const query = {};
168
- if (filters.propertyId)
169
- query.propertyId = filters.propertyId;
170
- if (filters.category)
171
- query.category = filters.category;
172
- if (filters.severity)
173
- query.severity = filters.severity;
174
- if (filters.entityType)
175
- query.entityType = filters.entityType;
176
- if (filters.entityId)
177
- query.entityId = filters.entityId;
178
- if (filters.isActive !== undefined)
179
- query.isActive = filters.isActive;
180
- if (filters.isRead !== undefined)
181
- query.isRead = filters.isRead;
182
- if (!filters.includeDeleted)
183
- query.isDeleted = false;
184
- return await Alert_model_1.AlertModel.countDocuments(query);
185
- }
186
- catch (error) {
187
- throw new Error(`Failed to count alerts: ${error instanceof Error ? error.message : "Unknown error"}`);
188
- }
189
- }
190
- /**
191
- * Find alerts by property
192
- */
193
- async findByProperty(propertyId, includeDeleted = false) {
194
- try {
195
- return await Alert_model_1.AlertModel.findByProperty(propertyId, includeDeleted);
196
- }
197
- catch (error) {
198
- throw new Error(`Failed to find alerts by property: ${error instanceof Error ? error.message : "Unknown error"}`);
199
- }
200
- }
201
- /**
202
- * Find alerts by entity
203
- */
204
- async findByEntity(entityId, entityType, includeDeleted = false) {
205
- try {
206
- return await Alert_model_1.AlertModel.findByEntity(entityId, entityType, includeDeleted);
207
- }
208
- catch (error) {
209
- throw new Error(`Failed to find alerts by entity: ${error instanceof Error ? error.message : "Unknown error"}`);
210
- }
211
- }
212
- /**
213
- * Find alerts by category
214
- */
215
- async findByCategory(category, includeDeleted = false) {
216
- try {
217
- return await Alert_model_1.AlertModel.findByCategory(category, includeDeleted);
218
- }
219
- catch (error) {
220
- throw new Error(`Failed to find alerts by category: ${error instanceof Error ? error.message : "Unknown error"}`);
221
- }
222
- }
223
- /**
224
- * Find alerts by severity
225
- */
226
- async findBySeverity(severity, includeDeleted = false) {
227
- try {
228
- return await Alert_model_1.AlertModel.findBySeverity(severity, includeDeleted);
229
- }
230
- catch (error) {
231
- throw new Error(`Failed to find alerts by severity: ${error instanceof Error ? error.message : "Unknown error"}`);
232
- }
233
- }
234
- /**
235
- * Find active alerts
236
- */
237
- async findActive(includeDeleted = false) {
238
- try {
239
- return await Alert_model_1.AlertModel.findActive(includeDeleted);
240
- }
241
- catch (error) {
242
- throw new Error(`Failed to find active alerts: ${error instanceof Error ? error.message : "Unknown error"}`);
243
- }
244
- }
245
- /**
246
- * Find unread alerts
247
- */
248
- async findUnread(includeDeleted = false) {
249
- try {
250
- return await Alert_model_1.AlertModel.findUnread(includeDeleted);
251
- }
252
- catch (error) {
253
- throw new Error(`Failed to find unread alerts: ${error instanceof Error ? error.message : "Unknown error"}`);
254
- }
255
- }
256
- /**
257
- * Find snoozed alerts
258
- */
259
- async findSnoozed(includeDeleted = false) {
260
- try {
261
- return await Alert_model_1.AlertModel.findSnoozed(includeDeleted);
262
- }
263
- catch (error) {
264
- throw new Error(`Failed to find snoozed alerts: ${error instanceof Error ? error.message : "Unknown error"}`);
265
- }
266
- }
267
- /**
268
- * Find expired snooze alerts
269
- */
270
- async findExpiredSnooze(includeDeleted = false) {
271
- try {
272
- return await Alert_model_1.AlertModel.findExpiredSnooze(includeDeleted);
273
- }
274
- catch (error) {
275
- throw new Error(`Failed to find expired snooze alerts: ${error instanceof Error ? error.message : "Unknown error"}`);
276
- }
277
- }
278
- /**
279
- * Get alert statistics
280
- */
281
- async getStatistics(propertyId) {
282
- try {
283
- const query = { isDeleted: false };
284
- if (propertyId)
285
- query.propertyId = propertyId;
286
- const [total, active, unread, snoozed, severityStats, categoryStats] = await Promise.all([
287
- Alert_model_1.AlertModel.countDocuments(query),
288
- Alert_model_1.AlertModel.countDocuments({ ...query, isActive: true }),
289
- Alert_model_1.AlertModel.countDocuments({ ...query, isRead: false }),
290
- Alert_model_1.AlertModel.countDocuments({
291
- ...query,
292
- snoozeUntil: { $exists: true, $ne: null },
293
- }),
294
- Alert_model_1.AlertModel.aggregate([
295
- { $match: query },
296
- { $group: { _id: "$severity", count: { $sum: 1 } } },
297
- ]),
298
- Alert_model_1.AlertModel.aggregate([
299
- { $match: query },
300
- { $group: { _id: "$category", count: { $sum: 1 } } },
301
- ]),
302
- ]);
303
- const bySeverity = Object.values(alert_types_1.AlertSeverity).reduce((acc, severity) => {
304
- acc[severity] = 0;
305
- return acc;
306
- }, {});
307
- const byCategory = Object.values(alert_types_1.AlertCategory).reduce((acc, category) => {
308
- acc[category] = 0;
309
- return acc;
310
- }, {});
311
- // Type-safe handling of aggregation results
312
- severityStats.forEach((stat) => {
313
- if (stat._id in bySeverity) {
314
- bySeverity[stat._id] = stat.count;
315
- }
316
- });
317
- categoryStats.forEach((stat) => {
318
- if (stat._id in byCategory) {
319
- byCategory[stat._id] = stat.count;
320
- }
321
- });
322
- return {
323
- total,
324
- active,
325
- unread,
326
- snoozed,
327
- bySeverity,
328
- byCategory,
329
- };
330
- }
331
- catch (error) {
332
- throw new Error(`Failed to get alert statistics: ${error instanceof Error ? error.message : "Unknown error"}`);
333
- }
334
- }
335
- /**
336
- * Bulk update alerts
337
- */
338
- async bulkUpdate(ids, updateData) {
339
- try {
340
- const result = await Alert_model_1.AlertModel.updateMany({ _id: { $in: ids } }, { ...updateData, updatedAt: new Date() });
341
- return result.modifiedCount;
342
- }
343
- catch (error) {
344
- throw new Error(`Failed to bulk update alerts: ${error instanceof Error ? error.message : "Unknown error"}`);
345
- }
346
- }
347
- /**
348
- * Bulk soft delete alerts
349
- */
350
- async bulkSoftDelete(ids, deletedBy) {
351
- try {
352
- const result = await Alert_model_1.AlertModel.updateMany({ _id: { $in: ids } }, {
353
- isDeleted: true,
354
- updatedBy: deletedBy,
355
- updatedAt: new Date(),
356
- });
357
- return result.modifiedCount;
358
- }
359
- catch (error) {
360
- throw new Error(`Failed to bulk soft delete alerts: ${error instanceof Error ? error.message : "Unknown error"}`);
361
- }
362
- }
363
- };
364
- __setFunctionName(_classThis, "AlertRepository");
365
- (() => {
366
- const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(null) : void 0;
367
- __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
368
- AlertRepository = _classThis = _classDescriptor.value;
369
- if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
370
- __runInitializers(_classThis, _classExtraInitializers);
371
- })();
372
- return AlertRepository = _classThis;
373
- })();
374
- exports.AlertRepository = AlertRepository;
@@ -1,8 +0,0 @@
1
- import { IConnection } from "../interfaces/IConnection";
2
- export declare class ConnectionRepository {
3
- private readonly pool;
4
- constructor();
5
- createConnection(data: Partial<IConnection>): Promise<IConnection>;
6
- getConnectionById(connectionId: string): Promise<IConnection>;
7
- updateConnection(connectionId: string, data: Partial<IConnection>): Promise<any>;
8
- }
@@ -1,113 +0,0 @@
1
- import { IIssueDocument } from "../models/Issue.model";
2
- import { CreateIssueData, UpdateIssueData, IssueStatus, IssuePriority, IssuesCategory, EntityType } from "../../../types/issue.types";
3
- export declare class IssueRepository {
4
- /**
5
- * Create a new issue
6
- */
7
- create(issueData: CreateIssueData): Promise<IIssueDocument>;
8
- /**
9
- * Find issue by ID
10
- */
11
- findById(id: string, includeDeleted?: boolean): Promise<IIssueDocument | null>;
12
- /**
13
- * Find all issues with filters
14
- */
15
- findAll(filters?: {
16
- propertyId?: string;
17
- assignedTo?: string;
18
- status?: IssueStatus;
19
- priority?: IssuePriority;
20
- category?: IssuesCategory;
21
- entityType?: EntityType;
22
- entityId?: string;
23
- includeDeleted?: boolean;
24
- limit?: number;
25
- skip?: number;
26
- sort?: {
27
- [key: string]: 1 | -1;
28
- };
29
- }): Promise<IIssueDocument[]>;
30
- /**
31
- * Update an issue
32
- */
33
- update(id: string, updateData: UpdateIssueData): Promise<IIssueDocument | null>;
34
- /**
35
- * Soft delete an issue
36
- */
37
- softDelete(id: string, deletedBy: string): Promise<boolean>;
38
- /**
39
- * Permanently delete an issue
40
- */
41
- hardDelete(id: string): Promise<boolean>;
42
- /**
43
- * Count issues with filters
44
- */
45
- count(filters?: {
46
- propertyId?: string;
47
- assignedTo?: string;
48
- status?: IssueStatus;
49
- priority?: IssuePriority;
50
- category?: IssuesCategory;
51
- entityType?: EntityType;
52
- entityId?: string;
53
- includeDeleted?: boolean;
54
- }): Promise<number>;
55
- /**
56
- * Find issues by property
57
- */
58
- findByProperty(propertyId: string, includeDeleted?: boolean): Promise<IIssueDocument[]>;
59
- /**
60
- * Find issues by assignee
61
- */
62
- findByAssignee(assignedTo: string, includeDeleted?: boolean): Promise<IIssueDocument[]>;
63
- /**
64
- * Find issues by entity
65
- */
66
- findByEntity(entityId: string, entityType: EntityType, includeDeleted?: boolean): Promise<IIssueDocument[]>;
67
- /**
68
- * Find issues by status
69
- */
70
- findByStatus(status: IssueStatus, includeDeleted?: boolean): Promise<IIssueDocument[]>;
71
- /**
72
- * Find issues by priority
73
- */
74
- findByPriority(priority: IssuePriority, includeDeleted?: boolean): Promise<IIssueDocument[]>;
75
- /**
76
- * Find overdue issues
77
- */
78
- findOverdue(includeDeleted?: boolean): Promise<IIssueDocument[]>;
79
- /**
80
- * Find upcoming issues
81
- */
82
- findUpcoming(days?: number, includeDeleted?: boolean): Promise<IIssueDocument[]>;
83
- /**
84
- * Search issues by text
85
- */
86
- search(searchTerm: string, filters?: {
87
- propertyId?: string;
88
- includeDeleted?: boolean;
89
- limit?: number;
90
- skip?: number;
91
- }): Promise<IIssueDocument[]>;
92
- /**
93
- * Get issue statistics
94
- */
95
- getStatistics(propertyId?: string): Promise<{
96
- total: number;
97
- pending: number;
98
- inProgress: number;
99
- resolved: number;
100
- closed: number;
101
- overdue: number;
102
- byPriority: Record<IssuePriority, number>;
103
- byCategory: Record<IssuesCategory, number>;
104
- }>;
105
- /**
106
- * Bulk update issues
107
- */
108
- bulkUpdate(ids: string[], updateData: Partial<UpdateIssueData>): Promise<number>;
109
- /**
110
- * Bulk soft delete issues
111
- */
112
- bulkSoftDelete(ids: string[], deletedBy: string): Promise<number>;
113
- }