matterbridge 3.0.6 → 3.0.7-dev-20250614-0d145a8

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 (183) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/dist/cli.js +2 -62
  3. package/dist/cluster/export.js +0 -2
  4. package/dist/defaultConfigSchema.js +0 -23
  5. package/dist/deviceManager.js +1 -94
  6. package/dist/evse.js +9 -65
  7. package/dist/frontend.js +16 -374
  8. package/dist/globalMatterbridge.js +0 -20
  9. package/dist/helpers.js +0 -51
  10. package/dist/index.js +1 -28
  11. package/dist/laundryWasher.js +7 -92
  12. package/dist/logger/export.js +0 -1
  13. package/dist/matter/behaviors.js +0 -2
  14. package/dist/matter/clusters.js +0 -2
  15. package/dist/matter/devices.js +0 -2
  16. package/dist/matter/endpoints.js +0 -2
  17. package/dist/matter/export.js +0 -2
  18. package/dist/matter/types.js +0 -2
  19. package/dist/matterbridge.js +46 -748
  20. package/dist/matterbridgeAccessoryPlatform.js +0 -34
  21. package/dist/matterbridgeBehaviors.js +1 -54
  22. package/dist/matterbridgeDeviceTypes.js +15 -578
  23. package/dist/matterbridgeDynamicPlatform.js +0 -34
  24. package/dist/matterbridgeEndpoint.js +43 -997
  25. package/dist/matterbridgeEndpointHelpers.js +10 -204
  26. package/dist/matterbridgePlatform.js +7 -225
  27. package/dist/matterbridgeTypes.js +0 -24
  28. package/dist/pluginManager.js +3 -269
  29. package/dist/roboticVacuumCleaner.js +6 -81
  30. package/dist/shelly.js +7 -155
  31. package/dist/storage/export.js +0 -1
  32. package/dist/update.js +0 -53
  33. package/dist/utils/colorUtils.js +2 -205
  34. package/dist/utils/commandLine.js +0 -53
  35. package/dist/utils/copyDirectory.js +1 -37
  36. package/dist/utils/createDirectory.js +0 -31
  37. package/dist/utils/createZip.js +2 -42
  38. package/dist/utils/deepCopy.js +0 -38
  39. package/dist/utils/deepEqual.js +1 -71
  40. package/dist/utils/export.js +0 -1
  41. package/dist/utils/hex.js +0 -57
  42. package/dist/utils/isvalid.js +0 -100
  43. package/dist/utils/network.js +5 -76
  44. package/dist/utils/spawn.js +0 -16
  45. package/dist/utils/wait.js +9 -58
  46. package/dist/waterHeater.js +2 -62
  47. package/npm-shrinkwrap.json +40 -28
  48. package/package.json +2 -3
  49. package/dist/cli.d.ts +0 -29
  50. package/dist/cli.d.ts.map +0 -1
  51. package/dist/cli.js.map +0 -1
  52. package/dist/cluster/export.d.ts +0 -2
  53. package/dist/cluster/export.d.ts.map +0 -1
  54. package/dist/cluster/export.js.map +0 -1
  55. package/dist/defaultConfigSchema.d.ts +0 -27
  56. package/dist/defaultConfigSchema.d.ts.map +0 -1
  57. package/dist/defaultConfigSchema.js.map +0 -1
  58. package/dist/deviceManager.d.ts +0 -114
  59. package/dist/deviceManager.d.ts.map +0 -1
  60. package/dist/deviceManager.js.map +0 -1
  61. package/dist/evse.d.ts +0 -67
  62. package/dist/evse.d.ts.map +0 -1
  63. package/dist/evse.js.map +0 -1
  64. package/dist/frontend.d.ts +0 -256
  65. package/dist/frontend.d.ts.map +0 -1
  66. package/dist/frontend.js.map +0 -1
  67. package/dist/globalMatterbridge.d.ts +0 -32
  68. package/dist/globalMatterbridge.d.ts.map +0 -1
  69. package/dist/globalMatterbridge.js.map +0 -1
  70. package/dist/helpers.d.ts +0 -47
  71. package/dist/helpers.d.ts.map +0 -1
  72. package/dist/helpers.js.map +0 -1
  73. package/dist/index.d.ts +0 -37
  74. package/dist/index.d.ts.map +0 -1
  75. package/dist/index.js.map +0 -1
  76. package/dist/laundryWasher.d.ts +0 -243
  77. package/dist/laundryWasher.d.ts.map +0 -1
  78. package/dist/laundryWasher.js.map +0 -1
  79. package/dist/logger/export.d.ts +0 -2
  80. package/dist/logger/export.d.ts.map +0 -1
  81. package/dist/logger/export.js.map +0 -1
  82. package/dist/matter/behaviors.d.ts +0 -2
  83. package/dist/matter/behaviors.d.ts.map +0 -1
  84. package/dist/matter/behaviors.js.map +0 -1
  85. package/dist/matter/clusters.d.ts +0 -2
  86. package/dist/matter/clusters.d.ts.map +0 -1
  87. package/dist/matter/clusters.js.map +0 -1
  88. package/dist/matter/devices.d.ts +0 -2
  89. package/dist/matter/devices.d.ts.map +0 -1
  90. package/dist/matter/devices.js.map +0 -1
  91. package/dist/matter/endpoints.d.ts +0 -2
  92. package/dist/matter/endpoints.d.ts.map +0 -1
  93. package/dist/matter/endpoints.js.map +0 -1
  94. package/dist/matter/export.d.ts +0 -5
  95. package/dist/matter/export.d.ts.map +0 -1
  96. package/dist/matter/export.js.map +0 -1
  97. package/dist/matter/types.d.ts +0 -3
  98. package/dist/matter/types.d.ts.map +0 -1
  99. package/dist/matter/types.js.map +0 -1
  100. package/dist/matterbridge.d.ts +0 -445
  101. package/dist/matterbridge.d.ts.map +0 -1
  102. package/dist/matterbridge.js.map +0 -1
  103. package/dist/matterbridgeAccessoryPlatform.d.ts +0 -40
  104. package/dist/matterbridgeAccessoryPlatform.d.ts.map +0 -1
  105. package/dist/matterbridgeAccessoryPlatform.js.map +0 -1
  106. package/dist/matterbridgeBehaviors.d.ts +0 -1333
  107. package/dist/matterbridgeBehaviors.d.ts.map +0 -1
  108. package/dist/matterbridgeBehaviors.js.map +0 -1
  109. package/dist/matterbridgeDeviceTypes.d.ts +0 -644
  110. package/dist/matterbridgeDeviceTypes.d.ts.map +0 -1
  111. package/dist/matterbridgeDeviceTypes.js.map +0 -1
  112. package/dist/matterbridgeDynamicPlatform.d.ts +0 -40
  113. package/dist/matterbridgeDynamicPlatform.d.ts.map +0 -1
  114. package/dist/matterbridgeDynamicPlatform.js.map +0 -1
  115. package/dist/matterbridgeEndpoint.d.ts +0 -1144
  116. package/dist/matterbridgeEndpoint.d.ts.map +0 -1
  117. package/dist/matterbridgeEndpoint.js.map +0 -1
  118. package/dist/matterbridgeEndpointHelpers.d.ts +0 -3083
  119. package/dist/matterbridgeEndpointHelpers.d.ts.map +0 -1
  120. package/dist/matterbridgeEndpointHelpers.js.map +0 -1
  121. package/dist/matterbridgePlatform.d.ts +0 -294
  122. package/dist/matterbridgePlatform.d.ts.map +0 -1
  123. package/dist/matterbridgePlatform.js.map +0 -1
  124. package/dist/matterbridgeTypes.d.ts +0 -196
  125. package/dist/matterbridgeTypes.d.ts.map +0 -1
  126. package/dist/matterbridgeTypes.js.map +0 -1
  127. package/dist/pluginManager.d.ts +0 -273
  128. package/dist/pluginManager.d.ts.map +0 -1
  129. package/dist/pluginManager.js.map +0 -1
  130. package/dist/roboticVacuumCleaner.d.ts +0 -102
  131. package/dist/roboticVacuumCleaner.d.ts.map +0 -1
  132. package/dist/roboticVacuumCleaner.js.map +0 -1
  133. package/dist/shelly.d.ts +0 -161
  134. package/dist/shelly.d.ts.map +0 -1
  135. package/dist/shelly.js.map +0 -1
  136. package/dist/storage/export.d.ts +0 -2
  137. package/dist/storage/export.d.ts.map +0 -1
  138. package/dist/storage/export.js.map +0 -1
  139. package/dist/update.d.ts +0 -58
  140. package/dist/update.d.ts.map +0 -1
  141. package/dist/update.js.map +0 -1
  142. package/dist/utils/colorUtils.d.ts +0 -61
  143. package/dist/utils/colorUtils.d.ts.map +0 -1
  144. package/dist/utils/colorUtils.js.map +0 -1
  145. package/dist/utils/commandLine.d.ts +0 -58
  146. package/dist/utils/commandLine.d.ts.map +0 -1
  147. package/dist/utils/commandLine.js.map +0 -1
  148. package/dist/utils/copyDirectory.d.ts +0 -32
  149. package/dist/utils/copyDirectory.d.ts.map +0 -1
  150. package/dist/utils/copyDirectory.js.map +0 -1
  151. package/dist/utils/createDirectory.d.ts +0 -32
  152. package/dist/utils/createDirectory.d.ts.map +0 -1
  153. package/dist/utils/createDirectory.js.map +0 -1
  154. package/dist/utils/createZip.d.ts +0 -38
  155. package/dist/utils/createZip.d.ts.map +0 -1
  156. package/dist/utils/createZip.js.map +0 -1
  157. package/dist/utils/deepCopy.d.ts +0 -31
  158. package/dist/utils/deepCopy.d.ts.map +0 -1
  159. package/dist/utils/deepCopy.js.map +0 -1
  160. package/dist/utils/deepEqual.d.ts +0 -53
  161. package/dist/utils/deepEqual.d.ts.map +0 -1
  162. package/dist/utils/deepEqual.js.map +0 -1
  163. package/dist/utils/export.d.ts +0 -12
  164. package/dist/utils/export.d.ts.map +0 -1
  165. package/dist/utils/export.js.map +0 -1
  166. package/dist/utils/hex.d.ts +0 -48
  167. package/dist/utils/hex.d.ts.map +0 -1
  168. package/dist/utils/hex.js.map +0 -1
  169. package/dist/utils/isvalid.d.ts +0 -102
  170. package/dist/utils/isvalid.d.ts.map +0 -1
  171. package/dist/utils/isvalid.js.map +0 -1
  172. package/dist/utils/network.d.ts +0 -69
  173. package/dist/utils/network.d.ts.map +0 -1
  174. package/dist/utils/network.js.map +0 -1
  175. package/dist/utils/spawn.d.ts +0 -12
  176. package/dist/utils/spawn.d.ts.map +0 -1
  177. package/dist/utils/spawn.js.map +0 -1
  178. package/dist/utils/wait.d.ts +0 -52
  179. package/dist/utils/wait.d.ts.map +0 -1
  180. package/dist/utils/wait.js.map +0 -1
  181. package/dist/waterHeater.d.ts +0 -90
  182. package/dist/waterHeater.d.ts.map +0 -1
  183. package/dist/waterHeater.js.map +0 -1
