homebridge 2.0.0-alpha.5 → 2.0.0-alpha.50

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 (105) hide show
  1. package/README.md +1 -1
  2. package/bin/homebridge.js +22 -0
  3. package/dist/api.d.ts +219 -3
  4. package/dist/api.d.ts.map +1 -1
  5. package/dist/api.js +79 -0
  6. package/dist/api.js.map +1 -1
  7. package/dist/bridgeService.d.ts +10 -3
  8. package/dist/bridgeService.d.ts.map +1 -1
  9. package/dist/bridgeService.js +9 -5
  10. package/dist/bridgeService.js.map +1 -1
  11. package/dist/childBridgeFork.d.ts +17 -2
  12. package/dist/childBridgeFork.d.ts.map +1 -1
  13. package/dist/childBridgeFork.js +161 -4
  14. package/dist/childBridgeFork.js.map +1 -1
  15. package/dist/childBridgeService.d.ts +21 -0
  16. package/dist/childBridgeService.d.ts.map +1 -1
  17. package/dist/childBridgeService.js +72 -25
  18. package/dist/childBridgeService.js.map +1 -1
  19. package/dist/cli.d.ts.map +1 -1
  20. package/dist/cli.js +3 -2
  21. package/dist/cli.js.map +1 -1
  22. package/dist/externalPortService.js.map +1 -1
  23. package/dist/index.d.ts +48 -2
  24. package/dist/index.d.ts.map +1 -1
  25. package/dist/index.js +15 -0
  26. package/dist/index.js.map +1 -1
  27. package/dist/ipcService.d.ts +20 -0
  28. package/dist/ipcService.d.ts.map +1 -1
  29. package/dist/ipcService.js.map +1 -1
  30. package/dist/logger.d.ts +6 -0
  31. package/dist/logger.d.ts.map +1 -1
  32. package/dist/logger.js +8 -0
  33. package/dist/logger.js.map +1 -1
  34. package/dist/matter/index.d.ts +51 -0
  35. package/dist/matter/index.d.ts.map +1 -0
  36. package/dist/matter/index.js +11 -0
  37. package/dist/matter/index.js.map +1 -0
  38. package/dist/matter/matterAccessoryCache.d.ts +77 -0
  39. package/dist/matter/matterAccessoryCache.d.ts.map +1 -0
  40. package/dist/matter/matterAccessoryCache.js +176 -0
  41. package/dist/matter/matterAccessoryCache.js.map +1 -0
  42. package/dist/matter/matterBehaviors.d.ts +127 -0
  43. package/dist/matter/matterBehaviors.d.ts.map +1 -0
  44. package/dist/matter/matterBehaviors.js +611 -0
  45. package/dist/matter/matterBehaviors.js.map +1 -0
  46. package/dist/matter/matterConfigValidator.d.ts +81 -0
  47. package/dist/matter/matterConfigValidator.d.ts.map +1 -0
  48. package/dist/matter/matterConfigValidator.js +240 -0
  49. package/dist/matter/matterConfigValidator.js.map +1 -0
  50. package/dist/matter/matterErrorHandler.d.ts +94 -0
  51. package/dist/matter/matterErrorHandler.d.ts.map +1 -0
  52. package/dist/matter/matterErrorHandler.js +485 -0
  53. package/dist/matter/matterErrorHandler.js.map +1 -0
  54. package/dist/matter/matterLogFormatter.d.ts +18 -0
  55. package/dist/matter/matterLogFormatter.d.ts.map +1 -0
  56. package/dist/matter/matterLogFormatter.js +128 -0
  57. package/dist/matter/matterLogFormatter.js.map +1 -0
  58. package/dist/matter/matterNetworkMonitor.d.ts +68 -0
  59. package/dist/matter/matterNetworkMonitor.d.ts.map +1 -0
  60. package/dist/matter/matterNetworkMonitor.js +250 -0
  61. package/dist/matter/matterNetworkMonitor.js.map +1 -0
  62. package/dist/matter/matterServer.d.ts +283 -0
  63. package/dist/matter/matterServer.d.ts.map +1 -0
  64. package/dist/matter/matterServer.js +1416 -0
  65. package/dist/matter/matterServer.js.map +1 -0
  66. package/dist/matter/matterSharedTypes.d.ts +165 -0
  67. package/dist/matter/matterSharedTypes.d.ts.map +1 -0
  68. package/dist/matter/matterSharedTypes.js +51 -0
  69. package/dist/matter/matterSharedTypes.js.map +1 -0
  70. package/dist/matter/matterStorage.d.ts +126 -0
  71. package/dist/matter/matterStorage.d.ts.map +1 -0
  72. package/dist/matter/matterStorage.js +419 -0
  73. package/dist/matter/matterStorage.js.map +1 -0
  74. package/dist/matter/matterTypes.d.ts +250 -0
  75. package/dist/matter/matterTypes.d.ts.map +1 -0
  76. package/dist/matter/matterTypes.js +142 -0
  77. package/dist/matter/matterTypes.js.map +1 -0
  78. package/dist/platformAccessory.d.ts +1 -0
  79. package/dist/platformAccessory.d.ts.map +1 -1
  80. package/dist/platformAccessory.js +8 -1
  81. package/dist/platformAccessory.js.map +1 -1
  82. package/dist/plugin.d.ts +0 -1
  83. package/dist/plugin.d.ts.map +1 -1
  84. package/dist/plugin.js +9 -12
  85. package/dist/plugin.js.map +1 -1
  86. package/dist/pluginManager.d.ts.map +1 -1
  87. package/dist/pluginManager.js +22 -21
  88. package/dist/pluginManager.js.map +1 -1
  89. package/dist/server.d.ts +16 -1
  90. package/dist/server.d.ts.map +1 -1
  91. package/dist/server.js +276 -8
  92. package/dist/server.js.map +1 -1
  93. package/dist/storageService.js +8 -8
  94. package/dist/storageService.js.map +1 -1
  95. package/dist/user.d.ts +1 -0
  96. package/dist/user.d.ts.map +1 -1
  97. package/dist/user.js +10 -7
  98. package/dist/user.js.map +1 -1
  99. package/dist/util/mac.d.ts.map +1 -1
  100. package/dist/util/mac.js +2 -2
  101. package/dist/util/mac.js.map +1 -1
  102. package/dist/version.js +2 -2
  103. package/dist/version.js.map +1 -1
  104. package/package.json +25 -26
  105. package/bin/homebridge +0 -19
