matterbridge 3.0.3 → 3.0.4-dev-20250525-c88cf84
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.
- package/CHANGELOG.md +25 -4
- package/README.md +6 -12
- package/dist/cli.js +2 -37
- package/dist/cluster/export.js +0 -2
- package/dist/defaultConfigSchema.js +0 -23
- package/dist/deviceManager.js +1 -94
- package/dist/frontend.js +100 -437
- package/dist/helpers.js +9 -53
- package/dist/index.js +1 -27
- package/dist/logger/export.js +0 -1
- package/dist/matter/behaviors.js +0 -2
- package/dist/matter/clusters.js +0 -2
- package/dist/matter/devices.js +0 -2
- package/dist/matter/endpoints.js +0 -2
- package/dist/matter/export.js +1 -3
- package/dist/matter/types.js +0 -2
- package/dist/matterbridge.js +47 -747
- package/dist/matterbridgeAccessoryPlatform.js +0 -34
- package/dist/matterbridgeBehaviors.js +43 -61
- package/dist/matterbridgeDeviceTypes.js +15 -563
- package/dist/matterbridgeDynamicPlatform.js +0 -34
- package/dist/matterbridgeEndpoint.js +68 -837
- package/dist/matterbridgeEndpointHelpers.js +33 -204
- package/dist/matterbridgePlatform.js +7 -225
- package/dist/matterbridgeTypes.js +0 -24
- package/dist/pluginManager.js +3 -264
- package/dist/roboticVacuumCleaner.js +3 -78
- package/dist/shelly.js +7 -155
- package/dist/storage/export.js +0 -1
- package/dist/update.js +0 -53
- package/dist/utils/colorUtils.js +2 -205
- package/dist/utils/commandLine.js +0 -53
- package/dist/utils/copyDirectory.js +1 -37
- package/dist/utils/createZip.js +2 -42
- package/dist/utils/deepCopy.js +0 -38
- package/dist/utils/deepEqual.js +1 -71
- package/dist/utils/export.js +0 -1
- package/dist/utils/hex.js +0 -57
- package/dist/utils/isvalid.js +0 -100
- package/dist/utils/network.js +5 -76
- package/dist/utils/wait.js +9 -58
- package/dist/waterHeater.js +0 -52
- package/npm-shrinkwrap.json +10 -10
- package/package.json +2 -3
- package/dist/cli.d.ts +0 -29
- package/dist/cli.d.ts.map +0 -1
- package/dist/cli.js.map +0 -1
- package/dist/cluster/export.d.ts +0 -2
- package/dist/cluster/export.d.ts.map +0 -1
- package/dist/cluster/export.js.map +0 -1
- package/dist/defaultConfigSchema.d.ts +0 -27
- package/dist/defaultConfigSchema.d.ts.map +0 -1
- package/dist/defaultConfigSchema.js.map +0 -1
- package/dist/deviceManager.d.ts +0 -114
- package/dist/deviceManager.d.ts.map +0 -1
- package/dist/deviceManager.js.map +0 -1
- package/dist/frontend.d.ts +0 -241
- package/dist/frontend.d.ts.map +0 -1
- package/dist/frontend.js.map +0 -1
- package/dist/helpers.d.ts +0 -47
- package/dist/helpers.d.ts.map +0 -1
- package/dist/helpers.js.map +0 -1
- package/dist/index.d.ts +0 -35
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/logger/export.d.ts +0 -2
- package/dist/logger/export.d.ts.map +0 -1
- package/dist/logger/export.js.map +0 -1
- package/dist/matter/behaviors.d.ts +0 -2
- package/dist/matter/behaviors.d.ts.map +0 -1
- package/dist/matter/behaviors.js.map +0 -1
- package/dist/matter/clusters.d.ts +0 -2
- package/dist/matter/clusters.d.ts.map +0 -1
- package/dist/matter/clusters.js.map +0 -1
- package/dist/matter/devices.d.ts +0 -2
- package/dist/matter/devices.d.ts.map +0 -1
- package/dist/matter/devices.js.map +0 -1
- package/dist/matter/endpoints.d.ts +0 -2
- package/dist/matter/endpoints.d.ts.map +0 -1
- package/dist/matter/endpoints.js.map +0 -1
- package/dist/matter/export.d.ts +0 -5
- package/dist/matter/export.d.ts.map +0 -1
- package/dist/matter/export.js.map +0 -1
- package/dist/matter/types.d.ts +0 -3
- package/dist/matter/types.d.ts.map +0 -1
- package/dist/matter/types.js.map +0 -1
- package/dist/matterbridge.d.ts +0 -445
- package/dist/matterbridge.d.ts.map +0 -1
- package/dist/matterbridge.js.map +0 -1
- package/dist/matterbridgeAccessoryPlatform.d.ts +0 -40
- package/dist/matterbridgeAccessoryPlatform.d.ts.map +0 -1
- package/dist/matterbridgeAccessoryPlatform.js.map +0 -1
- package/dist/matterbridgeBehaviors.d.ts +0 -1201
- package/dist/matterbridgeBehaviors.d.ts.map +0 -1
- package/dist/matterbridgeBehaviors.js.map +0 -1
- package/dist/matterbridgeDeviceTypes.d.ts +0 -629
- package/dist/matterbridgeDeviceTypes.d.ts.map +0 -1
- package/dist/matterbridgeDeviceTypes.js.map +0 -1
- package/dist/matterbridgeDynamicPlatform.d.ts +0 -40
- package/dist/matterbridgeDynamicPlatform.d.ts.map +0 -1
- package/dist/matterbridgeDynamicPlatform.js.map +0 -1
- package/dist/matterbridgeEndpoint.d.ts +0 -967
- package/dist/matterbridgeEndpoint.d.ts.map +0 -1
- package/dist/matterbridgeEndpoint.js.map +0 -1
- package/dist/matterbridgeEndpointHelpers.d.ts +0 -2728
- package/dist/matterbridgeEndpointHelpers.d.ts.map +0 -1
- package/dist/matterbridgeEndpointHelpers.js.map +0 -1
- package/dist/matterbridgePlatform.d.ts +0 -294
- package/dist/matterbridgePlatform.d.ts.map +0 -1
- package/dist/matterbridgePlatform.js.map +0 -1
- package/dist/matterbridgeTypes.d.ts +0 -188
- package/dist/matterbridgeTypes.d.ts.map +0 -1
- package/dist/matterbridgeTypes.js.map +0 -1
- package/dist/pluginManager.d.ts +0 -273
- package/dist/pluginManager.d.ts.map +0 -1
- package/dist/pluginManager.js.map +0 -1
- package/dist/roboticVacuumCleaner.d.ts +0 -82
- package/dist/roboticVacuumCleaner.d.ts.map +0 -1
- package/dist/roboticVacuumCleaner.js.map +0 -1
- package/dist/shelly.d.ts +0 -153
- package/dist/shelly.d.ts.map +0 -1
- package/dist/shelly.js.map +0 -1
- package/dist/storage/export.d.ts +0 -2
- package/dist/storage/export.d.ts.map +0 -1
- package/dist/storage/export.js.map +0 -1
- package/dist/update.d.ts +0 -58
- package/dist/update.d.ts.map +0 -1
- package/dist/update.js.map +0 -1
- package/dist/utils/colorUtils.d.ts +0 -61
- package/dist/utils/colorUtils.d.ts.map +0 -1
- package/dist/utils/colorUtils.js.map +0 -1
- package/dist/utils/commandLine.d.ts +0 -58
- package/dist/utils/commandLine.d.ts.map +0 -1
- package/dist/utils/commandLine.js.map +0 -1
- package/dist/utils/copyDirectory.d.ts +0 -32
- package/dist/utils/copyDirectory.d.ts.map +0 -1
- package/dist/utils/copyDirectory.js.map +0 -1
- package/dist/utils/createZip.d.ts +0 -38
- package/dist/utils/createZip.d.ts.map +0 -1
- package/dist/utils/createZip.js.map +0 -1
- package/dist/utils/deepCopy.d.ts +0 -31
- package/dist/utils/deepCopy.d.ts.map +0 -1
- package/dist/utils/deepCopy.js.map +0 -1
- package/dist/utils/deepEqual.d.ts +0 -53
- package/dist/utils/deepEqual.d.ts.map +0 -1
- package/dist/utils/deepEqual.js.map +0 -1
- package/dist/utils/export.d.ts +0 -11
- package/dist/utils/export.d.ts.map +0 -1
- package/dist/utils/export.js.map +0 -1
- package/dist/utils/hex.d.ts +0 -48
- package/dist/utils/hex.d.ts.map +0 -1
- package/dist/utils/hex.js.map +0 -1
- package/dist/utils/isvalid.d.ts +0 -102
- package/dist/utils/isvalid.d.ts.map +0 -1
- package/dist/utils/isvalid.js.map +0 -1
- package/dist/utils/network.d.ts +0 -69
- package/dist/utils/network.d.ts.map +0 -1
- package/dist/utils/network.js.map +0 -1
- package/dist/utils/wait.d.ts +0 -52
- package/dist/utils/wait.d.ts.map +0 -1
- package/dist/utils/wait.js.map +0 -1
- package/dist/waterHeater.d.ts +0 -75
- package/dist/waterHeater.d.ts.map +0 -1
- package/dist/waterHeater.js.map +0 -1
package/CHANGELOG.md
CHANGED
|
@@ -8,6 +8,27 @@ 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.4] - 2025-05-??
|
|
12
|
+
|
|
13
|
+
### Added
|
|
14
|
+
|
|
15
|
+
- [jsdoc]: Improved jsdoc for cluster helpers.
|
|
16
|
+
- [cover]: Added createDefaultTiltWindowCoveringClusterServer().
|
|
17
|
+
|
|
18
|
+
### Changed
|
|
19
|
+
|
|
20
|
+
- [legacy]: Removed legacy matter.js EndpointServer and logEndpoint that will be removed in matter.js 0.14.0. For developers: if you need to log the endpoint the call is Logger.get('LogEndpoint').info(endpoint).
|
|
21
|
+
- [package]: Updated dependencies.
|
|
22
|
+
- [package]: Updated multer package to 2.0.0.
|
|
23
|
+
|
|
24
|
+
### Fixed
|
|
25
|
+
|
|
26
|
+
- [virtualDevice]: Fixed possible vulnerability in the length of the nodeLabel.
|
|
27
|
+
|
|
28
|
+
<a href="https://www.buymeacoffee.com/luligugithub">
|
|
29
|
+
<img src="bmc-button.svg" alt="Buy me a coffee" width="80">
|
|
30
|
+
</a>
|
|
31
|
+
|
|
11
32
|
## [3.0.3] - 2025-05-19
|
|
12
33
|
|
|
13
34
|
### New plugins
|
|
@@ -23,10 +44,10 @@ AEG RX 9 / Electrolux Pure i9 robot vacuum plugin for Matterbridge.
|
|
|
23
44
|
|
|
24
45
|
### Added
|
|
25
46
|
|
|
26
|
-
- [virtual] Added virtual devices configuration mode in the Matterbridge Settings: 'Disabled', 'Light', 'Outlet', 'Switch', 'Mounted_switch'. Switch is not supported by Alexa. Mounted Switch is not supported by Apple.
|
|
27
|
-
- [deviceTypes] Added evse, waterHeater, solarPower, batteryStorage and heatPump device type.
|
|
28
|
-
- [waterHeater] Added WaterHeater class to create a Water Heater Device Type in one line of code (thanks https://github.com/lboue).
|
|
29
|
-
- [subscribe] Added a third parameter context (provisional implementation: when "context.offline === true" then this is a change coming from the device).
|
|
47
|
+
- [virtual]: Added virtual devices configuration mode in the Matterbridge Settings: 'Disabled', 'Light', 'Outlet', 'Switch', 'Mounted_switch'. Switch is not supported by Alexa. Mounted Switch is not supported by Apple.
|
|
48
|
+
- [deviceTypes]: Added evse, waterHeater, solarPower, batteryStorage and heatPump device type.
|
|
49
|
+
- [waterHeater]: Added WaterHeater class to create a Water Heater Device Type in one line of code (thanks https://github.com/lboue).
|
|
50
|
+
- [subscribe]: Added a third parameter context (provisional implementation: when "context.offline === true" then this is a change coming from the device).
|
|
30
51
|
|
|
31
52
|
### Changed
|
|
32
53
|
|
package/README.md
CHANGED
|
@@ -5,7 +5,7 @@
|
|
|
5
5
|
[](https://hub.docker.com/r/luligu/matterbridge)
|
|
6
6
|
[](https://hub.docker.com/r/luligu/matterbridge)
|
|
7
7
|

|
|
8
|
-

|
|
9
9
|
|
|
10
10
|
[](https://www.npmjs.com/package/matter-history)
|
|
11
11
|
[](https://www.npmjs.com/package/node-ansi-logger)
|
|
@@ -86,7 +86,7 @@ Follow these steps to install Matterbridge:
|
|
|
86
86
|
npm install -g matterbridge --omit=dev
|
|
87
87
|
```
|
|
88
88
|
|
|
89
|
-
on Linux you may need the necessary permissions:
|
|
89
|
+
on Linux or macOS you may need the necessary permissions:
|
|
90
90
|
|
|
91
91
|
```
|
|
92
92
|
sudo npm install -g matterbridge --omit=dev
|
|
@@ -142,7 +142,7 @@ Here's how to specify a different port number:
|
|
|
142
142
|
matterbridge -frontend [port number]
|
|
143
143
|
```
|
|
144
144
|
|
|
145
|
-
To use the frontend with ssl
|
|
145
|
+
To use the frontend with ssl see below.
|
|
146
146
|
|
|
147
147
|
From the frontend you can do all operations in an easy way.
|
|
148
148
|
|
|
@@ -196,7 +196,7 @@ The other Home Assistant Community Add-ons and plugins are not verified to work
|
|
|
196
196
|
<img src="screenshot/Shelly.svg" alt="Shelly plugin logo" width="100" />
|
|
197
197
|
</a>
|
|
198
198
|
|
|
199
|
-
Matterbridge shelly plugin allows you to expose all Shelly Gen 1, Gen 2, Gen 3 and BLU devices to Matter.
|
|
199
|
+
Matterbridge shelly plugin allows you to expose all Shelly Gen 1, Gen 2, Gen 3 and Gen 4 and BLU devices to Matter.
|
|
200
200
|
|
|
201
201
|
Features:
|
|
202
202
|
|
|
@@ -253,7 +253,7 @@ It is the ideal companion of the official [Matterbridge Home Assistant Add-on](h
|
|
|
253
253
|
<img src="frontend/public/matterbridge.svg" alt="Matterbridge logo" width="100" />
|
|
254
254
|
</a>
|
|
255
255
|
|
|
256
|
-
Matterbridge Webhooks plugin allows you to expose any webhooks to Matter
|
|
256
|
+
Matterbridge Webhooks plugin allows you to expose any webhooks to Matter.
|
|
257
257
|
|
|
258
258
|
### BTHome
|
|
259
259
|
|
|
@@ -506,12 +506,6 @@ As of version 18.4.x, the Robot is supported by the Home app only as a single, n
|
|
|
506
506
|
|
|
507
507
|
If a Robot is present alongside other devices in the bridge, the entire bridge becomes unstable in the Home app.
|
|
508
508
|
|
|
509
|
-
### Concentration measurements clusters
|
|
510
|
-
|
|
511
|
-
As of version 18.4.x, all cluster derived from the concentration measurement cluster hang the Home app while pairing and the entire bridge becomes unstable in the Home app.
|
|
512
|
-
|
|
513
|
-
For example: air quality sensors with TVOC measurement or co sensors with CarbonMonoxide measurement.
|
|
514
|
-
|
|
515
509
|
## Home Assistant
|
|
516
510
|
|
|
517
511
|
So far is the only controller supporting some Matter 1.2, 1.3 and 1.4 device type:
|
|
@@ -559,7 +553,7 @@ There is no support for these Matter device types:
|
|
|
559
553
|
|
|
560
554
|
In the zigbee2mqtt and shelly plugins select the option to expose
|
|
561
555
|
the switch devices like light or outlet cause they don't show up like switch
|
|
562
|
-
(Matterbridge uses a
|
|
556
|
+
(Matterbridge uses a switch device type without client cluster).
|
|
563
557
|
|
|
564
558
|
## SmartThings
|
|
565
559
|
|
package/dist/cli.js
CHANGED
|
@@ -1,44 +1,18 @@
|
|
|
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.0
|
|
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 { EventEmitter } from 'node:events';
|
|
30
6
|
import { inspect } from 'node:util';
|
|
31
7
|
export const cliEmitter = new EventEmitter();
|
|
32
8
|
export let instance;
|
|
33
|
-
// Inspectop
|
|
34
9
|
let session;
|
|
35
|
-
// Cpu and memory check
|
|
36
10
|
let memoryCheckInterval;
|
|
37
11
|
let prevCpus;
|
|
38
12
|
export let lastCpuUsage = 0;
|
|
39
13
|
let peakCpu = 0;
|
|
40
14
|
let peakRss = 0;
|
|
41
|
-
const log = new AnsiLogger({ logName: 'Cli', logTimestampFormat: 4
|
|
15
|
+
const log = new AnsiLogger({ logName: 'Cli', logTimestampFormat: 4, logLevel: hasParameter('debug') ? "debug" : "info" });
|
|
42
16
|
const formatMemoryUsage = (bytes) => {
|
|
43
17
|
if (bytes >= 1024 ** 3) {
|
|
44
18
|
return `${(bytes / 1024 ** 3).toFixed(2)} GB`;
|
|
@@ -71,11 +45,9 @@ async function startCpuMemoryCheck() {
|
|
|
71
45
|
prevCpus = os.cpus();
|
|
72
46
|
clearInterval(memoryCheckInterval);
|
|
73
47
|
const interval = () => {
|
|
74
|
-
// Get the os uptime
|
|
75
48
|
const systemUptime = formatOsUpTime(Math.floor(os.uptime()));
|
|
76
49
|
const processUptime = formatOsUpTime(Math.floor(process.uptime()));
|
|
77
50
|
cliEmitter.emit('uptime', systemUptime, processUptime);
|
|
78
|
-
// Get the memory usage
|
|
79
51
|
const totalMememory = formatMemoryUsage(os.totalmem());
|
|
80
52
|
const freeMemory = formatMemoryUsage(os.freemem());
|
|
81
53
|
const memoryUsageRaw = process.memoryUsage();
|
|
@@ -87,11 +59,10 @@ async function startCpuMemoryCheck() {
|
|
|
87
59
|
if (memoryUsageRaw.rss > peakRss)
|
|
88
60
|
peakRss = memoryUsageRaw.rss;
|
|
89
61
|
cliEmitter.emit('memory', totalMememory, freeMemory, rss, heapTotal, heapUsed, external, arrayBuffers);
|
|
90
|
-
// Get the cpu usage
|
|
91
62
|
const currCpus = os.cpus();
|
|
92
63
|
let cpuUsageLog;
|
|
93
64
|
if (currCpus.length !== prevCpus.length) {
|
|
94
|
-
prevCpus = currCpus;
|
|
65
|
+
prevCpus = currCpus;
|
|
95
66
|
log.debug(`Cpu check length failed, resetting previous cpus`);
|
|
96
67
|
return;
|
|
97
68
|
}
|
|
@@ -117,7 +88,6 @@ async function startCpuMemoryCheck() {
|
|
|
117
88
|
cliEmitter.emit('cpu', lastCpuUsage);
|
|
118
89
|
}
|
|
119
90
|
prevCpus = currCpus;
|
|
120
|
-
// Show the cpu and memory usage
|
|
121
91
|
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}`);
|
|
122
92
|
};
|
|
123
93
|
interval();
|
|
@@ -145,7 +115,6 @@ async function stopInspector() {
|
|
|
145
115
|
return;
|
|
146
116
|
}
|
|
147
117
|
try {
|
|
148
|
-
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
149
118
|
const result = await new Promise((resolve, reject) => {
|
|
150
119
|
session?.post('HeapProfiler.stopSampling', (err, result) => (err ? reject(err) : resolve(result)));
|
|
151
120
|
});
|
|
@@ -190,7 +159,6 @@ async function restart() {
|
|
|
190
159
|
}
|
|
191
160
|
async function update() {
|
|
192
161
|
log.debug('Received update event, updating...');
|
|
193
|
-
// TODO: Implement update logic outside of matterbridge
|
|
194
162
|
instance = await Matterbridge.loadInstance(true);
|
|
195
163
|
registerHandlers();
|
|
196
164
|
}
|
|
@@ -210,7 +178,6 @@ async function main() {
|
|
|
210
178
|
log.debug(`***Matterbridge.loadInstance(true) called`);
|
|
211
179
|
instance = await Matterbridge.loadInstance(true);
|
|
212
180
|
log.debug(`***Matterbridge.loadInstance(true) exited`);
|
|
213
|
-
// Check if the instance needs to shut down from parseCommandLine()
|
|
214
181
|
if (!instance || instance.shutdown) {
|
|
215
182
|
shutdown();
|
|
216
183
|
}
|
|
@@ -218,11 +185,9 @@ async function main() {
|
|
|
218
185
|
registerHandlers();
|
|
219
186
|
}
|
|
220
187
|
}
|
|
221
|
-
// Run the main function
|
|
222
188
|
process.title = 'matterbridge';
|
|
223
189
|
main().catch((error) => {
|
|
224
190
|
const errorMessage = error instanceof Error ? error.message : error;
|
|
225
191
|
const errorInspect = inspect(error, { depth: 10 });
|
|
226
192
|
log.error(`Matterbridge.loadInstance() failed with error: ${errorMessage}\nstack: ${errorInspect}`);
|
|
227
193
|
});
|
|
228
|
-
//# sourceMappingURL=cli.js.map
|
package/dist/cluster/export.js
CHANGED
|
@@ -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
|
package/dist/deviceManager.js
CHANGED
|
@@ -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
|
|
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
|