package/CHANGELOG.md CHANGED
@@ -8,6 +8,22 @@ If you like this project and find it useful, please consider giving it a star on
8
8
  <img src="bmc-button.svg" alt="Buy me a coffee" width="120">
9
9
  </a>
10
10
 
11
+ ## [3.0.7] - 2025-06-??
12
+
13
+ ### Added
14
+
15
+ ### Changed
16
+
17
+ - [package]: Updated dependencies.
18
+ - [package]: Downgrade jest to 29.7.0.
19
+ - [energy]: Added parameter for cumulativeEnergyExported to the helper. For solar power device.
20
+
21
+ ### Fixed
22
+
23
+ <a href="https://www.buymeacoffee.com/luligugithub">
24
+ <img src="bmc-button.svg" alt="Buy me a coffee" width="80">
25
+ </a>
26
+
11
27
  ## [3.0.6] - 2025-06-13
12
28
 
13
29
  ### Added
package/dist/cli.js CHANGED
@@ -1,46 +1,20 @@
1
1
  #!/usr/bin/env node
2
- /**
3
- * This file contains the CLI entry point of Matterbridge.
4
- *
5
- * @file cli.ts
6
- * @author Luca Liguori
7
- * @date 2023-12-29
8
- * @version 2.0.1
9
- *
10
- * Copyright 2023, 2024, 2025 Luca Liguori.
11
- *
12
- * Licensed under the Apache License, Version 2.0 (the "License");
13
- * you may not use this file except in compliance with the License.
14
- * You may obtain a copy of the License at
15
- *
16
- * http://www.apache.org/licenses/LICENSE-2.0
17
- *
18
- * Unless required by applicable law or agreed to in writing, software
19
- * distributed under the License is distributed on an "AS IS" BASIS,
20
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
21
- * See the License for the specific language governing permissions and
22
- * limitations under the License. *
23
- */
24
- // Matterbridge
25
2
  import { Matterbridge } from './matterbridge.js';
