homebridge 2.0.0-beta.30 → 2.0.0-beta.31

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 (88) hide show
  1. package/dist/api.d.ts +267 -3
  2. package/dist/api.d.ts.map +1 -1
  3. package/dist/api.js +92 -0
  4. package/dist/api.js.map +1 -1
  5. package/dist/bridgeService.d.ts +4 -2
  6. package/dist/bridgeService.d.ts.map +1 -1
  7. package/dist/bridgeService.js +1 -3
  8. package/dist/bridgeService.js.map +1 -1
  9. package/dist/childBridgeFork.d.ts +29 -2
  10. package/dist/childBridgeFork.d.ts.map +1 -1
  11. package/dist/childBridgeFork.js +294 -4
  12. package/dist/childBridgeFork.js.map +1 -1
  13. package/dist/childBridgeService.d.ts +19 -0
  14. package/dist/childBridgeService.d.ts.map +1 -1
  15. package/dist/childBridgeService.js +38 -3
  16. package/dist/childBridgeService.js.map +1 -1
  17. package/dist/externalPortService.d.ts +27 -6
  18. package/dist/externalPortService.d.ts.map +1 -1
  19. package/dist/externalPortService.js +73 -7
  20. package/dist/externalPortService.js.map +1 -1
  21. package/dist/index.d.ts +47 -1
  22. package/dist/index.d.ts.map +1 -1
  23. package/dist/index.js +15 -0
  24. package/dist/index.js.map +1 -1
  25. package/dist/ipcService.d.ts +20 -0
  26. package/dist/ipcService.d.ts.map +1 -1
  27. package/dist/ipcService.js.map +1 -1
  28. package/dist/logger.d.ts +6 -0
  29. package/dist/logger.d.ts.map +1 -1
  30. package/dist/logger.js +8 -0
  31. package/dist/logger.js.map +1 -1
  32. package/dist/matter/index.d.ts +123 -0
  33. package/dist/matter/index.d.ts.map +1 -0
  34. package/dist/matter/index.js +19 -0
  35. package/dist/matter/index.js.map +1 -0
  36. package/dist/matter/matterAccessoryCache.d.ts +96 -0
  37. package/dist/matter/matterAccessoryCache.d.ts.map +1 -0
  38. package/dist/matter/matterAccessoryCache.js +192 -0
  39. package/dist/matter/matterAccessoryCache.js.map +1 -0
  40. package/dist/matter/matterBehaviors.d.ts +194 -0
  41. package/dist/matter/matterBehaviors.d.ts.map +1 -0
  42. package/dist/matter/matterBehaviors.js +665 -0
  43. package/dist/matter/matterBehaviors.js.map +1 -0
  44. package/dist/matter/matterConfigValidator.d.ts +81 -0
  45. package/dist/matter/matterConfigValidator.d.ts.map +1 -0
  46. package/dist/matter/matterConfigValidator.js +240 -0
  47. package/dist/matter/matterConfigValidator.js.map +1 -0
  48. package/dist/matter/matterErrorHandler.d.ts +106 -0
  49. package/dist/matter/matterErrorHandler.d.ts.map +1 -0
  50. package/dist/matter/matterErrorHandler.js +495 -0
  51. package/dist/matter/matterErrorHandler.js.map +1 -0
  52. package/dist/matter/matterLogFormatter.d.ts +19 -0
  53. package/dist/matter/matterLogFormatter.d.ts.map +1 -0
  54. package/dist/matter/matterLogFormatter.js +144 -0
  55. package/dist/matter/matterLogFormatter.js.map +1 -0
  56. package/dist/matter/matterNetworkMonitor.d.ts +68 -0
  57. package/dist/matter/matterNetworkMonitor.d.ts.map +1 -0
  58. package/dist/matter/matterNetworkMonitor.js +249 -0
  59. package/dist/matter/matterNetworkMonitor.js.map +1 -0
  60. package/dist/matter/matterServer.d.ts +656 -0
  61. package/dist/matter/matterServer.d.ts.map +1 -0
  62. package/dist/matter/matterServer.js +1690 -0
  63. package/dist/matter/matterServer.js.map +1 -0
  64. package/dist/matter/matterServerHelpers.d.ts +81 -0
  65. package/dist/matter/matterServerHelpers.d.ts.map +1 -0
  66. package/dist/matter/matterServerHelpers.js +323 -0
  67. package/dist/matter/matterServerHelpers.js.map +1 -0
  68. package/dist/matter/matterSharedTypes.d.ts +170 -0
  69. package/dist/matter/matterSharedTypes.d.ts.map +1 -0
  70. package/dist/matter/matterSharedTypes.js +52 -0
  71. package/dist/matter/matterSharedTypes.js.map +1 -0
  72. package/dist/matter/matterStorage.d.ts +128 -0
  73. package/dist/matter/matterStorage.d.ts.map +1 -0
  74. package/dist/matter/matterStorage.js +415 -0
  75. package/dist/matter/matterStorage.js.map +1 -0
  76. package/dist/matter/matterTypes.d.ts +745 -0
  77. package/dist/matter/matterTypes.d.ts.map +1 -0
  78. package/dist/matter/matterTypes.js +174 -0
  79. package/dist/matter/matterTypes.js.map +1 -0
  80. package/dist/server.d.ts +23 -1
  81. package/dist/server.d.ts.map +1 -1
  82. package/dist/server.js +385 -7
  83. package/dist/server.js.map +1 -1
  84. package/dist/user.d.ts +1 -0
  85. package/dist/user.d.ts.map +1 -1
  86. package/dist/user.js +3 -0
  87. package/dist/user.js.map +1 -1
  88. package/package.json +16 -15
