dt-common-device 3.0.10 → 3.0.11

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 (113) hide show
  1. package/dist/config/config.d.ts +1 -2
  2. package/dist/config/config.js +4 -5
  3. package/dist/device/local/repository/Schedule.repository.d.ts +0 -1
  4. package/dist/device/local/repository/Schedule.repository.js +6 -6
  5. package/dist/queue/entities/HybridHttpQueue.d.ts +4 -14
  6. package/dist/queue/entities/HybridHttpQueue.js +31 -119
  7. package/dist/queue/interfaces/IHybridHttpQueue.d.ts +2 -12
  8. package/dist/queue/interfaces/IJobResult.d.ts +1 -8
  9. package/dist/queue/interfaces/index.d.ts +0 -1
  10. package/dist/queue/interfaces/index.js +0 -1
  11. package/dist/queue/services/QueueService.d.ts +2 -12
  12. package/dist/queue/types/queue.types.d.ts +10 -29
  13. package/dist/queue/utils/jobUtils.d.ts +0 -3
  14. package/dist/queue/utils/jobUtils.js +0 -48
  15. package/dist/queue/utils/queueUtils.d.ts +7 -0
  16. package/dist/queue/utils/queueUtils.js +113 -4
  17. package/package.json +6 -1
  18. package/.eslintrc.js +0 -44
  19. package/src/alerts/Alert.model.ts +0 -289
  20. package/src/alerts/Alert.repository.ts +0 -487
  21. package/src/alerts/Alert.service.ts +0 -711
  22. package/src/alerts/AlertBuilder.example.ts +0 -126
  23. package/src/alerts/AlertBuilder.ts +0 -208
  24. package/src/alerts/AlertService.example.ts +0 -232
  25. package/src/alerts/alert.types.ts +0 -64
  26. package/src/alerts/index.ts +0 -3
  27. package/src/config/config.ts +0 -202
  28. package/src/config/config.types.ts +0 -21
  29. package/src/connection/Connection.repository.ts +0 -52
  30. package/src/connection/Connection.service.ts +0 -39
  31. package/src/connection/IConnection.ts +0 -27
  32. package/src/connection/index.ts +0 -3
  33. package/src/constants/ConnectionProviders.ts +0 -11
  34. package/src/constants/Event.ts +0 -89
  35. package/src/constants/Service.ts +0 -17
  36. package/src/constants/index.ts +0 -3
  37. package/src/db/db.ts +0 -24
  38. package/src/db/index.ts +0 -2
  39. package/src/db/redis.ts +0 -20
  40. package/src/device/cloud/entities/CloudDevice.ts +0 -40
  41. package/src/device/cloud/entities/CloudDeviceService.ts +0 -8
  42. package/src/device/cloud/entities/DeviceFactory.ts +0 -27
  43. package/src/device/cloud/entities/index.ts +0 -3
  44. package/src/device/cloud/interfaces/ICloudDevice.ts +0 -14
  45. package/src/device/cloud/interfaces/ICloudDeviceService.ts +0 -6
  46. package/src/device/cloud/interfaces/IDeviceFactory.ts +0 -5
  47. package/src/device/cloud/interfaces/IRawDataTransformer.ts +0 -5
  48. package/src/device/cloud/interfaces/IRawDevice.ts +0 -19
  49. package/src/device/cloud/interfaces/index.ts +0 -5
  50. package/src/device/local/interfaces/IDevice.ts +0 -62
  51. package/src/device/local/interfaces/IDtDevice.ts +0 -16
  52. package/src/device/local/interfaces/ISchedule.ts +0 -40
  53. package/src/device/local/interfaces/index.ts +0 -3
  54. package/src/device/local/repository/Device.repository.ts +0 -368
  55. package/src/device/local/repository/Hub.repository.ts +0 -107
  56. package/src/device/local/repository/Schedule.repository.ts +0 -72
  57. package/src/device/local/services/Device.service.ts +0 -436
  58. package/src/device/local/services/Hub.service.ts +0 -57
  59. package/src/device/local/services/Schedule.service.ts +0 -26
  60. package/src/device/local/services/index.ts +0 -3
  61. package/src/docs/Alert.model.md +0 -319
  62. package/src/docs/Alerts&IssuesModel.md +0 -312
  63. package/src/docs/Issue.model.md +0 -386
  64. package/src/docs/SECURITY.md +0 -67
  65. package/src/docs/TROUBLESHOOTING.md +0 -184
  66. package/src/events/BaseEventHandler.ts +0 -145
  67. package/src/events/BaseEventTransformer.ts +0 -97
  68. package/src/events/DeviceEventHandler.ts +0 -213
  69. package/src/events/DeviceEventTransformerFactory.ts +0 -77
  70. package/src/events/EventHandler.ts +0 -124
  71. package/src/events/EventHandlerOrchestrator.ts +0 -119
  72. package/src/events/EventProcessingService.ts +0 -248
  73. package/src/events/InternalEventSubscription.ts +0 -194
  74. package/src/events/index.ts +0 -9
  75. package/src/events/interfaces/DeviceEvent.ts +0 -56
  76. package/src/events/interfaces/IEventHandler.ts +0 -28
  77. package/src/events/interfaces/IEventTransformer.ts +0 -8
  78. package/src/events/interfaces/IInternalEvent.ts +0 -33
  79. package/src/events/interfaces/index.ts +0 -4
  80. package/src/index.ts +0 -43
  81. package/src/issues/Issue.model.ts +0 -350
  82. package/src/issues/Issue.repository.ts +0 -517
  83. package/src/issues/Issue.service.ts +0 -932
  84. package/src/issues/IssueBuilder.example.ts +0 -210
  85. package/src/issues/IssueBuilder.ts +0 -263
  86. package/src/issues/IssueService.example.ts +0 -310
  87. package/src/issues/index.ts +0 -2
  88. package/src/issues/issue.types.ts +0 -98
  89. package/src/property/IProperty.ts +0 -30
  90. package/src/property/Property.repository.ts +0 -53
  91. package/src/property/Property.service.ts +0 -38
  92. package/src/property/index.ts +0 -2
  93. package/src/queue/entities/HybridHttpQueue.ts +0 -274
  94. package/src/queue/entities/index.ts +0 -1
  95. package/src/queue/index.ts +0 -6
  96. package/src/queue/interfaces/IHttpRequestJob.ts +0 -10
  97. package/src/queue/interfaces/IHybridHttpQueue.ts +0 -25
  98. package/src/queue/interfaces/IJobResult.ts +0 -15
  99. package/src/queue/interfaces/IRateLimitConfig.ts +0 -5
  100. package/src/queue/interfaces/index.ts +0 -4
  101. package/src/queue/services/QueueService.ts +0 -40
  102. package/src/queue/services/index.ts +0 -1
  103. package/src/queue/types/http.types.ts +0 -23
  104. package/src/queue/types/index.ts +0 -2
  105. package/src/queue/types/queue.types.ts +0 -21
  106. package/src/queue/utils/index.ts +0 -3
  107. package/src/queue/utils/jobUtils.ts +0 -79
  108. package/src/queue/utils/queueUtils.ts +0 -84
  109. package/src/queue/utils/rateLimit.utils.ts +0 -131
  110. package/src/utils/http.utils.ts +0 -143
  111. package/src/utils/index.ts +0 -2
  112. package/src/utils/redis.utils.ts +0 -74
  113. package/tsconfig.json +0 -20