26
3
  import { getIntParameter, hasParameter } from './utils/export.js';
27
- // AnsiLogger module
28
4
  import { AnsiLogger, BRIGHT, CYAN, db, YELLOW } from './logger/export.js';
29
5
  import os from 'node:os';
30
6
  import { EventEmitter } from 'node:events';
31
7
  import { inspect } from 'node:util';
32
8
  export const cliEmitter = new EventEmitter();
33
9
  export let instance;
34
- // Inspectop
35
10
  let session;
36
11
  let snapshotInterval;
37
- // Cpu and memory check
38
12
  let memoryCheckInterval;
39
13
  let prevCpus;
40
14
  export let lastCpuUsage = 0;
41
15
  let peakCpu = 0;
42
16
  let peakRss = 0;
43
- const log = new AnsiLogger({ logName: 'Cli', logTimestampFormat: 4 /* TimestampFormat.TIME_MILLIS */, logLevel: hasParameter('debug') ? "debug" /* LogLevel.DEBUG */ : "info" /* LogLevel.INFO */ });
17
+ const log = new AnsiLogger({ logName: 'Cli', logTimestampFormat: 4, logLevel: hasParameter('debug') ? "debug" : "info" });
44
18
  const formatMemoryUsage = (bytes) => {
45
19
  if (bytes >= 1024 ** 3) {
46
20
  return `${(bytes / 1024 ** 3).toFixed(2)} GB`;
@@ -68,16 +42,13 @@ const formatOsUpTime = (seconds) => {
68
42
  return `${seconds} second${seconds !== 1 ? 's' : ''}`;
69
43
  };
70
44
  async function startCpuMemoryCheck() {
71
- // const os = await import('node:os');
72
45
  log.debug(`Cpu memory check started`);
73
46
  prevCpus = os.cpus();
74
47
  clearInterval(memoryCheckInterval);
75
48
  const interval = () => {
76
- // Get the os uptime
77
49
  const systemUptime = formatOsUpTime(Math.floor(os.uptime()));
78
50
  const processUptime = formatOsUpTime(Math.floor(process.uptime()));
79
51
  cliEmitter.emit('uptime', systemUptime, processUptime);
80
- // Get the memory usage
81
52
  const totalMememory = formatMemoryUsage(os.totalmem());
82
53
  const freeMemory = formatMemoryUsage(os.freemem());
83
54
  const memoryUsageRaw = process.memoryUsage();
@@ -89,12 +60,10 @@ async function startCpuMemoryCheck() {
89
60
  if (memoryUsageRaw.rss > peakRss)
90
61
  peakRss = memoryUsageRaw.rss;
91
62
  cliEmitter.emit('memory', totalMememory, freeMemory, rss, heapTotal, heapUsed, external, arrayBuffers);
92
- // Get the cpu usage
93
63
  const currCpus = os.cpus();
94
- // log.debug(`Cpus: ${JSON.stringify(currCpus)}`);
95
64
  let cpuUsageLog;
96
65
  if (currCpus.length !== prevCpus.length) {
97
- prevCpus = currCpus; // Reset the previous cpus
66
+ prevCpus = currCpus;
98
67
  log.debug(`Cpu check length failed, resetting previous cpus`);
99
68
  return;
100
69
  }
@@ -120,7 +89,6 @@ async function startCpuMemoryCheck() {
120
89
  cliEmitter.emit('cpu', lastCpuUsage);
121
90
  }
122
91
  prevCpus = currCpus;
123
- // Show the cpu and memory usage
124
92
  log.debug(`***${YELLOW}${BRIGHT}Cpu usage:${db} ${CYAN}${cpuUsageLog.padStart(6, ' ')} %${db} ${YELLOW}${BRIGHT}Memory usage:${db} rss ${CYAN}${rss}${db} heapTotal ${CYAN}${heapTotal}${db} heapUsed ${CYAN}${heapUsed}${db} external ${external} arrayBuffers ${arrayBuffers}`);
125
93
  };
126
94
  interval();
@@ -131,15 +99,10 @@ async function stopCpuMemoryCheck() {
131
99
  log.debug(`***Cpu memory check stopped. Peak cpu: ${CYAN}${peakCpu.toFixed(2)} %${db}. Peak rss: ${CYAN}${formatMemoryUsage(peakRss)}${db}.`);
132
100
  clearInterval(memoryCheckInterval);
133
101
  }
134
- /**
135
- * Starts the inspector for heap sampling.
136
- * This function is called when the -inspect parameter is passed.
137
- */
138
102
  async function startInspector() {
139
103
  const { Session } = await import('node:inspector');
140
104
  const { mkdirSync } = await import('node:fs');
141
105
  log.debug(`***Starting heap sampling...`);
142
- // Create the heap snapshots directory if it doesn't exist
143
106
  mkdirSync('heap_profile', { recursive: true });
144
107
  try {
145
108
  session = new Session();
@@ -148,7 +111,6 @@ async function startInspector() {
148
111
  session?.post('HeapProfiler.startSampling', (err) => (err ? reject(err) : resolve()));
149
112
  });
150
113
  log.debug(`***Started heap sampling`);
151
- // Set an interval to take heap snapshots
152
114
  const interval = getIntParameter('snapshotinterval');
153
115
  if (interval && interval >= 30000) {
154
116
  log.debug(`***Started heap snapshot interval of ${CYAN}${interval}${db} ms`);
@@ -166,19 +128,13 @@ async function startInspector() {
166
128
  return;
167
129
  }
168
130
  }
169
- /**
170
- * Stops the heap sampling and saves the profile to a file.
171
- * This function is called when the inspector is stopped.
172
- */
173
131
  async function stopInspector() {
174
132
  const { writeFileSync } = await import('node:fs');
175
133
  const path = await import('node:path');
176
134
  log.debug(`***Stopping heap sampling...`);
177
135
  if (snapshotInterval) {
178
136
  log.debug(`***Clearing heap snapshot interval...`);
179
- // Clear the snapshot interval if it exists
180
137
  clearInterval(snapshotInterval);
181
- // Take a final heap snapshot before stopping
182
138
  await takeHeapSnapshot();
183
139
  }
184
140
  if (!session) {
@@ -186,7 +142,6 @@ async function stopInspector() {
186
142
  return;
187
143
  }
188
144
  try {
189
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
190
145
  const result = await new Promise((resolve, reject) => {
191
146
  session?.post('HeapProfiler.stopSampling', (err, result) => (err ? reject(err) : resolve(result)));
192
147
  });
@@ -204,13 +159,6 @@ async function stopInspector() {
204
159
  log.debug(`***Stopped heap sampling`);
205
160
  }
206
161
  }
207
- /**
208
- * Takes a heap snapshot and saves it to the file name Heap-snapshot-<timestamp>.heapsnapshot.
209
- * This function is called periodically based on the -snapshotinterval parameter.
210
- * The -snapshotinterval parameter must at least 30000 ms.
211
- * The snapshot is saved in the heap_profile directory that is created in the current working directory.
212
- * The snapshot can be analyzed using vscode or Chrome DevTools or other tools that support heap snapshots.
213
- */
214
162
  async function takeHeapSnapshot() {
215
163
  const { writeFileSync } = await import('node:fs');
216
164
  const path = await import('node:path');
@@ -242,10 +190,6 @@ async function takeHeapSnapshot() {
242
190
  });
243
191
  });
244
192
  }
245
- /**
246
- * Triggers a manual garbage collection.
247
- * This function is working only if the process is started with --expose-gc.
248
- */
249
193
  function triggerGarbageCollection() {
250
194
  if (typeof global.gc === 'function') {
251
195
  global.gc();
@@ -292,7 +236,6 @@ async function restart() {
292
236
  }
293
237
  async function update() {
294
238
  log.debug('Received update event, updating...');
295
- // TODO: Implement update logic outside of matterbridge
296
239
  instance = await Matterbridge.loadInstance(true);
297
240
  registerHandlers();
298
241
  }
@@ -312,7 +255,6 @@ async function main() {
312
255
  log.debug(`***Matterbridge.loadInstance(true) called`);
313
256
  instance = await Matterbridge.loadInstance(true);
314
257
  log.debug(`***Matterbridge.loadInstance(true) exited`);
315
- // Check if the instance needs to shut down from parseCommandLine()
316
258
  if (!instance || instance.shutdown) {
317
259
  shutdown();
318
260
  }
@@ -321,11 +263,9 @@ async function main() {
321
263
  cliEmitter.emit('ready');
322
264
  }
323
265
  }
324
- // Run the main function
325
266
  process.title = 'matterbridge';
326
267
  main().catch((error) => {
327
268
  const errorMessage = error instanceof Error ? error.message : error;
328
269
  const errorInspect = inspect(error, { depth: 10 });
329
270
  log.error(`Matterbridge.loadInstance() failed with error: ${errorMessage}\nstack: ${errorInspect}`);
330
271
  });
331
- //# sourceMappingURL=cli.js.map
@@ -1,3 +1 @@
1
1
  export {};
2
- // Nothing to export right now, but this file is here to make it easier to add exports in the future
3
- //# sourceMappingURL=export.js.map
@@ -1,25 +1,3 @@
1
- /**
2
- * This file contains the default config for the plugins.
3
- *
4
- * @file defaultConfigSchema.ts
5
- * @author Luca Liguori
6
- * @date 2024-05-07
7
- * @version 1.0.1
8
- *
9
- * Copyright 2024, 2025, 2026 Luca Liguori.
10
- *
11
- * Licensed under the Apache License, Version 2.0 (the "License");
12
- * you may not use this file except in compliance with the License.
13
- * You may obtain a copy of the License at
14
- *
15
- * http://www.apache.org/licenses/LICENSE-2.0
16
- *
17
- * Unless required by applicable law or agreed to in writing, software
18
- * distributed under the License is distributed on an "AS IS" BASIS,
19
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
20
- * See the License for the specific language governing permissions and
21
- * limitations under the License. *
22
- */
23
1
  export const zigbee2mqtt_config = {
24
2
  name: 'matterbridge-zigbee2mqtt',
25
3
  type: 'DynamicPlatform',
@@ -78,4 +56,3 @@ export const shelly_config = {
78
56
  debugWs: false,
79
57
  unregisterOnShutdown: false,
80
58
  };
81
- //# sourceMappingURL=defaultConfigSchema.js.map
@@ -1,89 +1,28 @@
1
- /**
2
- * This file contains the DeviceManager class.
3
- *
4
- * @file devices.ts
5
- * @author Luca Liguori
6
- * @date 2024-07-26
7
- * @version 1.0.10
8
- *
9
- * Copyright 2024, 2025, 2026 Luca Liguori.
10
- *
11
- * Licensed under the Apache License, Version 2.0 (the "License");
12
- * you may not use this file except in compliance with the License.
13
- * You may obtain a copy of the License at
14
- *
15
- * http://www.apache.org/licenses/LICENSE-2.0
16
- *
17
- * Unless required by applicable law or agreed to in writing, software
18
- * distributed under the License is distributed on an "AS IS" BASIS,
19
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
20
- * See the License for the specific language governing permissions and
21
- * limitations under the License. *
22
- */
23
- // AnsiLogger module
24
1
  import { AnsiLogger, BLUE, er } from './logger/export.js';
25
2
  import { dev } from './matterbridgeTypes.js';
26
- /**
27
- * Manages Matterbridge devices.
28
- */
29
3
  export class DeviceManager {
30
4
  _devices = new Map();
31
5
  matterbridge;
32
6
  nodeContext;
33
7
  log;
34
- /**
35
- * Creates an instance of DeviceManager.
36
- *
37
- * @param {Matterbridge} matterbridge - The Matterbridge instance.
38
- * @param {NodeStorage} nodeContext - The node storage context.
39
- */
40
8
  constructor(matterbridge, nodeContext) {
41
9
  this.matterbridge = matterbridge;
42
10
  this.nodeContext = nodeContext;
43
- this.log = new AnsiLogger({ logName: 'DeviceManager', logTimestampFormat: 4 /* TimestampFormat.TIME_MILLIS */, logLevel: matterbridge.log.logLevel });
11
+ this.log = new AnsiLogger({ logName: 'DeviceManager', logTimestampFormat: 4, logLevel: matterbridge.log.logLevel });
44
12
  this.log.debug('Matterbridge device manager starting...');
45
13
  }
46
- /**
47
- * Gets the number of devices.
48
- *
49
- * @returns {number} The number of devices.
50
- */
51
14
  get length() {
52
15
  return this._devices.size;
53
16
  }
54
- /**
55
- * Gets the number of devices.
56
- *
57
- * @returns {number} The number of devices.
58
- */
59
17
  get size() {
60
18
  return this._devices.size;
61
19
  }
62
- /**
63
- * Checks if a device with the specified unique ID exists.
64
- *
65
- * @param {string} uniqueId - The unique ID of the device.
66
- * @returns {boolean} True if the device exists, false otherwise.
67
- */
68
20
  has(uniqueId) {
69
21
  return this._devices.has(uniqueId);
70
22
  }
71
- /**
72
- * Gets a device by its unique ID.
73
- *
74
- * @param {string} uniqueId - The unique ID of the device.
75
- * @returns {MatterbridgeEndpoint | undefined} The device, or undefined if not found.
76
- */
77
23
  get(uniqueId) {
78
24
  return this._devices.get(uniqueId);
79
25
  }
80
- /**
81
- * Adds a device to the manager.
82
- *
83
- * @param {MatterbridgeEndpoint} device - The device to add.
84
- * @returns {MatterbridgeEndpoint} The added device.
85
- * @throws {Error} If the device does not have a unique ID.
86
- */
87
26
  set(device) {
88
27
  if (!device.uniqueId)
89
28
  throw new Error(`The device ${dev}${device.deviceName}${er} has not been initialized: uniqueId is required`);
@@ -92,13 +31,6 @@ export class DeviceManager {
92
31
  this._devices.set(device.uniqueId, device);
93
32
  return device;
94
33
  }
95
- /**
96
- * Removes a device from the manager.
97
- *
98
- * @param {MatterbridgeEndpoint} device - The device to remove.
99
- * @returns {boolean} True if the device was removed, false otherwise.
100
- * @throws {Error} If the device does not have a unique ID.
101
- */
102
34
  remove(device) {
103
35
  if (!device.uniqueId)
104
36
  throw new Error(`The device ${dev}${device.deviceName}${er} has not been initialized: uniqueId is required`);
@@ -106,34 +38,15 @@ export class DeviceManager {
106
38
  this.log.error(`The device ${dev}${device.deviceName}${er} with uniqueId ${BLUE}${device.uniqueId}${er} serialNumber ${BLUE}${device.serialNumber}${er} is not registered in the device manager`);
107
39
  return this._devices.delete(device.uniqueId);
108
40
  }
109
- /**
110
- * Clears all devices from the manager.
111
- */
112
41
  clear() {
113
42
  this._devices.clear();
114
43
  }
115
- /**
116
- * Gets an array of all devices.
117
- *
118
- * @returns {MatterbridgeEndpoint[]} An array of all devices.
119
- */
120
44
  array() {
121
45
  return Array.from(this._devices.values());
122
46
  }
123
- /**
124
- * Iterates over all devices.
125
- *
126
- * @returns {IterableIterator<MatterbridgeEndpoint>} An iterator for the devices.
127
- */
128
47
  [Symbol.iterator]() {
129
48
  return this._devices.values();
130
49
  }
131
- /**
132
- * Asynchronously iterates over each device and calls the provided callback function.
133
- *
134
- * @param {(device: MatterbridgeEndpoint) => Promise<void>} callback - The callback function to call with each device.
135
- * @returns {Promise<void>} A promise that resolves when all callbacks have been called.
136
- */
137
50
  async forEach(callback) {
138
51
  if (this.size === 0)
139
52
  return;
@@ -147,13 +60,7 @@ export class DeviceManager {
147
60
  });
148
61
  await Promise.all(tasks);
149
62
  }
150
- /**
151
- * Sets the log level.
152
- *
153
- * @param {LogLevel} logLevel - The log level to set.
154
- */
155
63
  set logLevel(logLevel) {
156
64
  this.log.logLevel = logLevel;
157
65
  }
158
66
  }
159
- //# sourceMappingURL=deviceManager.js.map
package/dist/evse.js CHANGED
@@ -1,49 +1,12 @@
1
- /**
2
- * This file contains the Evse class.
3
- *
4
- * @file energy-evse.ts
5
- * @author Luca Liguori
6
- * @contributor Ludovic BOUÉ
7
- * @date 2025-05-27
8
- * @version 1.1.0
9
- *
10
- * Copyright 2025, 2026, 2027 Luca Liguori.
11
- *
12
- * Licensed under the Apache License, Version 2.0 (the "License");
13
- * you may not use this file except in compliance with the License.
14
- * You may obtain a copy of the License at
15
- *
16
- * http://www.apache.org/licenses/LICENSE-2.0
17
- *
18
- * Unless required by applicable law or agreed to in writing, software
19
- * distributed under the License is distributed on an "AS IS" BASIS,
20
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
21
- * See the License for the specific language governing permissions and
22
- * limitations under the License. *
23
- */
24
1
  import { EnergyEvseServer } from '@matter/main/behaviors/energy-evse';
25
2
  import { EnergyEvseModeServer } from '@matter/main/behaviors/energy-evse-mode';
26
3
  import { EnergyEvse, EnergyEvseMode } from '@matter/main/clusters';
27
4
  import { DeviceEnergyManagement } from '@matter/main/clusters/device-energy-management';
28
5
  import { ModeBase } from '@matter/main/clusters/mode-base';
29
- // Matterbridge
30
6
  import { MatterbridgeEndpoint } from './matterbridgeEndpoint.js';
31
7
  import { MatterbridgeServer } from './matterbridgeBehaviors.js';
32
8
  import { deviceEnergyManagement, electricalSensor, evse, powerSource } from './matterbridgeDeviceTypes.js';
33
9
  export class Evse extends MatterbridgeEndpoint {
34
- /**
35
- * Creates an instance of the EVSE class.
36
- *
37
- * @param {string} name - The name of the EVSE.
38
- * @param {string} serial - The serial number of the EVSE.
39
- * @param {number} [currentMode] - The current mode of the EnergyEvseMode cluster. Defaults to mode 1 (EnergyEvseMode.ModeTag.Manual).
40
- * @param {EnergyEvseMode.ModeOption[]} [supportedModes] - The supported modes for the EnergyEvseMode cluster. This is a fixed attribute that defaults to a predefined set of EnergyEvseMode cluster modes.
41
- * @param {EnergyEvse.State} [state] - The current state of the EVSE. Defaults to NotPluggedIn.
42
- * @param {EnergyEvse.SupplyState} [supplyState] - The supply state of the EVSE. Defaults to Disabled.
43
- * @param {EnergyEvse.FaultState} [faultState] - The fault state of the EVSE. Defaults to NoError.
44
- * @param {number} [absMinPower=0] - Indicate the minimum electrical power that the ESA can consume when switched on. Defaults to `0` if not provided.
45
- * @param {number} [absMaxPower=0] - Indicate the maximum electrical power that the ESA can consume when switched on. Defaults to `0` if not provided.
46
- */
47
10
  constructor(name, serial, currentMode, supportedModes, state, supplyState, faultState, absMinPower, absMaxPower) {
48
11
  super([evse, powerSource, electricalSensor, deviceEnergyManagement], { uniqueStorageKey: `${name.replaceAll(' ', '')}-${serial.replaceAll(' ', '')}` }, true);
49
12
  this.createDefaultIdentifyClusterServer()
@@ -57,42 +20,29 @@ export class Evse extends MatterbridgeEndpoint {
57
20
  .createDefaultEnergyEvseModeClusterServer(currentMode, supportedModes)
58
21
  .addRequiredClusterServers();
59
22
  }
60
- /**
61
- * Creates a default EnergyEvseServer Cluster Server.
62
- *
63
- */
64
23
  createDefaultEnergyEvseClusterServer(state, supplyState, faultState) {
65
24
  this.behaviors.require(MatterbridgeEnergyEvseServer, {
66
25
  state: state ?? EnergyEvse.State.NotPluggedIn,
67
26
  supplyState: supplyState ?? EnergyEvse.SupplyState.ChargingEnabled,
68
27
  faultState: faultState ?? EnergyEvse.FaultState.NoError,
69
- chargingEnabledUntil: 0, // Persistent attribute
70
- circuitCapacity: 0, // Persistent attribute in mA
71
- minimumChargeCurrent: 6000, // Persistent attribute in mA
72
- maximumChargeCurrent: 0, // Persistent attribute in mA
73
- sessionId: null, // Persistent attribute
74
- sessionDuration: 0, // Persistent attribute
75
- sessionEnergyCharged: 0, // Persistent attribute
28
+ chargingEnabledUntil: 0,
29
+ circuitCapacity: 0,
30
+ minimumChargeCurrent: 6000,
31
+ maximumChargeCurrent: 0,
32
+ sessionId: null,
33
+ sessionDuration: 0,
34
+ sessionEnergyCharged: 0,
76
35
  });
77
36
  return this;
78
37
  }
79
- /**
80
- * Creates a default EnergyEvseMode Cluster Server.
81
- *
82
- * @param {number} [currentMode] - The current mode of the EnergyEvseMode cluster. Defaults to mode 1 (EnergyEvseMode.ModeTag.Manual).
83
- * @param {EnergyEvseMode.ModeOption[]} [supportedModes] - The supported modes for the EnergyEvseMode cluster. Defaults all EnergyEvseMode cluster modes.
84
- *
85
- * @returns {this} The current MatterbridgeEndpoint instance for chaining.
86
- */
87
38
  createDefaultEnergyEvseModeClusterServer(currentMode, supportedModes) {
88
39
  this.behaviors.require(MatterbridgeEnergyEvseModeServer, {
89
40
  supportedModes: supportedModes ?? [
90
41
  { label: 'On demand', mode: 1, modeTags: [{ value: EnergyEvseMode.ModeTag.Manual }] },
91
42
  { label: 'Scheduled', mode: 2, modeTags: [{ value: EnergyEvseMode.ModeTag.TimeOfUse }] },
92
43
  { label: 'Solar charging', mode: 3, modeTags: [{ value: EnergyEvseMode.ModeTag.SolarCharging }] },
93
- // { label: 'Home to vehicle and Vehicle to home', mode: 4, modeTags: [{ value: EnergyEvseMode.ModeTag.V2X }] }, // This mode is not valid in charging only EVSEs
94
- ], // FixedAttribute
95
- currentMode: currentMode ?? 1, // Persistent attribute
44
+ ],
45
+ currentMode: currentMode ?? 1,
96
46
  });
97
47
  return this;
98
48
  }
@@ -108,8 +58,6 @@ export class MatterbridgeEnergyEvseServer extends EnergyEvseServer {
108
58
  this.state.state = EnergyEvse.State.PluggedInDemand;
109
59
  }
110
60
  this.state.chargingEnabledUntil = 0;
111
- // super.disable();
112
- // disable is not implemented in matter.js
113
61
  }
114
62
  enableCharging(request) {
115
63
  const device = this.endpoint.stateOf(MatterbridgeServer);
@@ -123,9 +71,6 @@ export class MatterbridgeEnergyEvseServer extends EnergyEvseServer {
123
71
  this.state.chargingEnabledUntil = request.chargingEnabledUntil;
124
72
  this.state.minimumChargeCurrent = request.minimumChargeCurrent;
125
73
  this.state.maximumChargeCurrent = request.maximumChargeCurrent;
126
- // The implementation should also stop the charging session at the required time and update the sessionId, sessionDuration, and sessionEnergyCharged attributes if needed.
127
- // super.enableCharging();
128
- // enableCharging is not implemented in matter.js
129
74
  }
130
75
  }
131
76
  export class MatterbridgeEnergyEvseModeServer extends EnergyEvseModeServer {
@@ -143,4 +88,3 @@ export class MatterbridgeEnergyEvseModeServer extends EnergyEvseModeServer {
143
88
  return { status: ModeBase.ModeChangeStatus.Success, statusText: 'Success' };
144
89
  }
145
90
  }
146
- //# sourceMappingURL=evse.js.map