@@ -0,0 +1,419 @@
1
+ /* global NodeJS */
2
+ /**
3
+ * Custom Matter.js Storage Implementation for Homebridge
4
+ *
5
+ * Provides persistent storage for Matter fabric data and device configuration.
6
+ * This ensures commissioning data persists across Homebridge restarts.
7
+ */
8
+ import { Buffer } from 'node:buffer';
9
+ import * as fs from 'node:fs';
10
+ import * as fsp from 'node:fs/promises';
11
+ import * as path from 'node:path';
12
+ import { Logger } from '../logger.js';
13
+ const log = Logger.withPrefix('Matter/Storage');
14
+ // Storage configuration constants
15
+ const STORAGE_WRITE_DEBOUNCE_MS = 100; // Delay for non-critical writes
16
+ /**
17
+ * Custom Matter.js StorageContext implementation for Homebridge
18
+ * Provides persistent storage for fabric data and device configuration
19
+ */
20
+ export class HomebridgeMatterStorage {
21
+ namespace;
22
+ storage = new Map();
23
+ filePath;
24
+ isInitialized = false;
25
+ writeTimer = null;
26
+ pendingWrite = false;
27
+ persistLock = null;
28
+ constructor(namespace, storagePath) {
29
+ this.namespace = namespace;
30
+ this.filePath = path.join(storagePath, `${namespace}.json`);
31
+ // Synchronously load existing data to avoid race conditions with Matter.js
32
+ // Matter.js expects storage to be immediately available
33
+ this.initializeSync();
34
+ }
35
+ /**
36
+ * Synchronously initialize storage by loading existing data
37
+ * This is called in the constructor to ensure storage is ready immediately
38
+ */
39
+ initializeSync() {
40
+ try {
41
+ const fileContent = fs.readFileSync(this.filePath, 'utf-8');
42
+ // Parse WITHOUT a reviver - we'll deserialize manually
43
+ const data = JSON.parse(fileContent);
44
+ // Ensure data is valid before loading
45
+ if (data && typeof data === 'object') {
46
+ // Deserialize ALL values as we load them into the Map
47
+ const entries = Object.entries(data).map(([key, value]) => [
48
+ key,
49
+ this.deserializeValue(value),
50
+ ]);
51
+ this.storage = new Map(entries);
52
+ log.debug(`Loaded ${this.storage.size} entries for namespace: ${this.namespace}`);
53
+ }
54
+ else {
55
+ log.warn(`Invalid storage data for ${this.namespace}, starting fresh`);
56
+ this.storage = new Map();
57
+ }
58
+ this.isInitialized = true;
59
+ }
60
+ catch (error) {
61
+ if (error.code === 'ENOENT') {
62
+ log.debug(`No existing storage for namespace: ${this.namespace}`);
63
+ }
64
+ else {
65
+ log.warn(`Failed to load storage for ${this.namespace} (${error.message}), starting fresh`);
66
+ }
67
+ // Create fresh storage if file doesn't exist or is corrupted
68
+ this.storage = new Map();
69
+ this.isInitialized = true;
70
+ }
71
+ }
72
+ /**
73
+ * Initialize storage and load existing data (async for compatibility)
74
+ * Note: Storage is now initialized synchronously in constructor
75
+ */
76
+ async initialize() {
77
+ // Storage is already initialized in constructor
78
+ return Promise.resolve();
79
+ }
80
+ /**
81
+ * Build a context key from an array of contexts
82
+ */
83
+ buildContextKey(contexts) {
84
+ return contexts.join('.');
85
+ }
86
+ /**
87
+ * Recursively convert special serialized types back to their original types
88
+ *
89
+ * This is necessary because JSON.parse() doesn't automatically reconstruct:
90
+ * - BigInt values (serialized as {__type: 'bigint', value: string})
91
+ * - Uint8Array values (serialized as {__type: 'Uint8Array', value: number[]})
92
+ * - Buffer values (Node.js format: {type: 'Buffer', data: number[]})
93
+ *
94
+ * Matter.js fabric data contains these types which must be properly restored
95
+ * for commissioning to work across restarts.
96
+ *
97
+ * @param value - The value to deserialize (might be nested object/array)
98
+ * @returns The deserialized value with proper types restored
99
+ */
100
+ deserializeValue(value) {
101
+ if (value && typeof value === 'object') {
102
+ // Handle special type markers
103
+ const obj = value;
104
+ if (obj.__type === 'bigint' && typeof obj.value === 'string') {
105
+ return BigInt(obj.value);
106
+ }
107
+ if (obj.__type === 'Uint8Array' && Array.isArray(obj.value)) {
108
+ return new Uint8Array(obj.value);
109
+ }
110
+ // Handle Node.js Buffer JSON format: {type: "Buffer", data: [...]}
111
+ if (obj.type === 'Buffer' && Array.isArray(obj.data)) {
112
+ return new Uint8Array(obj.data);
113
+ }
114
+ // Recursively process arrays
115
+ if (Array.isArray(value)) {
116
+ return value.map(item => this.deserializeValue(item));
117
+ }
118
+ // Recursively process plain objects
119
+ if (Object.getPrototypeOf(value) === Object.prototype) {
120
+ const result = {};
121
+ for (const [k, v] of Object.entries(value)) {
122
+ result[k] = this.deserializeValue(v);
123
+ }
124
+ return result;
125
+ }
126
+ }
127
+ return value;
128
+ }
129
+ /**
130
+ * Get a value from storage (Matter.js interface)
131
+ */
132
+ get(contexts, key) {
133
+ // Storage is initialized in constructor, so this should always work
134
+ const fullKey = contexts.length ? `${this.buildContextKey(contexts)}.${key}` : key;
135
+ const value = this.storage.get(fullKey);
136
+ // Ensure value is fully deserialized (handles nested special types)
137
+ return this.deserializeValue(value);
138
+ }
139
+ set(contexts, keyOrValues, value) {
140
+ const contextKey = this.buildContextKey(contexts);
141
+ if (typeof keyOrValues === 'string') {
142
+ const fullKey = contextKey ? `${contextKey}.${keyOrValues}` : keyOrValues;
143
+ this.storage.set(fullKey, value);
144
+ }
145
+ else {
146
+ for (const [k, v] of Object.entries(keyOrValues)) {
147
+ const fullKey = contextKey ? `${contextKey}.${k}` : k;
148
+ this.storage.set(fullKey, v);
149
+ }
150
+ }
151
+ // Debounce writes to avoid excessive disk I/O
152
+ void this.schedulePersist();
153
+ }
154
+ /**
155
+ * Delete a key from storage (Matter.js interface)
156
+ */
157
+ delete(contexts, key) {
158
+ const fullKey = contexts.length ? `${this.buildContextKey(contexts)}.${key}` : key;
159
+ const deleted = this.storage.delete(fullKey);
160
+ if (deleted) {
161
+ void this.schedulePersist();
162
+ }
163
+ }
164
+ /**
165
+ * Clear all storage in a context (Matter.js interface)
166
+ */
167
+ clearAll(contexts) {
168
+ const contextKey = this.buildContextKey(contexts);
169
+ const prefix = contextKey ? `${contextKey}.` : '';
170
+ // Collect keys to delete first to avoid modifying during iteration
171
+ const keysToDelete = [];
172
+ for (const key of this.storage.keys()) {
173
+ if (!prefix || key.startsWith(prefix)) {
174
+ keysToDelete.push(key);
175
+ }
176
+ }
177
+ // Delete collected keys
178
+ for (const key of keysToDelete) {
179
+ this.storage.delete(key);
180
+ }
181
+ if (keysToDelete.length > 0) {
182
+ void this.schedulePersist();
183
+ }
184
+ }
185
+ /**
186
+ * Get all keys in a context (Matter.js interface)
187
+ */
188
+ keys(contexts) {
189
+ if (!this.isInitialized) {
190
+ return [];
191
+ }
192
+ const contextKey = this.buildContextKey(contexts);
193
+ const prefix = contextKey ? `${contextKey}.` : '';
194
+ const contextKeys = [];
195
+ for (const key of this.storage.keys()) {
196
+ if (prefix) {
197
+ // Return keys within this context (strip context prefix)
198
+ if (key.startsWith(prefix)) {
199
+ const subKey = key.substring(prefix.length);
200
+ // Only include direct children (no further nesting)
201
+ if (!subKey.includes('.')) {
202
+ contextKeys.push(subKey);
203
+ }
204
+ }
205
+ }
206
+ else {
207
+ // Root level - return keys with no dots
208
+ if (!key.includes('.')) {
209
+ contextKeys.push(key);
210
+ }
211
+ }
212
+ }
213
+ return contextKeys;
214
+ }
215
+ /**
216
+ * Get all child context names (Matter.js interface)
217
+ */
218
+ contexts(contexts) {
219
+ if (!this.isInitialized) {
220
+ return [];
221
+ }
222
+ const contextKey = this.buildContextKey(contexts);
223
+ const prefix = contextKey ? `${contextKey}.` : '';
224
+ const childContexts = new Set();
225
+ for (const key of this.storage.keys()) {
226
+ if (prefix) {
227
+ // Find sub-contexts within this context
228
+ if (key.startsWith(prefix)) {
229
+ const subKey = key.substring(prefix.length);
230
+ const nextDot = subKey.indexOf('.');
231
+ if (nextDot > 0) {
232
+ childContexts.add(subKey.substring(0, nextDot));
233
+ }
234
+ }
235
+ }
236
+ else {
237
+ // Root level - find top-level contexts
238
+ const dotIndex = key.indexOf('.');
239
+ if (dotIndex > 0) {
240
+ childContexts.add(key.substring(0, dotIndex));
241
+ }
242
+ }
243
+ }
244
+ return Array.from(childContexts);
245
+ }
246
+ /**
247
+ * Check if a key exists (Matter.js interface)
248
+ */
249
+ has(contexts, key) {
250
+ if (!this.isInitialized) {
251
+ return false;
252
+ }
253
+ const fullKey = contexts.length ? `${this.buildContextKey(contexts)}.${key}` : key;
254
+ return this.storage.has(fullKey);
255
+ }
256
+ /**
257
+ * Get all values in a context
258
+ */
259
+ async values(contexts) {
260
+ await this.initialize();
261
+ const contextKey = this.buildContextKey(contexts);
262
+ const prefix = contextKey ? `${contextKey}.` : '';
263
+ const values = {};
264
+ for (const [key, value] of this.storage.entries()) {
265
+ if (prefix) {
266
+ if (key.startsWith(prefix)) {
267
+ const subKey = key.substring(prefix.length);
268
+ if (!subKey.includes('.')) {
269
+ values[subKey] = this.deserializeValue(value);
270
+ }
271
+ }
272
+ }
273
+ else {
274
+ if (!key.includes('.')) {
275
+ values[key] = this.deserializeValue(value);
276
+ }
277
+ }
278
+ }
279
+ return values;
280
+ }
281
+ /**
282
+ * Schedule a persist operation (debounced)
283
+ */
284
+ async schedulePersist() {
285
+ if (this.writeTimer) {
286
+ clearTimeout(this.writeTimer);
287
+ }
288
+ this.pendingWrite = true;
289
+ // Immediate persist for critical data (fabric information)
290
+ const hasCriticalData = Array.from(this.storage.keys()).some(key => key.includes('fabric'));
291
+ if (hasCriticalData) {
292
+ await this.persist();
293
+ }
294
+ else {
295
+ // Debounce non-critical writes
296
+ this.writeTimer = setTimeout(() => {
297
+ void this.persist();
298
+ }, STORAGE_WRITE_DEBOUNCE_MS);
299
+ }
300
+ }
301
+ /**
302
+ * Persist storage to disk with atomic write
303
+ */
304
+ async persist() {
305
+ // Wait for any in-progress persist operation to complete
306
+ if (this.persistLock) {
307
+ await this.persistLock;
308
+ }
309
+ if (!this.pendingWrite) {
310
+ return;
311
+ }
312
+ // Create a new lock for this persist operation
313
+ this.persistLock = (async () => {
314
+ try {
315
+ const data = Object.fromEntries(this.storage.entries());
316
+ const dir = path.dirname(this.filePath);
317
+ // Ensure directory exists
318
+ await fsp.mkdir(dir, { recursive: true });
319
+ // Atomic write: write to temp file then rename
320
+ // Use a unique temp file to avoid conflicts
321
+ const tempFile = `${this.filePath}.tmp.${Date.now()}`;
322
+ // Custom replacer to handle BigInt, Uint8Array, and Buffer serialization
323
+ const jsonString = JSON.stringify(data, (_key, value) => {
324
+ if (typeof value === 'bigint') {
325
+ return { __type: 'bigint', value: value.toString() };
326
+ }
327
+ // Handle Buffer before Uint8Array since Buffer extends Uint8Array
328
+ // Note: Buffer.toJSON() returns {type: 'Buffer', data: [...]}, but we want consistent format
329
+ if (Buffer.isBuffer(value)) {
330
+ return { __type: 'Uint8Array', value: Array.from(value) };
331
+ }
332
+ if (value instanceof Uint8Array) {
333
+ return { __type: 'Uint8Array', value: Array.from(value) };
334
+ }
335
+ return value;
336
+ }, 2);
337
+ await fsp.writeFile(tempFile, jsonString, 'utf-8');
338
+ await fsp.rename(tempFile, this.filePath);
339
+ this.pendingWrite = false;
340
+ log.debug(`Persisted ${this.storage.size} entries for namespace: ${this.namespace}`);
341
+ }
342
+ catch (error) {
343
+ log.error(`Failed to persist storage for ${this.namespace}:`, error);
344
+ // Don't throw - we don't want to break Matter operations
345
+ }
346
+ finally {
347
+ this.persistLock = null;
348
+ }
349
+ })();
350
+ await this.persistLock;
351
+ }
352
+ /**
353
+ * Force immediate persist (for shutdown)
354
+ */
355
+ async forcePersist() {
356
+ if (this.writeTimer) {
357
+ clearTimeout(this.writeTimer);
358
+ this.writeTimer = null;
359
+ }
360
+ if (this.pendingWrite) {
361
+ await this.persist();
362
+ }
363
+ }
364
+ /**
365
+ * Close and cleanup storage
366
+ */
367
+ async close() {
368
+ await this.forcePersist();
369
+ this.storage.clear();
370
+ this.isInitialized = false;
371
+ }
372
+ /**
373
+ * Get storage statistics
374
+ */
375
+ getStats() {
376
+ return {
377
+ entries: this.storage.size,
378
+ namespace: this.namespace,
379
+ path: this.filePath,
380
+ };
381
+ }
382
+ }
383
+ /**
384
+ * Storage Manager for Matter.js
385
+ * Manages multiple storage contexts for different namespaces
386
+ */
387
+ export class MatterStorageManager {
388
+ storagePath;
389
+ storages = new Map();
390
+ constructor(storagePath) {
391
+ this.storagePath = storagePath;
392
+ }
393
+ /**
394
+ * Get or create a storage context for a namespace
395
+ */
396
+ getStorage(namespace) {
397
+ let storage = this.storages.get(namespace);
398
+ if (!storage) {
399
+ storage = new HomebridgeMatterStorage(namespace, this.storagePath);
400
+ this.storages.set(namespace, storage);
401
+ }
402
+ return storage;
403
+ }
404
+ /**
405
+ * Close all storage contexts
406
+ */
407
+ async closeAll() {
408
+ const promises = Array.from(this.storages.values()).map(storage => storage.close());
409
+ await Promise.all(promises);
410
+ this.storages.clear();
411
+ }
412
+ /**
413
+ * Get statistics for all storage contexts
414
+ */
415
+ getAllStats() {
416
+ return Array.from(this.storages.values()).map(storage => storage.getStats());
417
+ }
418
+ }
419
+ //# sourceMappingURL=matterStorage.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"matterStorage.js","sourceRoot":"","sources":["../../src/matter/matterStorage.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,250 @@
1
+ /**
2
+ * Matter Types for Homebridge Plugin API
3
+ *
4
+ * This module provides types and interfaces for plugin developers
5
+ * to create Matter-compatible accessories.
6
+ */
7
+ import type { Endpoint, EndpointType } from '@matter/main';
8
+ import * as clusters from '@matter/main/clusters';
9
+ import * as devices from '@matter/main/devices';
10
+ /**
11
+ * Matter command handler function type
12
+ *
13
+ * Handlers can be synchronous or asynchronous (returning a Promise).
14
+ * The args parameter contains the command arguments passed by Matter.js (optional).
15
+ */
16
+ export type MatterCommandHandler<TArgs = unknown> = (args?: TArgs) => Promise<void> | void;
17
+ /**
18
+ * Matter cluster handlers interface
19
+ *
20
+ * Maps command names to their handler functions.
21
+ * Each command can have custom argument types.
22
+ */
23
+ export interface MatterClusterHandlers {
24
+ [commandName: string]: MatterCommandHandler<any>;
25
+ }
26
+ /**
27
+ * Matter Accessory - Plugin API Interface
28
+ *
29
+ * This is the main interface that plugin developers use to register
30
+ * Matter accessories with Homebridge.
31
+ */
32
+ export interface MatterAccessory<T = Record<string, any>> {
33
+ /** Unique identifier for this accessory (must be unique across all accessories) */
34
+ uuid: string;
35
+ /** Display name for the accessory */
36
+ displayName: string;
37
+ /** Matter device type (e.g., OnOffLightDevice, DimmableLightDevice, etc.) */
38
+ deviceType: EndpointType;
39
+ /** Serial number for the device */
40
+ serialNumber: string;
41
+ /** Manufacturer name */
42
+ manufacturer: string;
43
+ /** Model name/identifier */
44
+ model: string;
45
+ /** Firmware revision (optional) */
46
+ firmwareRevision?: string;
47
+ /** Hardware revision (optional) */
48
+ hardwareRevision?: string;
49
+ /** Software version (optional) */
50
+ softwareVersion?: string;
51
+ /**
52
+ * Plugin developer storage - persists across restarts
53
+ * This is a way for plugin developers to store custom data with their accessory
54
+ * Similar to `PlatformAccessory.context` for HAP accessories
55
+ */
56
+ context?: T;
57
+ /**
58
+ * Initial cluster states
59
+ * Key is the cluster name, value is an object of attribute name -> value
60
+ *
61
+ * Example:
62
+ * {
63
+ * onOff: { onOff: true },
64
+ * levelControl: { currentLevel: 127, minLevel: 1, maxLevel: 254 }
65
+ * }
66
+ */
67
+ clusters: {
68
+ [clusterName: string]: {
69
+ [attributeName: string]: unknown;
70
+ };
71
+ };
72
+ /**
73
+ * Handlers for Matter commands (Home app → Device)
74
+ *
75
+ * These handlers are called when a user controls the accessory via the Home app.
76
+ * Use handlers to send commands to your actual device (cloud API, local network, etc.).
77
+ */
78
+ handlers?: {
79
+ [clusterName: string]: MatterClusterHandlers;
80
+ };
81
+ /**
82
+ * Optional: Get current state handler
83
+ * Called when a Matter controller reads an attribute
84
+ * If not provided, the last set value is returned
85
+ */
86
+ getState?: (cluster: string, attribute: string) => Promise<any> | any;
87
+ }
88
+ /**
89
+ * Matter Configuration (for bridge or child bridge)
90
+ */
91
+ export interface MatterConfig extends Record<string, unknown> {
92
+ /** Port for Matter server (optional, will auto-assign if not specified) */
93
+ port?: number;
94
+ /** Name for the Matter bridge (optional) */
95
+ name?: string;
96
+ }
97
+ /**
98
+ * Matter Fabric Information
99
+ * Represents a commissioned controller (fabric) on the Matter bridge
100
+ */
101
+ export interface MatterFabricInfo {
102
+ fabricIndex: number;
103
+ fabricId: string;
104
+ nodeId: string;
105
+ rootVendorId: number;
106
+ label?: string;
107
+ }
108
+ /**
109
+ * Matter Server Events
110
+ * Event types emitted by the Matter server for commissioning lifecycle
111
+ */
112
+ export interface MatterServerEvents {
113
+ /** Emitted when the bridge is commissioned for the first time */
114
+ 'commissioned': (fabricInfo: MatterFabricInfo) => void;
115
+ /** Emitted when the last fabric is removed (bridge becomes uncommissioned) */
116
+ 'decommissioned': () => void;
117
+ /** Emitted when a new fabric (controller) is added */
118
+ 'fabric-added': (fabricInfo: MatterFabricInfo) => void;
119
+ /** Emitted when a fabric (controller) is removed */
120
+ 'fabric-removed': (fabricInfo: MatterFabricInfo) => void;
121
+ /** Emitted whenever commissioning state changes (any fabric added/removed) */
122
+ 'commissioning-changed': (commissioned: boolean, fabricCount: number) => void;
123
+ /** Emitted when an accessory is registered */
124
+ 'accessory-registered': (accessory: MatterAccessory) => void;
125
+ /** Emitted when an accessory is unregistered */
126
+ 'accessory-unregistered': (uuid: string) => void;
127
+ }
128
+ /**
129
+ * Internal Matter accessory representation
130
+ * (Used internally by MatterServer)
131
+ */
132
+ export interface InternalMatterAccessory extends MatterAccessory {
133
+ _associatedPlugin?: string;
134
+ _associatedPlatform?: string;
135
+ endpoint?: Endpoint;
136
+ registered: boolean;
137
+ }
138
+ /**
139
+ * Matter error type enum (for error handler categorization)
140
+ */
141
+ export declare enum MatterErrorType {
142
+ INITIALIZATION = "INITIALIZATION",
143
+ NETWORK = "NETWORK",
144
+ COMMISSIONING = "COMMISSIONING",
145
+ DEVICE_SYNC = "DEVICE_SYNC",
146
+ SERVER = "SERVER",
147
+ STORAGE = "STORAGE",
148
+ CONFIGURATION = "CONFIGURATION",
149
+ DEVICE_ERROR = "DEVICE_ERROR",
150
+ UNKNOWN = "UNKNOWN"
151
+ }
152
+ /**
153
+ * Matter error details interface
154
+ */
155
+ export interface MatterErrorDetails {
156
+ type?: MatterErrorType;
157
+ recoverable?: boolean;
158
+ code?: string;
159
+ context?: string;
160
+ originalError?: Error;
161
+ }
162
+ /**
163
+ * Matter error types
164
+ */
165
+ export declare class MatterError extends Error {
166
+ readonly code: string;
167
+ readonly details?: MatterErrorDetails | undefined;
168
+ readonly type: MatterErrorType;
169
+ readonly timestamp: Date;
170
+ readonly recoverable: boolean;
171
+ constructor(message: string, code: string, details?: MatterErrorDetails | undefined, type?: MatterErrorType, recoverable?: boolean);
172
+ }
173
+ export declare class MatterCommissioningError extends MatterError {
174
+ constructor(message: string, details?: MatterErrorDetails);
175
+ }
176
+ export declare class MatterStorageError extends MatterError {
177
+ constructor(message: string, details?: MatterErrorDetails);
178
+ }
179
+ export declare class MatterDeviceError extends MatterError {
180
+ constructor(message: string, details?: MatterErrorDetails);
181
+ }
182
+ export declare class MatterNetworkError extends MatterError {
183
+ constructor(message: string, details?: MatterErrorDetails);
184
+ }
185
+ export { clusters };
186
+ export { devices };
187
+ /**
188
+ * Friendly device type names for the Plugin API
189
+ * Maps simplified names to actual Matter.js device types
190
+ */
191
+ export declare const deviceTypes: {
192
+ readonly OnOffLight: devices.OnOffLightDevice;
193
+ readonly DimmableLight: devices.DimmableLightDevice;
194
+ readonly ColorTemperatureLight: devices.ColorTemperatureLightDevice;
195
+ readonly ExtendedColorLight: devices.ExtendedColorLightDevice;
196
+ readonly OnOffSwitch: devices.OnOffLightSwitchDevice;
197
+ readonly OnOffOutlet: devices.OnOffPlugInUnitDevice;
198
+ readonly DimmableOutlet: devices.DimmablePlugInUnitDevice;
199
+ readonly TemperatureSensor: devices.TemperatureSensorDevice;
200
+ readonly HumiditySensor: devices.HumiditySensorDevice;
201
+ readonly LightSensor: devices.LightSensorDevice;
202
+ readonly MotionSensor: devices.OccupancySensorDevice;
203
+ readonly ContactSensor: devices.ContactSensorDevice;
204
+ readonly LeakSensor: devices.WaterLeakDetectorDevice;
205
+ readonly SmokeSensor: devices.SmokeCoAlarmDevice;
206
+ readonly Thermostat: devices.ThermostatDevice;
207
+ readonly Fan: devices.FanDevice;
208
+ readonly DoorLock: devices.DoorLockDevice;
209
+ readonly WindowCovering: devices.WindowCoveringDevice;
210
+ readonly GenericSwitch: devices.GenericSwitchDevice;
211
+ readonly Pump: devices.PumpDevice;
212
+ readonly RoomAirConditioner: devices.RoomAirConditionerDevice;
213
+ };
214
+ /**
215
+ * Matter Cluster Names
216
+ * Commonly used cluster names for type safety and autocomplete
217
+ * Use these with api.updateMatterAccessoryState() and api.getAccessoryState()
218
+ *
219
+ * @example
220
+ * ```typescript
221
+ * // With autocomplete and type safety:
222
+ * api.updateMatterAccessoryState(uuid, api.matterClusterNames.OnOff, { onOff: true })
223
+ * api.getAccessoryState(uuid, api.matterClusterNames.LevelControl)
224
+ * ```
225
+ */
226
+ export declare const clusterNames: {
227
+ readonly OnOff: "onOff";
228
+ readonly LevelControl: "levelControl";
229
+ readonly ColorControl: "colorControl";
230
+ readonly DoorLock: "doorLock";
231
+ readonly WindowCovering: "windowCovering";
232
+ readonly Thermostat: "thermostat";
233
+ readonly FanControl: "fanControl";
234
+ readonly TemperatureMeasurement: "temperatureMeasurement";
235
+ readonly RelativeHumidityMeasurement: "relativeHumidityMeasurement";
236
+ readonly IlluminanceMeasurement: "illuminanceMeasurement";
237
+ readonly OccupancySensing: "occupancySensing";
238
+ readonly BooleanState: "booleanState";
239
+ readonly SmokeCoAlarm: "smokeCoAlarm";
240
+ readonly PumpConfigurationAndControl: "pumpConfigurationAndControl";
241
+ readonly Identify: "identify";
242
+ readonly BasicInformation: "basicInformation";
243
+ readonly BridgedDeviceBasicInformation: "bridgedDeviceBasicInformation";
244
+ };
245
+ /**
246
+ * Type for Matter cluster names
247
+ * Provides type safety for cluster name strings
248
+ */
249
+ export type MatterClusterName = typeof clusterNames[keyof typeof clusterNames];
250
+ //# sourceMappingURL=matterTypes.d.ts.map