@@ -1,210 +0,0 @@
1
- import { IssueBuilder } from "./IssueBuilder";
2
- import { IssuesCategory, IssuePriority, EntityType } from "./issue.types";
3
-
4
- /**
5
- * Example usage of IssueBuilder
6
- * This file demonstrates various ways to use the IssueBuilder pattern
7
- */
8
-
9
- // Example 1: Basic issue creation
10
- export function createBasicIssue() {
11
- const issueData = new IssueBuilder()
12
- .setCategory(IssuesCategory.OPERATIONS)
13
- .setPropertyId("prop123")
14
- .setTitle("Device Maintenance Required")
15
- .setDescription("Device requires scheduled maintenance")
16
- .setEntityId("device456")
17
- .setEntityType(EntityType.DEVICE)
18
- .setPriority(IssuePriority.HIGH)
19
- .setAssignedTo("tech789")
20
- .setCreatedBy("user123")
21
- .setDueDate(new Date("2024-01-15"))
22
- .build();
23
-
24
- return issueData;
25
- }
26
-
27
- // Example 2: Using static factory methods
28
- export function createDeviceIssue() {
29
- const issueData = IssueBuilder.createDeviceIssue("device123", "prop456")
30
- .setCategory(IssuesCategory.READINESS)
31
- .setTitle("Device Firmware Update")
32
- .setDescription("Device firmware update is available")
33
- .setPriority(IssuePriority.MEDIUM)
34
- .setAssignedTo("admin")
35
- .setCreatedBy("system")
36
- .setDueDate(new Date("2024-01-20"))
37
- .build();
38
-
39
- return issueData;
40
- }
41
-
42
- // Example 3: Using predefined issue types
43
- export function createSecurityIssue() {
44
- const issueData = IssueBuilder.createSecurityIssue()
45
- .setPropertyId("prop789")
46
- .setTitle("Security Breach Detected")
47
- .setDescription("Unauthorized access attempt detected")
48
- .setEntityId("user123")
49
- .setEntityType(EntityType.USER)
50
- .setAssignedTo("security-team")
51
- .setCreatedBy("security-system")
52
- .setDueDate(new Date("2024-01-10"))
53
- .build();
54
-
55
- return issueData;
56
- }
57
-
58
- // Example 4: Creating energy issue
59
- export function createEnergyIssue() {
60
- const issueData = IssueBuilder.createEnergyIssue()
61
- .setPropertyId("prop101")
62
- .setTitle("High Energy Consumption")
63
- .setDescription("Energy usage is 20% above normal levels")
64
- .setEntityId("zone456")
65
- .setEntityType(EntityType.COLLECTION)
66
- .setAssignedTo("energy-manager")
67
- .setCreatedBy("energy-monitor")
68
- .setDueDate(new Date("2024-01-25"))
69
- .build();
70
-
71
- return issueData;
72
- }
73
-
74
- // Example 5: Creating hub issue
75
- export function createHubIssue() {
76
- const issueData = IssueBuilder.createHubIssue("hub789", "prop202")
77
- .setCategory(IssuesCategory.OPERATIONS)
78
- .setTitle("Hub Connection Lost")
79
- .setDescription("Hub has lost connection to the network")
80
- .setPriority(IssuePriority.CRITICAL)
81
- .setAssignedTo("network-admin")
82
- .setCreatedBy("network-monitor")
83
- .setDueDate(new Date("2024-01-05"))
84
- .build();
85
-
86
- return issueData;
87
- }
88
-
89
- // Example 6: Creating user-specific issue
90
- export function createUserIssue() {
91
- const issueData = IssueBuilder.createUserIssue("user456", "prop303")
92
- .setCategory(IssuesCategory.SECURITY)
93
- .setTitle("User Access Review Required")
94
- .setDescription("User access permissions need review")
95
- .setPriority(IssuePriority.MEDIUM)
96
- .setAssignedTo("hr-admin")
97
- .setCreatedBy("access-control")
98
- .setDueDate(new Date("2024-01-30"))
99
- .build();
100
-
101
- return issueData;
102
- }
103
-
104
- // Example 7: Creating property-specific issue
105
- export function createPropertyIssue() {
106
- const issueData = IssueBuilder.createPropertyIssue("prop404")
107
- .setCategory(IssuesCategory.READINESS)
108
- .setTitle("Property Maintenance Schedule")
109
- .setDescription("Annual property maintenance is due")
110
- .setPriority(IssuePriority.LOW)
111
- .setAssignedTo("property-manager")
112
- .setCreatedBy("maintenance-system")
113
- .setDueDate(new Date("2024-02-15"))
114
- .build();
115
-
116
- return issueData;
117
- }
118
-
119
- // Example 8: Creating maintenance issue
120
- export function createMaintenanceIssue() {
121
- const issueData = IssueBuilder.createMaintenanceIssue("prop505", "device789", EntityType.DEVICE)
122
- .setTitle("Scheduled Device Maintenance")
123
- .setDescription("Regular maintenance is scheduled for this device")
124
- .setAssignedTo("technician")
125
- .setCreatedBy("maintenance-scheduler")
126
- .setDueDate(new Date("2024-01-12"))
127
- .build();
128
-
129
- return issueData;
130
- }
131
-
132
- // Example 9: Creating urgent issue
133
- export function createUrgentIssue() {
134
- const issueData = IssueBuilder.createUrgentIssue("prop606", "hub123", EntityType.HUB)
135
- .setTitle("Critical Hub Failure")
136
- .setDescription("Hub is experiencing critical failures")
137
- .setAssignedTo("emergency-tech")
138
- .setCreatedBy("monitoring-system")
139
- .setDueDate(new Date("2024-01-03"))
140
- .build();
141
-
142
- return issueData;
143
- }
144
-
145
- // Example 10: Reusing builder instance
146
- export function createMultipleIssues() {
147
- const builder = new IssueBuilder()
148
- .setPropertyId("prop707")
149
- .setCreatedBy("batch-processor");
150
-
151
- const issue1 = builder
152
- .setCategory(IssuesCategory.OPERATIONS)
153
- .setTitle("Device Temperature High")
154
- .setDescription("Device temperature exceeds normal operating range")
155
- .setEntityId("device789")
156
- .setEntityType(EntityType.DEVICE)
157
- .setPriority(IssuePriority.HIGH)
158
- .setAssignedTo("tech-support")
159
- .build();
160
-
161
- const issue2 = builder
162
- .reset()
163
- .setPropertyId("prop707")
164
- .setCategory(IssuesCategory.ENERGY)
165
- .setTitle("Low Battery Warning")
166
- .setDescription("Device battery level is below 20%")
167
- .setEntityId("device789")
168
- .setEntityType(EntityType.DEVICE)
169
- .setPriority(IssuePriority.MEDIUM)
170
- .setAssignedTo("maintenance-team")
171
- .setCreatedBy("batch-processor")
172
- .build();
173
-
174
- return [issue1, issue2];
175
- }
176
-
177
- // Example 11: Creating issue with due date calculation
178
- export function createIssueWithDueDate() {
179
- const dueDate = new Date();
180
- dueDate.setDate(dueDate.getDate() + 7); // Due in 7 days
181
-
182
- const issueData = new IssueBuilder()
183
- .setCategory(IssuesCategory.READINESS)
184
- .setPropertyId("prop808")
185
- .setTitle("System Update Required")
186
- .setDescription("System requires critical security update")
187
- .setEntityType(EntityType.PROPERTY)
188
- .setPriority(IssuePriority.HIGH)
189
- .setAssignedTo("system-admin")
190
- .setCreatedBy("update-manager")
191
- .setDueDate(dueDate)
192
- .build();
193
-
194
- return issueData;
195
- }
196
-
197
- // Example 12: Creating issue without assignment
198
- export function createUnassignedIssue() {
199
- const issueData = new IssueBuilder()
200
- .setCategory(IssuesCategory.OTHER)
201
- .setPropertyId("prop909")
202
- .setTitle("General Inquiry")
203
- .setDescription("General inquiry about system functionality")
204
- .setEntityType(EntityType.PROPERTY)
205
- .setPriority(IssuePriority.LOW)
206
- .setCreatedBy("user-inquiry")
207
- .build();
208
-
209
- return issueData;
210
- }
@@ -1,263 +0,0 @@
1
- import {
2
- CreateIssueData,
3
- IssuesCategory,
4
- IssuePriority,
5
- EntityType,
6
- } from "./issue.types";
7
-
8
- /**
9
- * IssueBuilder - A builder pattern implementation for constructing CreateIssueData objects
10
- *
11
- * This builder provides a fluent interface for creating issue data with proper validation
12
- * and default values. It follows the Builder pattern which is a standard design pattern
13
- * in TypeScript for constructing complex objects.
14
- *
15
- * Usage example:
16
- * const issueData = new IssueBuilder()
17
- * .setCategory(IssuesCategory.OPERATIONS)
18
- * .setPropertyId("prop123")
19
- * .setTitle("Device Maintenance Required")
20
- * .setDescription("Device requires scheduled maintenance")
21
- * .setEntityId("device456")
22
- * .setEntityType(EntityType.DEVICE)
23
- * .setPriority(IssuePriority.HIGH)
24
- * .setAssignedTo("tech789")
25
- * .setCreatedBy("user123")
26
- * .setDueDate(new Date("2024-01-15"))
27
- * .build();
28
- */
29
- export class IssueBuilder {
30
- private data: Partial<CreateIssueData> = {};
31
-
32
- /**
33
- * Sets the issue category
34
- */
35
- setCategory(category: IssuesCategory): IssueBuilder {
36
- this.data.category = category;
37
- return this;
38
- }
39
-
40
- /**
41
- * Sets the property ID
42
- */
43
- setPropertyId(propertyId: string): IssueBuilder {
44
- if (!propertyId || propertyId.trim() === "") {
45
- throw new Error("Property ID is required and cannot be empty");
46
- }
47
- this.data.propertyId = propertyId;
48
- return this;
49
- }
50
-
51
- /**
52
- * Sets the issue title
53
- */
54
- setTitle(title: string): IssueBuilder {
55
- if (!title || title.trim() === "") {
56
- throw new Error("Title is required and cannot be empty");
57
- }
58
- this.data.title = title.trim();
59
- return this;
60
- }
61
-
62
- /**
63
- * Sets the issue description
64
- */
65
- setDescription(description: string): IssueBuilder {
66
- if (!description || description.trim() === "") {
67
- throw new Error("Description is required and cannot be empty");
68
- }
69
- this.data.description = description.trim();
70
- return this;
71
- }
72
-
73
- /**
74
- * Sets the entity ID (optional)
75
- */
76
- setEntityId(entityId?: string): IssueBuilder {
77
- if (entityId !== undefined) {
78
- this.data.entityId = entityId.trim() || undefined;
79
- }
80
- return this;
81
- }
82
-
83
- /**
84
- * Sets the entity type
85
- */
86
- setEntityType(entityType: EntityType): IssueBuilder {
87
- this.data.entityType = entityType;
88
- return this;
89
- }
90
-
91
- /**
92
- * Sets the issue priority (optional, defaults to MEDIUM)
93
- */
94
- setPriority(priority?: IssuePriority): IssueBuilder {
95
- if (priority !== undefined) {
96
- this.data.priority = priority;
97
- }
98
- return this;
99
- }
100
-
101
- /**
102
- * Sets the user assigned to the issue (optional)
103
- */
104
- setAssignedTo(assignedTo?: string): IssueBuilder {
105
- if (assignedTo !== undefined) {
106
- this.data.assignedTo = assignedTo.trim() || undefined;
107
- }
108
- return this;
109
- }
110
-
111
- /**
112
- * Sets the user who created the issue (required)
113
- */
114
- setCreatedBy(createdBy: string): IssueBuilder {
115
- if (!createdBy || createdBy.trim() === "") {
116
- throw new Error("Created by user is required and cannot be empty");
117
- }
118
- this.data.createdBy = createdBy.trim();
119
- return this;
120
- }
121
-
122
- /**
123
- * Sets the due date (optional)
124
- */
125
- setDueDate(dueDate?: Date): IssueBuilder {
126
- if (dueDate !== undefined) {
127
- this.data.dueDate = dueDate;
128
- }
129
- return this;
130
- }
131
-
132
- /**
133
- * Validates that all required fields are present
134
- */
135
- private validate(): void {
136
- const requiredFields = ["category", "propertyId", "title", "description", "entityType", "createdBy"];
137
- const missingFields = requiredFields.filter(field => !this.data[field as keyof CreateIssueData]);
138
-
139
- if (missingFields.length > 0) {
140
- throw new Error(`Missing required fields: ${missingFields.join(", ")}`);
141
- }
142
- }
143
-
144
- /**
145
- * Builds and returns the CreateIssueData object
146
- * @throws Error if required fields are missing
147
- */
148
- build(): CreateIssueData {
149
- this.validate();
150
-
151
- // Set default priority if not provided
152
- if (!this.data.priority) {
153
- this.data.priority = IssuePriority.MEDIUM;
154
- }
155
-
156
- return this.data as CreateIssueData;
157
- }
158
-
159
- /**
160
- * Resets the builder to its initial state
161
- */
162
- reset(): IssueBuilder {
163
- this.data = {};
164
- return this;
165
- }
166
-
167
- /**
168
- * Creates a new builder instance with predefined values for common issue types
169
- */
170
- static createReadinessIssue(): IssueBuilder {
171
- return new IssueBuilder()
172
- .setCategory(IssuesCategory.READINESS)
173
- .setPriority(IssuePriority.MEDIUM);
174
- }
175
-
176
- static createOperationsIssue(): IssueBuilder {
177
- return new IssueBuilder()
178
- .setCategory(IssuesCategory.OPERATIONS)
179
- .setPriority(IssuePriority.HIGH);
180
- }
181
-
182
- static createSecurityIssue(): IssueBuilder {
183
- return new IssueBuilder()
184
- .setCategory(IssuesCategory.SECURITY)
185
- .setPriority(IssuePriority.CRITICAL);
186
- }
187
-
188
- static createEnergyIssue(): IssueBuilder {
189
- return new IssueBuilder()
190
- .setCategory(IssuesCategory.ENERGY)
191
- .setPriority(IssuePriority.LOW);
192
- }
193
-
194
- /**
195
- * Creates a device-specific issue builder
196
- */
197
- static createDeviceIssue(deviceId: string, propertyId: string): IssueBuilder {
198
- return new IssueBuilder()
199
- .setEntityType(EntityType.DEVICE)
200
- .setEntityId(deviceId)
201
- .setPropertyId(propertyId);
202
- }
203
-
204
- /**
205
- * Creates a hub-specific issue builder
206
- */
207
- static createHubIssue(hubId: string, propertyId: string): IssueBuilder {
208
- return new IssueBuilder()
209
- .setEntityType(EntityType.HUB)
210
- .setEntityId(hubId)
211
- .setPropertyId(propertyId);
212
- }
213
-
214
- /**
215
- * Creates a user-specific issue builder
216
- */
217
- static createUserIssue(userId: string, propertyId: string): IssueBuilder {
218
- return new IssueBuilder()
219
- .setEntityType(EntityType.USER)
220
- .setEntityId(userId)
221
- .setPropertyId(propertyId);
222
- }
223
-
224
- /**
225
- * Creates a property-specific issue builder
226
- */
227
- static createPropertyIssue(propertyId: string): IssueBuilder {
228
- return new IssueBuilder()
229
- .setEntityType(EntityType.PROPERTY)
230
- .setEntityId(propertyId)
231
- .setPropertyId(propertyId);
232
- }
233
-
234
- /**
235
- * Creates a maintenance issue builder
236
- */
237
- static createMaintenanceIssue(propertyId: string, entityId?: string, entityType?: EntityType): IssueBuilder {
238
- const builder = new IssueBuilder()
239
- .setCategory(IssuesCategory.READINESS)
240
- .setPropertyId(propertyId)
241
- .setPriority(IssuePriority.MEDIUM);
242
-
243
- if (entityId) builder.setEntityId(entityId);
244
- if (entityType) builder.setEntityType(entityType);
245
-
246
- return builder;
247
- }
248
-
249
- /**
250
- * Creates an urgent issue builder
251
- */
252
- static createUrgentIssue(propertyId: string, entityId?: string, entityType?: EntityType): IssueBuilder {
253
- const builder = new IssueBuilder()
254
- .setCategory(IssuesCategory.OPERATIONS)
255
- .setPropertyId(propertyId)
256
- .setPriority(IssuePriority.URGENT);
257
-
258
- if (entityId) builder.setEntityId(entityId);
259
- if (entityType) builder.setEntityType(entityType);
260
-
261
- return builder;
262
- }
263
- }