@@ -0,0 +1,495 @@
1
+ /**
2
+ * Matter Error Handler
3
+ *
4
+ * Centralized error handling and recovery for Matter.js integration
5
+ * with circuit breaker pattern and contextual recovery
6
+ */
7
+ import { Logger } from '../logger.js';
8
+ import { MatterCommissioningError, MatterDeviceError, MatterError, MatterErrorType, MatterNetworkError, MatterStorageError, } from './matterTypes.js';
9
+ const log = Logger.withPrefix('Matter/Errors');
10
+ // Re-export for backward compatibility
11
+ export { MatterCommissioningError, MatterDeviceError, MatterError, MatterErrorType, MatterNetworkError, MatterStorageError };
12
+ /**
13
+ * Circuit breaker states
14
+ */
15
+ var CircuitState;
16
+ (function (CircuitState) {
17
+ CircuitState["CLOSED"] = "CLOSED";
18
+ CircuitState["OPEN"] = "OPEN";
19
+ CircuitState["HALF_OPEN"] = "HALF_OPEN";
20
+ })(CircuitState || (CircuitState = {}));
21
+ /**
22
+ * Circuit breaker for error recovery
23
+ */
24
+ class CircuitBreaker {
25
+ threshold;
26
+ timeout;
27
+ successThreshold;
28
+ state = CircuitState.CLOSED;
29
+ failureCount = 0;
30
+ successCount = 0;
31
+ nextAttemptTime = 0;
32
+ constructor(threshold = 5, timeout = 60000, // 1 minute
33
+ successThreshold = 3) {
34
+ this.threshold = threshold;
35
+ this.timeout = timeout;
36
+ this.successThreshold = successThreshold;
37
+ }
38
+ /**
39
+ * Check if operation should be allowed
40
+ */
41
+ canAttempt() {
42
+ const now = Date.now();
43
+ switch (this.state) {
44
+ case CircuitState.CLOSED:
45
+ return true;
46
+ case CircuitState.OPEN:
47
+ if (now >= this.nextAttemptTime) {
48
+ this.state = CircuitState.HALF_OPEN;
49
+ return true;
50
+ }
51
+ return false;
52
+ case CircuitState.HALF_OPEN:
53
+ return true;
54
+ default:
55
+ return false;
56
+ }
57
+ }
58
+ /**
59
+ * Record success
60
+ */
61
+ recordSuccess() {
62
+ this.failureCount = 0;
63
+ if (this.state === CircuitState.HALF_OPEN) {
64
+ this.successCount++;
65
+ if (this.successCount >= this.successThreshold) {
66
+ this.state = CircuitState.CLOSED;
67
+ this.successCount = 0;
68
+ }
69
+ }
70
+ }
71
+ /**
72
+ * Record failure
73
+ */
74
+ recordFailure() {
75
+ this.failureCount++;
76
+ this.successCount = 0;
77
+ if (this.state === CircuitState.HALF_OPEN) {
78
+ this.state = CircuitState.OPEN;
79
+ this.nextAttemptTime = Date.now() + this.timeout;
80
+ }
81
+ else if (this.failureCount >= this.threshold) {
82
+ this.state = CircuitState.OPEN;
83
+ this.nextAttemptTime = Date.now() + this.timeout;
84
+ }
85
+ }
86
+ /**
87
+ * Get current state
88
+ */
89
+ getState() {
90
+ return this.state;
91
+ }
92
+ /**
93
+ * Reset the circuit breaker
94
+ */
95
+ reset() {
96
+ this.state = CircuitState.CLOSED;
97
+ this.failureCount = 0;
98
+ this.successCount = 0;
99
+ this.nextAttemptTime = 0;
100
+ }
101
+ }
102
+ export class MatterErrorHandler {
103
+ static instance;
104
+ errorCount = new Map();
105
+ lastErrors = new Map();
106
+ recoveryCallbacks = new Map();
107
+ circuitBreakers = new Map();
108
+ recoveryContexts = new Map();
109
+ MAX_RECOVERY_ATTEMPTS = 5;
110
+ constructor() { }
111
+ static getInstance() {
112
+ if (!MatterErrorHandler.instance) {
113
+ MatterErrorHandler.instance = new MatterErrorHandler();
114
+ }
115
+ return MatterErrorHandler.instance;
116
+ }
117
+ /**
118
+ * Handle a Matter error with context-aware recovery
119
+ */
120
+ async handleError(error, context) {
121
+ const matterError = this.categorizeError(error, context);
122
+ // Log the error with appropriate level
123
+ this.logError(matterError);
124
+ // Track error occurrence
125
+ this.trackError(matterError);
126
+ // Check circuit breaker before attempting recovery
127
+ const circuitBreaker = this.getOrCreateCircuitBreaker(matterError.type);
128
+ if (matterError.recoverable && circuitBreaker.canAttempt()) {
129
+ // Check if we should attempt recovery based on context
130
+ if (this.shouldAttemptRecovery(matterError)) {
131
+ this.attemptContextualRecovery(matterError, circuitBreaker).catch((err) => {
132
+ log.debug(`Recovery attempt failed for ${matterError.type}:`, err);
133
+ circuitBreaker.recordFailure();
134
+ });
135
+ }
136
+ }
137
+ else if (!circuitBreaker.canAttempt()) {
138
+ log.debug(`Circuit breaker OPEN for ${matterError.type}, skipping recovery`);
139
+ }
140
+ }
141
+ /**
142
+ * Error patterns for categorization
143
+ * Defined as a class constant for better performance (avoids recreation on every call)
144
+ */
145
+ static ERROR_PATTERNS = [
146
+ {
147
+ patterns: ['EADDRINUSE'],
148
+ create: error => new MatterNetworkError(`Port is already in use: ${error.message}`, { code: 'PORT_IN_USE', recoverable: false }),
149
+ },
150
+ {
151
+ patterns: ['ECONNREFUSED', 'ETIMEDOUT'],
152
+ create: error => new MatterNetworkError(`Connection failed: ${error.message}`, { code: 'CONNECTION_FAILED', recoverable: true }),
153
+ },
154
+ {
155
+ patterns: ['commissioning', 'pairing'],
156
+ create: error => new MatterCommissioningError(`Commissioning error: ${error.message}`, { recoverable: false }),
157
+ },
158
+ {
159
+ patterns: ['storage', 'ENOENT'],
160
+ create: error => new MatterStorageError(`Storage error: ${error.message}`, { recoverable: true }),
161
+ },
162
+ {
163
+ patterns: ['config', 'invalid'],
164
+ create: error => new MatterError(`Configuration error: ${error.message}`, 'CONFIGURATION_ERROR', { recoverable: false, type: MatterErrorType.CONFIGURATION }),
165
+ },
166
+ ];
167
+ /**
168
+ * Categorize error into Matter error types using pattern matching
169
+ * Converts generic Error objects into typed MatterError instances for better handling
170
+ */
171
+ categorizeError(error, context) {
172
+ // If already a typed MatterError, return it
173
+ if (error instanceof MatterError) {
174
+ return error;
175
+ }
176
+ const errorMessage = error.message.toLowerCase();
177
+ // Check message-based patterns first
178
+ for (const { patterns, create } of MatterErrorHandler.ERROR_PATTERNS) {
179
+ if (patterns.some(pattern => errorMessage.includes(pattern.toLowerCase()))) {
180
+ return create(error);
181
+ }
182
+ }
183
+ // Check context-based patterns
184
+ if (context?.includes('sync') || context?.includes('device')) {
185
+ return new MatterDeviceError(`Device sync error: ${error.message}`, { recoverable: true, context });
186
+ }
187
+ if (context?.includes('server')) {
188
+ return new MatterError(`Server error: ${error.message}`, 'SERVER_ERROR', { recoverable: true, type: MatterErrorType.SERVER, context });
189
+ }
190
+ if (context?.includes('init')) {
191
+ return new MatterError(`Initialization error: ${error.message}`, 'INITIALIZATION_ERROR', { recoverable: true, type: MatterErrorType.INITIALIZATION, context });
192
+ }
193
+ // Default to unknown error
194
+ return new MatterError(error.message || 'Unknown Matter error', 'UNKNOWN_ERROR', { recoverable: false, type: MatterErrorType.UNKNOWN, originalError: error });
195
+ }
196
+ /**
197
+ * Log error with appropriate severity
198
+ */
199
+ logError(error) {
200
+ // Get the error type from the details if available, otherwise try to determine it
201
+ const details = error.details;
202
+ const errorType = details?.type || this.getErrorType(error);
203
+ const errorCount = this.errorCount.get(errorType) || 0;
204
+ const recoverable = details?.recoverable !== false;
205
+ if (error instanceof MatterNetworkError) {
206
+ if (details?.code === 'PORT_IN_USE') {
207
+ log.error('Matter port is already in use. Please configure a different port.');
208
+ }
209
+ else {
210
+ log.warn(`Matter network error: ${error.message}`);
211
+ }
212
+ }
213
+ else if (error instanceof MatterCommissioningError) {
214
+ log.info(`Matter commissioning issue: ${error.message}`);
215
+ }
216
+ else if (error instanceof MatterDeviceError) {
217
+ if (errorCount < 3) {
218
+ log.debug(`Device sync error: ${error.message}`);
219
+ }
220
+ else {
221
+ log.warn(`Repeated device sync errors: ${error.message}`);
222
+ }
223
+ }
224
+ else if (error instanceof MatterStorageError) {
225
+ log.warn(`Matter storage error: ${error.message}`);
226
+ }
227
+ else if (error.code === 'CONFIGURATION_ERROR') {
228
+ log.error(`Matter configuration error: ${error.message}`);
229
+ }
230
+ else if (error.code === 'SERVER_ERROR') {
231
+ log.error(`Matter server error: ${error.message}`);
232
+ }
233
+ else if (error.code === 'INITIALIZATION_ERROR') {
234
+ log.error(`Matter initialization error: ${error.message}`);
235
+ }
236
+ else {
237
+ log.error(`Matter error: ${error.message}`);
238
+ }
239
+ // Log stack trace for non-recoverable errors
240
+ if (!recoverable && error.stack) {
241
+ log.debug('Stack trace:', error.stack);
242
+ }
243
+ }
244
+ /**
245
+ * Get error type from MatterError
246
+ */
247
+ getErrorType(error) {
248
+ if (error instanceof MatterNetworkError) {
249
+ return MatterErrorType.NETWORK;
250
+ }
251
+ else if (error instanceof MatterCommissioningError) {
252
+ return MatterErrorType.COMMISSIONING;
253
+ }
254
+ else if (error instanceof MatterDeviceError) {
255
+ return MatterErrorType.DEVICE_SYNC;
256
+ }
257
+ else if (error instanceof MatterStorageError) {
258
+ return MatterErrorType.STORAGE;
259
+ }
260
+ else if (error.code === 'CONFIGURATION_ERROR') {
261
+ return MatterErrorType.CONFIGURATION;
262
+ }
263
+ else if (error.code === 'SERVER_ERROR') {
264
+ return MatterErrorType.SERVER;
265
+ }
266
+ else if (error.code === 'INITIALIZATION_ERROR') {
267
+ return MatterErrorType.INITIALIZATION;
268
+ }
269
+ else {
270
+ return MatterErrorType.UNKNOWN;
271
+ }
272
+ }
273
+ /**
274
+ * Track error occurrences with bounds checking
275
+ */
276
+ trackError(error) {
277
+ // Limit total error types tracked to prevent unbounded growth
278
+ const MAX_ERROR_TYPES = 50;
279
+ const MAX_ERRORS_PER_TYPE = 100;
280
+ const errorType = this.getErrorType(error);
281
+ if (!this.errorCount.has(errorType) && this.errorCount.size >= MAX_ERROR_TYPES) {
282
+ // Remove oldest error type
283
+ const firstKey = this.errorCount.keys().next().value;
284
+ if (firstKey) {
285
+ this.errorCount.delete(firstKey);
286
+ this.lastErrors.delete(firstKey);
287
+ this.recoveryContexts.delete(firstKey);
288
+ this.circuitBreakers.delete(firstKey);
289
+ }
290
+ }
291
+ const count = (this.errorCount.get(error.type) || 0) + 1;
292
+ // Cap error count per type
293
+ this.errorCount.set(error.type, Math.min(count, MAX_ERRORS_PER_TYPE));
294
+ this.lastErrors.set(error.type, error);
295
+ // Auto-cleanup old errors after 1 hour
296
+ setTimeout(() => {
297
+ const currentError = this.lastErrors.get(error.type);
298
+ if (currentError && currentError.timestamp === error.timestamp) {
299
+ this.clearErrors(error.type);
300
+ }
301
+ }, 3600000); // 1 hour
302
+ }
303
+ /**
304
+ * Clear errors for a specific type
305
+ */
306
+ clearErrors(errorType) {
307
+ this.errorCount.delete(errorType);
308
+ this.lastErrors.delete(errorType);
309
+ }
310
+ /**
311
+ * Attempt contextual recovery from error
312
+ */
313
+ async attemptContextualRecovery(error, circuitBreaker) {
314
+ // Get or create recovery context
315
+ let context = this.recoveryContexts.get(error.type);
316
+ if (!context) {
317
+ context = {
318
+ errorType: error.type,
319
+ attemptCount: 0,
320
+ lastAttemptTime: 0,
321
+ backoffMultiplier: 1,
322
+ };
323
+ this.recoveryContexts.set(error.type, context);
324
+ }
325
+ context.attemptCount++;
326
+ context.lastAttemptTime = Date.now();
327
+ const delay = this.getContextualDelay(error.type, context.attemptCount - 1);
328
+ log.info(`Attempting recovery from ${error.type} error (attempt ${context.attemptCount}) in ${delay}ms`);
329
+ // Use global.setTimeout so it can be mocked in tests
330
+ await new Promise(resolve => globalThis.setTimeout(resolve, delay));
331
+ try {
332
+ const callbacks = this.recoveryCallbacks.get(error.type) || [];
333
+ let anySuccess = false;
334
+ for (const callback of callbacks) {
335
+ try {
336
+ await callback();
337
+ anySuccess = true;
338
+ }
339
+ catch (callbackError) {
340
+ log.debug(`Recovery callback failed for ${error.type}:`, callbackError);
341
+ }
342
+ }
343
+ if (anySuccess) {
344
+ circuitBreaker.recordSuccess();
345
+ // Reset context on success
346
+ this.recoveryContexts.delete(error.type);
347
+ this.errorCount.set(error.type, 0);
348
+ log.info(`Recovery successful for ${error.type}`);
349
+ }
350
+ else {
351
+ circuitBreaker.recordFailure();
352
+ // Increase backoff multiplier but don't delete context
353
+ context.backoffMultiplier = Math.min(context.backoffMultiplier * 2, 10);
354
+ // Keep the context so attemptCount persists
355
+ }
356
+ }
357
+ catch (recoveryError) {
358
+ log.error(`Recovery failed for ${error.type}:`, recoveryError);
359
+ circuitBreaker.recordFailure();
360
+ context.backoffMultiplier = Math.min(context.backoffMultiplier * 2, 10);
361
+ // Keep the context so attemptCount persists
362
+ }
363
+ }
364
+ /**
365
+ * Get or create a circuit breaker for an error type
366
+ */
367
+ getOrCreateCircuitBreaker(type) {
368
+ let breaker = this.circuitBreakers.get(type);
369
+ if (!breaker) {
370
+ breaker = new CircuitBreaker();
371
+ this.circuitBreakers.set(type, breaker);
372
+ }
373
+ return breaker;
374
+ }
375
+ /**
376
+ * Check if we should attempt recovery
377
+ */
378
+ shouldAttemptRecovery(error) {
379
+ // Don't attempt recovery for non-recoverable errors
380
+ if (!error.recoverable) {
381
+ return false;
382
+ }
383
+ // Check if we've exceeded max recovery attempts
384
+ const context = this.recoveryContexts.get(error.type);
385
+ return !(context && context.attemptCount >= this.MAX_RECOVERY_ATTEMPTS);
386
+ }
387
+ /**
388
+ * Base delays by error type (in milliseconds)
389
+ * Network errors have longer delays since they often indicate transient network issues
390
+ */
391
+ static BASE_DELAYS = {
392
+ [MatterErrorType.NETWORK]: 5000,
393
+ [MatterErrorType.STORAGE]: 1000,
394
+ [MatterErrorType.DEVICE_SYNC]: 2000,
395
+ [MatterErrorType.DEVICE_ERROR]: 2000,
396
+ [MatterErrorType.COMMISSIONING]: 3000,
397
+ [MatterErrorType.CONFIGURATION]: 1000,
398
+ [MatterErrorType.INITIALIZATION]: 2000,
399
+ [MatterErrorType.SERVER]: 1000,
400
+ [MatterErrorType.UNKNOWN]: 2000,
401
+ };
402
+ /**
403
+ * Get contextual delay based on error type and attempt count
404
+ * Uses exponential backoff with jitter to avoid thundering herd
405
+ */
406
+ getContextualDelay(type, attemptCount) {
407
+ const baseDelay = MatterErrorHandler.BASE_DELAYS[type] ?? 2000;
408
+ // Exponential backoff with max cap of 30 seconds
409
+ const backoffDelay = Math.min(baseDelay * 2 ** attemptCount, 30000);
410
+ // Add random jitter (0-1000ms) to prevent synchronized retries
411
+ const jitter = Math.random() * 1000;
412
+ return backoffDelay + jitter;
413
+ }
414
+ /**
415
+ * Register a recovery callback for specific error type
416
+ */
417
+ registerRecoveryCallback(type, callback) {
418
+ const callbacks = this.recoveryCallbacks.get(type) || [];
419
+ callbacks.push(callback);
420
+ this.recoveryCallbacks.set(type, callbacks);
421
+ }
422
+ /**
423
+ * Reset error counts (useful after successful recovery)
424
+ */
425
+ resetErrorCount(type) {
426
+ if (type) {
427
+ this.errorCount.delete(type);
428
+ this.lastErrors.delete(type);
429
+ this.recoveryContexts.delete(type);
430
+ // Reset circuit breaker
431
+ const circuitBreaker = this.circuitBreakers.get(type);
432
+ if (circuitBreaker) {
433
+ circuitBreaker.reset();
434
+ }
435
+ }
436
+ else {
437
+ this.errorCount.clear();
438
+ this.lastErrors.clear();
439
+ this.recoveryContexts.clear();
440
+ // Reset all circuit breakers
441
+ for (const breaker of this.circuitBreakers.values()) {
442
+ breaker.reset();
443
+ }
444
+ }
445
+ }
446
+ /**
447
+ * Get error statistics
448
+ */
449
+ getErrorStats() {
450
+ const stats = new Map();
451
+ for (const [type, count] of this.errorCount) {
452
+ const lastError = this.lastErrors.get(type);
453
+ const circuitBreaker = this.circuitBreakers.get(type);
454
+ const context = this.recoveryContexts.get(type);
455
+ stats.set(type, {
456
+ count,
457
+ lastError,
458
+ circuitState: circuitBreaker?.getState(),
459
+ recoveryAttempts: context?.attemptCount,
460
+ });
461
+ }
462
+ return stats;
463
+ }
464
+ /**
465
+ * Create a wrapped function with error handling
466
+ */
467
+ wrapAsync(fn, context) {
468
+ return (async (...args) => {
469
+ try {
470
+ return await fn(...args);
471
+ }
472
+ catch (error) {
473
+ await this.handleError(error, context);
474
+ throw error;
475
+ }
476
+ });
477
+ }
478
+ /**
479
+ * Create a wrapped function with error suppression
480
+ */
481
+ wrapAsyncSafe(fn, context, defaultValue) {
482
+ return (async (...args) => {
483
+ try {
484
+ return await fn(...args);
485
+ }
486
+ catch (error) {
487
+ await this.handleError(error, context);
488
+ return defaultValue;
489
+ }
490
+ });
491
+ }
492
+ }
493
+ // Export singleton instance
494
+ export const errorHandler = MatterErrorHandler.getInstance();
495
+ //# sourceMappingURL=matterErrorHandler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"matterErrorHandler.js","sourceRoot":"","sources":["../../src/matter/matterErrorHandler.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,19 @@
1
+ /**
2
+ * Matter.js Log Formatter
3
+ *
4
+ * Formats Matter.js library logs to match the homebridge log format and color scheme.
5
+ * This ensures consistent logging output across Homebridge and Matter.js.
6
+ */
7
+ /**
8
+ * Create a custom log formatter that matches the homebridge format.
9
+ * Format: [timestamp] [Matter:Facility] message
10
+ * Timestamp format matches system locale (via toLocaleString()).
11
+ *
12
+ * Log level color mapping:
13
+ * - Matter DEBUG/INFO → gray (Homebridge debug)
14
+ * - Matter NOTICE → no color (Homebridge info)
15
+ * - Matter WARN → yellow (Homebridge warn)
16
+ * - Matter ERROR/FATAL → red (Homebridge error)
17
+ */
18
+ export declare function createHomebridgeLogFormatter(): (diagnostic: unknown) => string;
19
+ //# sourceMappingURL=matterLogFormatter.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"matterLogFormatter.d.ts","sourceRoot":"","sources":["../../src/matter/matterLogFormatter.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAOH;;;;;;;;;;GAUG;AACH,wBAAgB,4BAA4B,IAAI,CAAC,UAAU,EAAE,OAAO,KAAK,MAAM,CA2D9E"}