matterbridge 3.4.3-dev-20251209-e6cb85f → 3.4.3
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/README.md +2 -3
- package/dist/broadcastServer.d.ts +144 -0
- package/dist/broadcastServer.d.ts.map +1 -0
- package/dist/broadcastServer.js +119 -0
- package/dist/broadcastServer.js.map +1 -0
- package/dist/broadcastServerTypes.d.ts +841 -0
- package/dist/broadcastServerTypes.d.ts.map +1 -0
- package/dist/broadcastServerTypes.js +24 -0
- package/dist/broadcastServerTypes.js.map +1 -0
- package/dist/cli.d.ts +30 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +97 -1
- package/dist/cli.js.map +1 -0
- package/dist/cliEmitter.d.ts +50 -0
- package/dist/cliEmitter.d.ts.map +1 -0
- package/dist/cliEmitter.js +37 -0
- package/dist/cliEmitter.js.map +1 -0
- package/dist/cliHistory.d.ts +48 -0
- package/dist/cliHistory.d.ts.map +1 -0
- package/dist/cliHistory.js +38 -0
- package/dist/cliHistory.js.map +1 -0
- package/dist/clusters/export.d.ts +2 -0
- package/dist/clusters/export.d.ts.map +1 -0
- package/dist/clusters/export.js +2 -0
- package/dist/clusters/export.js.map +1 -0
- package/dist/deviceManager.d.ts +135 -0
- package/dist/deviceManager.d.ts.map +1 -0
- package/dist/deviceManager.js +113 -1
- package/dist/deviceManager.js.map +1 -0
- package/dist/devices/airConditioner.d.ts +98 -0
- package/dist/devices/airConditioner.d.ts.map +1 -0
- package/dist/devices/airConditioner.js +57 -0
- package/dist/devices/airConditioner.js.map +1 -0
- package/dist/devices/batteryStorage.d.ts +48 -0
- package/dist/devices/batteryStorage.d.ts.map +1 -0
- package/dist/devices/batteryStorage.js +48 -1
- package/dist/devices/batteryStorage.js.map +1 -0
- package/dist/devices/cooktop.d.ts +61 -0
- package/dist/devices/cooktop.d.ts.map +1 -0
- package/dist/devices/cooktop.js +56 -0
- package/dist/devices/cooktop.js.map +1 -0
- package/dist/devices/dishwasher.d.ts +71 -0
- package/dist/devices/dishwasher.d.ts.map +1 -0
- package/dist/devices/dishwasher.js +57 -0
- package/dist/devices/dishwasher.js.map +1 -0
- package/dist/devices/evse.d.ts +76 -0
- package/dist/devices/evse.d.ts.map +1 -0
- package/dist/devices/evse.js +74 -10
- package/dist/devices/evse.js.map +1 -0
- package/dist/devices/export.d.ts +17 -0
- package/dist/devices/export.d.ts.map +1 -0
- package/dist/devices/export.js +5 -0
- package/dist/devices/export.js.map +1 -0
- package/dist/devices/extractorHood.d.ts +46 -0
- package/dist/devices/extractorHood.d.ts.map +1 -0
- package/dist/devices/extractorHood.js +43 -0
- package/dist/devices/extractorHood.js.map +1 -0
- package/dist/devices/heatPump.d.ts +47 -0
- package/dist/devices/heatPump.d.ts.map +1 -0
- package/dist/devices/heatPump.js +50 -2
- package/dist/devices/heatPump.js.map +1 -0
- package/dist/devices/laundryDryer.d.ts +67 -0
- package/dist/devices/laundryDryer.d.ts.map +1 -0
- package/dist/devices/laundryDryer.js +62 -3
- package/dist/devices/laundryDryer.js.map +1 -0
- package/dist/devices/laundryWasher.d.ts +81 -0
- package/dist/devices/laundryWasher.d.ts.map +1 -0
- package/dist/devices/laundryWasher.js +70 -4
- package/dist/devices/laundryWasher.js.map +1 -0
- package/dist/devices/microwaveOven.d.ts +168 -0
- package/dist/devices/microwaveOven.d.ts.map +1 -0
- package/dist/devices/microwaveOven.js +88 -5
- package/dist/devices/microwaveOven.js.map +1 -0
- package/dist/devices/oven.d.ts +105 -0
- package/dist/devices/oven.d.ts.map +1 -0
- package/dist/devices/oven.js +85 -0
- package/dist/devices/oven.js.map +1 -0
- package/dist/devices/refrigerator.d.ts +118 -0
- package/dist/devices/refrigerator.d.ts.map +1 -0
- package/dist/devices/refrigerator.js +102 -0
- package/dist/devices/refrigerator.js.map +1 -0
- package/dist/devices/roboticVacuumCleaner.d.ts +112 -0
- package/dist/devices/roboticVacuumCleaner.d.ts.map +1 -0
- package/dist/devices/roboticVacuumCleaner.js +100 -9
- package/dist/devices/roboticVacuumCleaner.js.map +1 -0
- package/dist/devices/solarPower.d.ts +40 -0
- package/dist/devices/solarPower.d.ts.map +1 -0
- package/dist/devices/solarPower.js +38 -0
- package/dist/devices/solarPower.js.map +1 -0
- package/dist/devices/speaker.d.ts +87 -0
- package/dist/devices/speaker.d.ts.map +1 -0
- package/dist/devices/speaker.js +84 -0
- package/dist/devices/speaker.js.map +1 -0
- package/dist/devices/temperatureControl.d.ts +166 -0
- package/dist/devices/temperatureControl.d.ts.map +1 -0
- package/dist/devices/temperatureControl.js +24 -3
- package/dist/devices/temperatureControl.js.map +1 -0
- package/dist/devices/waterHeater.d.ts +111 -0
- package/dist/devices/waterHeater.d.ts.map +1 -0
- package/dist/devices/waterHeater.js +82 -2
- package/dist/devices/waterHeater.js.map +1 -0
- package/dist/dgram/coap.d.ts +205 -0
- package/dist/dgram/coap.d.ts.map +1 -0
- package/dist/dgram/coap.js +126 -13
- package/dist/dgram/coap.js.map +1 -0
- package/dist/dgram/dgram.d.ts +141 -0
- package/dist/dgram/dgram.d.ts.map +1 -0
- package/dist/dgram/dgram.js +114 -2
- package/dist/dgram/dgram.js.map +1 -0
- package/dist/dgram/mb_coap.d.ts +24 -0
- package/dist/dgram/mb_coap.d.ts.map +1 -0
- package/dist/dgram/mb_coap.js +41 -3
- package/dist/dgram/mb_coap.js.map +1 -0
- package/dist/dgram/mb_mdns.d.ts +24 -0
- package/dist/dgram/mb_mdns.d.ts.map +1 -0
- package/dist/dgram/mb_mdns.js +80 -15
- package/dist/dgram/mb_mdns.js.map +1 -0
- package/dist/dgram/mdns.d.ts +290 -0
- package/dist/dgram/mdns.d.ts.map +1 -0
- package/dist/dgram/mdns.js +299 -137
- package/dist/dgram/mdns.js.map +1 -0
- package/dist/dgram/multicast.d.ts +67 -0
- package/dist/dgram/multicast.d.ts.map +1 -0
- package/dist/dgram/multicast.js +62 -1
- package/dist/dgram/multicast.js.map +1 -0
- package/dist/dgram/unicast.d.ts +56 -0
- package/dist/dgram/unicast.d.ts.map +1 -0
- package/dist/dgram/unicast.js +54 -0
- package/dist/dgram/unicast.js.map +1 -0
- package/dist/frontend.d.ts +238 -0
- package/dist/frontend.d.ts.map +1 -0
- package/dist/frontend.js +455 -35
- package/dist/frontend.js.map +1 -0
- package/dist/frontendTypes.d.ts +529 -0
- package/dist/frontendTypes.d.ts.map +1 -0
- package/dist/frontendTypes.js +45 -0
- package/dist/frontendTypes.js.map +1 -0
- package/dist/helpers.d.ts +48 -0
- package/dist/helpers.d.ts.map +1 -0
- package/dist/helpers.js +53 -0
- package/dist/helpers.js.map +1 -0
- package/dist/index.d.ts +34 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +25 -0
- package/dist/index.js.map +1 -0
- package/dist/jestutils/export.d.ts +2 -0
- package/dist/jestutils/export.d.ts.map +1 -0
- package/dist/jestutils/export.js +1 -0
- package/dist/jestutils/export.js.map +1 -0
- package/dist/jestutils/jestHelpers.d.ts +345 -0
- package/dist/jestutils/jestHelpers.d.ts.map +1 -0
- package/dist/jestutils/jestHelpers.js +371 -14
- package/dist/jestutils/jestHelpers.js.map +1 -0
- package/dist/logger/export.d.ts +2 -0
- package/dist/logger/export.d.ts.map +1 -0
- package/dist/logger/export.js +1 -0
- package/dist/logger/export.js.map +1 -0
- package/dist/matter/behaviors.d.ts +2 -0
- package/dist/matter/behaviors.d.ts.map +1 -0
- package/dist/matter/behaviors.js +2 -0
- package/dist/matter/behaviors.js.map +1 -0
- package/dist/matter/clusters.d.ts +2 -0
- package/dist/matter/clusters.d.ts.map +1 -0
- package/dist/matter/clusters.js +2 -0
- package/dist/matter/clusters.js.map +1 -0
- package/dist/matter/devices.d.ts +2 -0
- package/dist/matter/devices.d.ts.map +1 -0
- package/dist/matter/devices.js +2 -0
- package/dist/matter/devices.js.map +1 -0
- package/dist/matter/endpoints.d.ts +2 -0
- package/dist/matter/endpoints.d.ts.map +1 -0
- package/dist/matter/endpoints.js +2 -0
- package/dist/matter/endpoints.js.map +1 -0
- package/dist/matter/export.d.ts +5 -0
- package/dist/matter/export.d.ts.map +1 -0
- package/dist/matter/export.js +3 -0
- package/dist/matter/export.js.map +1 -0
- package/dist/matter/types.d.ts +3 -0
- package/dist/matter/types.d.ts.map +1 -0
- package/dist/matter/types.js +3 -0
- package/dist/matter/types.js.map +1 -0
- package/dist/matterNode.d.ts +342 -0
- package/dist/matterNode.d.ts.map +1 -0
- package/dist/matterNode.js +369 -8
- package/dist/matterNode.js.map +1 -0
- package/dist/matterbridge.d.ts +492 -0
- package/dist/matterbridge.d.ts.map +1 -0
- package/dist/matterbridge.js +811 -46
- package/dist/matterbridge.js.map +1 -0
- package/dist/matterbridgeAccessoryPlatform.d.ts +41 -0
- package/dist/matterbridgeAccessoryPlatform.d.ts.map +1 -0
- package/dist/matterbridgeAccessoryPlatform.js +38 -0
- package/dist/matterbridgeAccessoryPlatform.js.map +1 -0
- package/dist/matterbridgeBehaviors.d.ts +2404 -0
- package/dist/matterbridgeBehaviors.d.ts.map +1 -0
- package/dist/matterbridgeBehaviors.js +68 -5
- package/dist/matterbridgeBehaviors.js.map +1 -0
- package/dist/matterbridgeDeviceTypes.d.ts +698 -0
- package/dist/matterbridgeDeviceTypes.d.ts.map +1 -0
- package/dist/matterbridgeDeviceTypes.js +635 -14
- package/dist/matterbridgeDeviceTypes.js.map +1 -0
- package/dist/matterbridgeDynamicPlatform.d.ts +41 -0
- package/dist/matterbridgeDynamicPlatform.d.ts.map +1 -0
- package/dist/matterbridgeDynamicPlatform.js +38 -0
- package/dist/matterbridgeDynamicPlatform.js.map +1 -0
- package/dist/matterbridgeEndpoint.d.ts +1507 -0
- package/dist/matterbridgeEndpoint.d.ts.map +1 -0
- package/dist/matterbridgeEndpoint.js +1444 -53
- package/dist/matterbridgeEndpoint.js.map +1 -0
- package/dist/matterbridgeEndpointHelpers.d.ts +787 -0
- package/dist/matterbridgeEndpointHelpers.d.ts.map +1 -0
- package/dist/matterbridgeEndpointHelpers.js +483 -20
- package/dist/matterbridgeEndpointHelpers.js.map +1 -0
- package/dist/matterbridgeEndpointTypes.d.ts +166 -0
- package/dist/matterbridgeEndpointTypes.d.ts.map +1 -0
- package/dist/matterbridgeEndpointTypes.js +25 -0
- package/dist/matterbridgeEndpointTypes.js.map +1 -0
- package/dist/matterbridgePlatform.d.ts +539 -0
- package/dist/matterbridgePlatform.d.ts.map +1 -0
- package/dist/matterbridgePlatform.js +451 -1
- package/dist/matterbridgePlatform.js.map +1 -0
- package/dist/matterbridgeTypes.d.ts +251 -0
- package/dist/matterbridgeTypes.d.ts.map +1 -0
- package/dist/matterbridgeTypes.js +26 -0
- package/dist/matterbridgeTypes.js.map +1 -0
- package/dist/pluginManager.d.ts +372 -0
- package/dist/pluginManager.d.ts.map +1 -0
- package/dist/pluginManager.js +341 -5
- package/dist/pluginManager.js.map +1 -0
- package/dist/shelly.d.ts +181 -0
- package/dist/shelly.d.ts.map +1 -0
- package/dist/shelly.js +178 -7
- package/dist/shelly.js.map +1 -0
- package/dist/storage/export.d.ts +2 -0
- package/dist/storage/export.d.ts.map +1 -0
- package/dist/storage/export.js +1 -0
- package/dist/storage/export.js.map +1 -0
- package/dist/update.d.ts +84 -0
- package/dist/update.d.ts.map +1 -0
- package/dist/update.js +93 -1
- package/dist/update.js.map +1 -0
- package/dist/utils/colorUtils.d.ts +101 -0
- package/dist/utils/colorUtils.d.ts.map +1 -0
- package/dist/utils/colorUtils.js +97 -2
- package/dist/utils/colorUtils.js.map +1 -0
- package/dist/utils/commandLine.d.ts +66 -0
- package/dist/utils/commandLine.d.ts.map +1 -0
- package/dist/utils/commandLine.js +60 -0
- package/dist/utils/commandLine.js.map +1 -0
- package/dist/utils/copyDirectory.d.ts +35 -0
- package/dist/utils/copyDirectory.d.ts.map +1 -0
- package/dist/utils/copyDirectory.js +37 -0
- package/dist/utils/copyDirectory.js.map +1 -0
- package/dist/utils/createDirectory.d.ts +34 -0
- package/dist/utils/createDirectory.d.ts.map +1 -0
- package/dist/utils/createDirectory.js +33 -0
- package/dist/utils/createDirectory.js.map +1 -0
- package/dist/utils/createZip.d.ts +39 -0
- package/dist/utils/createZip.d.ts.map +1 -0
- package/dist/utils/createZip.js +47 -2
- package/dist/utils/createZip.js.map +1 -0
- package/dist/utils/deepCopy.d.ts +32 -0
- package/dist/utils/deepCopy.d.ts.map +1 -0
- package/dist/utils/deepCopy.js +39 -0
- package/dist/utils/deepCopy.js.map +1 -0
- package/dist/utils/deepEqual.d.ts +54 -0
- package/dist/utils/deepEqual.d.ts.map +1 -0
- package/dist/utils/deepEqual.js +72 -1
- package/dist/utils/deepEqual.js.map +1 -0
- package/dist/utils/error.d.ts +45 -0
- package/dist/utils/error.d.ts.map +1 -0
- package/dist/utils/error.js +42 -0
- package/dist/utils/error.js.map +1 -0
- package/dist/utils/export.d.ts +13 -0
- package/dist/utils/export.d.ts.map +1 -0
- package/dist/utils/export.js +1 -0
- package/dist/utils/export.js.map +1 -0
- package/dist/utils/format.d.ts +53 -0
- package/dist/utils/format.d.ts.map +1 -0
- package/dist/utils/format.js +49 -0
- package/dist/utils/format.js.map +1 -0
- package/dist/utils/hex.d.ts +89 -0
- package/dist/utils/hex.d.ts.map +1 -0
- package/dist/utils/hex.js +124 -0
- package/dist/utils/hex.js.map +1 -0
- package/dist/utils/inspector.d.ts +87 -0
- package/dist/utils/inspector.d.ts.map +1 -0
- package/dist/utils/inspector.js +69 -1
- package/dist/utils/inspector.js.map +1 -0
- package/dist/utils/isvalid.d.ts +103 -0
- package/dist/utils/isvalid.d.ts.map +1 -0
- package/dist/utils/isvalid.js +101 -0
- package/dist/utils/isvalid.js.map +1 -0
- package/dist/utils/network.d.ts +111 -0
- package/dist/utils/network.d.ts.map +1 -0
- package/dist/utils/network.js +96 -5
- package/dist/utils/network.js.map +1 -0
- package/dist/utils/spawn.d.ts +33 -0
- package/dist/utils/spawn.d.ts.map +1 -0
- package/dist/utils/spawn.js +71 -1
- package/dist/utils/spawn.js.map +1 -0
- package/dist/utils/tracker.d.ts +108 -0
- package/dist/utils/tracker.d.ts.map +1 -0
- package/dist/utils/tracker.js +64 -1
- package/dist/utils/tracker.js.map +1 -0
- package/dist/utils/wait.d.ts +54 -0
- package/dist/utils/wait.d.ts.map +1 -0
- package/dist/utils/wait.js +60 -8
- package/dist/utils/wait.js.map +1 -0
- package/dist/workerGlobalPrefix.d.ts +25 -0
- package/dist/workerGlobalPrefix.d.ts.map +1 -0
- package/dist/workerGlobalPrefix.js +37 -5
- package/dist/workerGlobalPrefix.js.map +1 -0
- package/dist/workerTypes.d.ts +52 -0
- package/dist/workerTypes.d.ts.map +1 -0
- package/dist/workerTypes.js +24 -0
- package/dist/workerTypes.js.map +1 -0
- package/dist/workers.d.ts +69 -0
- package/dist/workers.d.ts.map +1 -0
- package/dist/workers.js +68 -4
- package/dist/workers.js.map +1 -0
- package/npm-shrinkwrap.json +2 -2
- package/package.json +2 -1
- package/scripts/data_model.mjs +2058 -0
|
@@ -0,0 +1,135 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* This file contains the DeviceManager class.
|
|
3
|
+
*
|
|
4
|
+
* @file devices.ts
|
|
5
|
+
* @author Luca Liguori
|
|
6
|
+
* @created 2024-07-26
|
|
7
|
+
* @version 1.1.2
|
|
8
|
+
* @license Apache-2.0
|
|
9
|
+
*
|
|
10
|
+
* Copyright 2024, 2025, 2026 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
|
+
import { LogLevel } from 'node-ansi-logger';
|
|
25
|
+
import type { MatterbridgeEndpoint } from './matterbridgeEndpoint.js';
|
|
26
|
+
import { type BaseDevice } from './matterbridgeTypes.js';
|
|
27
|
+
/**
|
|
28
|
+
* Converts a MatterbridgeEndpoint to a BaseDevice.
|
|
29
|
+
*
|
|
30
|
+
* @param {MatterbridgeEndpoint} device The MatterbridgeEndpoint to convert.
|
|
31
|
+
* @returns {BaseDevice} The converted BaseDevice.
|
|
32
|
+
*/
|
|
33
|
+
export declare function toBaseDevice(device: MatterbridgeEndpoint | BaseDevice): BaseDevice;
|
|
34
|
+
/**
|
|
35
|
+
* Manages Matterbridge devices.
|
|
36
|
+
*/
|
|
37
|
+
export declare class DeviceManager {
|
|
38
|
+
private readonly _devices;
|
|
39
|
+
private readonly log;
|
|
40
|
+
private readonly server;
|
|
41
|
+
private readonly debug;
|
|
42
|
+
private readonly verbose;
|
|
43
|
+
/**
|
|
44
|
+
* Creates an instance of DeviceManager.
|
|
45
|
+
*/
|
|
46
|
+
constructor();
|
|
47
|
+
destroy(): void;
|
|
48
|
+
private msgHandler;
|
|
49
|
+
/**
|
|
50
|
+
* Gets the number of devices.
|
|
51
|
+
*
|
|
52
|
+
* @returns {number} The number of devices.
|
|
53
|
+
*/
|
|
54
|
+
get length(): number;
|
|
55
|
+
/**
|
|
56
|
+
* Gets the number of devices.
|
|
57
|
+
*
|
|
58
|
+
* @returns {number} The number of devices.
|
|
59
|
+
*/
|
|
60
|
+
get size(): number;
|
|
61
|
+
/**
|
|
62
|
+
* Checks if a device with the specified unique ID exists.
|
|
63
|
+
*
|
|
64
|
+
* @param {string} uniqueId - The unique ID of the device.
|
|
65
|
+
* @returns {boolean} True if the device exists, false otherwise.
|
|
66
|
+
*/
|
|
67
|
+
has(uniqueId: string): boolean;
|
|
68
|
+
/**
|
|
69
|
+
* Gets a device by its unique ID.
|
|
70
|
+
*
|
|
71
|
+
* @param {string} uniqueId - The unique ID of the device.
|
|
72
|
+
* @returns {MatterbridgeEndpoint | undefined} The device, or undefined if not found.
|
|
73
|
+
*/
|
|
74
|
+
get(uniqueId: string): MatterbridgeEndpoint | undefined;
|
|
75
|
+
/**
|
|
76
|
+
* Adds a device to the manager.
|
|
77
|
+
*
|
|
78
|
+
* @param {MatterbridgeEndpoint} device - The device to add.
|
|
79
|
+
* @returns {MatterbridgeEndpoint} The added device.
|
|
80
|
+
* @throws {Error} If the device does not have a unique ID.
|
|
81
|
+
*/
|
|
82
|
+
set(device: MatterbridgeEndpoint): MatterbridgeEndpoint;
|
|
83
|
+
/**
|
|
84
|
+
* Removes a device from the manager.
|
|
85
|
+
*
|
|
86
|
+
* @param {MatterbridgeEndpoint} device - The device to remove.
|
|
87
|
+
* @returns {boolean} True if the device was removed, false otherwise.
|
|
88
|
+
* @throws {Error} If the device does not have a unique ID.
|
|
89
|
+
*/
|
|
90
|
+
remove(device: MatterbridgeEndpoint): boolean;
|
|
91
|
+
/**
|
|
92
|
+
* Clears all devices from the manager.
|
|
93
|
+
*/
|
|
94
|
+
clear(): void;
|
|
95
|
+
/**
|
|
96
|
+
* Converts a MatterbridgeEndpoint to a BaseDevice.
|
|
97
|
+
*
|
|
98
|
+
* @param {MatterbridgeEndpoint} device The MatterbridgeEndpoint to convert.
|
|
99
|
+
* @returns {BaseDevice} The converted BaseDevice.
|
|
100
|
+
*/
|
|
101
|
+
private toBaseDevice;
|
|
102
|
+
/**
|
|
103
|
+
* Gets an array of all devices.
|
|
104
|
+
*
|
|
105
|
+
* @returns {MatterbridgeEndpoint[]} An array of all devices.
|
|
106
|
+
*/
|
|
107
|
+
array(): MatterbridgeEndpoint[];
|
|
108
|
+
/**
|
|
109
|
+
* Gets a base array of all devices suitable for serialization.
|
|
110
|
+
*
|
|
111
|
+
* @param {string} [pluginName] - Optional plugin name to filter devices.
|
|
112
|
+
* @returns {ApiDevices[]} A base array of all devices.
|
|
113
|
+
*/
|
|
114
|
+
baseArray(pluginName?: string): BaseDevice[];
|
|
115
|
+
/**
|
|
116
|
+
* Iterates over all devices.
|
|
117
|
+
*
|
|
118
|
+
* @returns {IterableIterator<MatterbridgeEndpoint>} An iterator for the devices.
|
|
119
|
+
*/
|
|
120
|
+
[Symbol.iterator](): MapIterator<MatterbridgeEndpoint>;
|
|
121
|
+
/**
|
|
122
|
+
* Asynchronously iterates over each device and calls the provided callback function.
|
|
123
|
+
*
|
|
124
|
+
* @param {(device: MatterbridgeEndpoint) => Promise<void>} callback - The callback function to call with each device.
|
|
125
|
+
* @returns {Promise<void>} A promise that resolves when all callbacks have been called.
|
|
126
|
+
*/
|
|
127
|
+
forEach(callback: (device: MatterbridgeEndpoint) => Promise<void>): Promise<void>;
|
|
128
|
+
/**
|
|
129
|
+
* Sets the log level.
|
|
130
|
+
*
|
|
131
|
+
* @param {LogLevel} logLevel - The log level to set.
|
|
132
|
+
*/
|
|
133
|
+
set logLevel(logLevel: LogLevel);
|
|
134
|
+
}
|
|
135
|
+
//# sourceMappingURL=deviceManager.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"deviceManager.d.ts","sourceRoot":"","sources":["../src/deviceManager.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;GAsBG;AAGH,OAAO,EAAkD,QAAQ,EAAmB,MAAM,kBAAkB,CAAC;AAG7G,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAC;AACtE,OAAO,EAAE,KAAK,UAAU,EAAO,MAAM,wBAAwB,CAAC;AAK9D;;;;;GAKG;AACH,wBAAgB,YAAY,CAAC,MAAM,EAAE,oBAAoB,GAAG,UAAU,GAAG,UAAU,CA0BlF;AAED;;GAEG;AACH,qBAAa,aAAa;IACxB,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAA2C;IACpE,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAa;IACjC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAkB;IACzC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAoD;IAC1E,OAAO,CAAC,QAAQ,CAAC,OAAO,CAA2B;IAEnD;;OAEG;;IASH,OAAO,IAAI,IAAI;YAKD,UAAU;IA6CxB;;;;OAIG;IACH,IAAI,MAAM,IAAI,MAAM,CAEnB;IAED;;;;OAIG;IACH,IAAI,IAAI,IAAI,MAAM,CAEjB;IAED;;;;;OAKG;IACH,GAAG,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO;IAI9B;;;;;OAKG;IACH,GAAG,CAAC,QAAQ,EAAE,MAAM,GAAG,oBAAoB,GAAG,SAAS;IAIvD;;;;;;OAMG;IACH,GAAG,CAAC,MAAM,EAAE,oBAAoB,GAAG,oBAAoB;IAOvD;;;;;;OAMG;IACH,MAAM,CAAC,MAAM,EAAE,oBAAoB,GAAG,OAAO;IAM7C;;OAEG;IACH,KAAK,IAAI,IAAI;IAIb;;;;;OAKG;IACH,OAAO,CAAC,YAAY;IAIpB;;;;OAIG;IACH,KAAK,IAAI,oBAAoB,EAAE;IAI/B;;;;;OAKG;IACH,SAAS,CAAC,UAAU,CAAC,EAAE,MAAM,GAAG,UAAU,EAAE;IAU5C;;;;OAIG;IACH,CAAC,MAAM,CAAC,QAAQ,CAAC;IAIjB;;;;;OAKG;IACG,OAAO,CAAC,QAAQ,EAAE,CAAC,MAAM,EAAE,oBAAoB,KAAK,OAAO,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;IAavF;;;;OAIG;IACH,IAAI,QAAQ,CAAC,QAAQ,EAAE,QAAQ,EAE9B;CACF"}
|
package/dist/deviceManager.js
CHANGED
|
@@ -1,9 +1,40 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* This file contains the DeviceManager class.
|
|
3
|
+
*
|
|
4
|
+
* @file devices.ts
|
|
5
|
+
* @author Luca Liguori
|
|
6
|
+
* @created 2024-07-26
|
|
7
|
+
* @version 1.1.2
|
|
8
|
+
* @license Apache-2.0
|
|
9
|
+
*
|
|
10
|
+
* Copyright 2024, 2025, 2026 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
|
+
// AnsiLogger module
|
|
1
25
|
import { AnsiLogger, BLUE, CYAN, db, debugStringify, er } from 'node-ansi-logger';
|
|
2
26
|
import { dev } from './matterbridgeTypes.js';
|
|
3
27
|
import { BroadcastServer } from './broadcastServer.js';
|
|
4
28
|
import { hasParameter } from './utils/commandLine.js';
|
|
29
|
+
/**
|
|
30
|
+
* Converts a MatterbridgeEndpoint to a BaseDevice.
|
|
31
|
+
*
|
|
32
|
+
* @param {MatterbridgeEndpoint} device The MatterbridgeEndpoint to convert.
|
|
33
|
+
* @returns {BaseDevice} The converted BaseDevice.
|
|
34
|
+
*/
|
|
5
35
|
export function toBaseDevice(device) {
|
|
6
36
|
return {
|
|
37
|
+
// MatterbridgeEndpoint properties
|
|
7
38
|
mode: device.mode,
|
|
8
39
|
plugin: device.plugin,
|
|
9
40
|
configUrl: device.configUrl,
|
|
@@ -23,18 +54,25 @@ export function toBaseDevice(device) {
|
|
|
23
54
|
originalId: device.originalId,
|
|
24
55
|
name: device.name,
|
|
25
56
|
deviceType: device.deviceType,
|
|
57
|
+
// Endpoint properties
|
|
26
58
|
number: device.number,
|
|
27
59
|
id: device.id,
|
|
28
60
|
};
|
|
29
61
|
}
|
|
62
|
+
/**
|
|
63
|
+
* Manages Matterbridge devices.
|
|
64
|
+
*/
|
|
30
65
|
export class DeviceManager {
|
|
31
66
|
_devices = new Map();
|
|
32
67
|
log;
|
|
33
68
|
server;
|
|
34
69
|
debug = hasParameter('debug') || hasParameter('verbose');
|
|
35
70
|
verbose = hasParameter('verbose');
|
|
71
|
+
/**
|
|
72
|
+
* Creates an instance of DeviceManager.
|
|
73
|
+
*/
|
|
36
74
|
constructor() {
|
|
37
|
-
this.log = new AnsiLogger({ logName: 'DeviceManager', logTimestampFormat: 4
|
|
75
|
+
this.log = new AnsiLogger({ logName: 'DeviceManager', logTimestampFormat: 4 /* TimestampFormat.TIME_MILLIS */, logLevel: hasParameter('debug') ? "debug" /* LogLevel.DEBUG */ : "info" /* LogLevel.INFO */ });
|
|
38
76
|
this.log.debug('Matterbridge device manager starting...');
|
|
39
77
|
this.server = new BroadcastServer('devices', this.log);
|
|
40
78
|
this.server.on('broadcast_message', this.msgHandler.bind(this));
|
|
@@ -90,18 +128,47 @@ export class DeviceManager {
|
|
|
90
128
|
}
|
|
91
129
|
}
|
|
92
130
|
}
|
|
131
|
+
/**
|
|
132
|
+
* Gets the number of devices.
|
|
133
|
+
*
|
|
134
|
+
* @returns {number} The number of devices.
|
|
135
|
+
*/
|
|
93
136
|
get length() {
|
|
94
137
|
return this._devices.size;
|
|
95
138
|
}
|
|
139
|
+
/**
|
|
140
|
+
* Gets the number of devices.
|
|
141
|
+
*
|
|
142
|
+
* @returns {number} The number of devices.
|
|
143
|
+
*/
|
|
96
144
|
get size() {
|
|
97
145
|
return this._devices.size;
|
|
98
146
|
}
|
|
147
|
+
/**
|
|
148
|
+
* Checks if a device with the specified unique ID exists.
|
|
149
|
+
*
|
|
150
|
+
* @param {string} uniqueId - The unique ID of the device.
|
|
151
|
+
* @returns {boolean} True if the device exists, false otherwise.
|
|
152
|
+
*/
|
|
99
153
|
has(uniqueId) {
|
|
100
154
|
return this._devices.has(uniqueId);
|
|
101
155
|
}
|
|
156
|
+
/**
|
|
157
|
+
* Gets a device by its unique ID.
|
|
158
|
+
*
|
|
159
|
+
* @param {string} uniqueId - The unique ID of the device.
|
|
160
|
+
* @returns {MatterbridgeEndpoint | undefined} The device, or undefined if not found.
|
|
161
|
+
*/
|
|
102
162
|
get(uniqueId) {
|
|
103
163
|
return this._devices.get(uniqueId);
|
|
104
164
|
}
|
|
165
|
+
/**
|
|
166
|
+
* Adds a device to the manager.
|
|
167
|
+
*
|
|
168
|
+
* @param {MatterbridgeEndpoint} device - The device to add.
|
|
169
|
+
* @returns {MatterbridgeEndpoint} The added device.
|
|
170
|
+
* @throws {Error} If the device does not have a unique ID.
|
|
171
|
+
*/
|
|
105
172
|
set(device) {
|
|
106
173
|
if (!device.uniqueId)
|
|
107
174
|
throw new Error(`The device ${dev}${device.deviceName}${er} has not been initialized: uniqueId is required`);
|
|
@@ -110,6 +177,13 @@ export class DeviceManager {
|
|
|
110
177
|
this._devices.set(device.uniqueId, device);
|
|
111
178
|
return device;
|
|
112
179
|
}
|
|
180
|
+
/**
|
|
181
|
+
* Removes a device from the manager.
|
|
182
|
+
*
|
|
183
|
+
* @param {MatterbridgeEndpoint} device - The device to remove.
|
|
184
|
+
* @returns {boolean} True if the device was removed, false otherwise.
|
|
185
|
+
* @throws {Error} If the device does not have a unique ID.
|
|
186
|
+
*/
|
|
113
187
|
remove(device) {
|
|
114
188
|
if (!device.uniqueId)
|
|
115
189
|
throw new Error(`The device ${dev}${device.deviceName}${er} has not been initialized: uniqueId is required`);
|
|
@@ -117,27 +191,59 @@ export class DeviceManager {
|
|
|
117
191
|
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`);
|
|
118
192
|
return this._devices.delete(device.uniqueId);
|
|
119
193
|
}
|
|
194
|
+
/**
|
|
195
|
+
* Clears all devices from the manager.
|
|
196
|
+
*/
|
|
120
197
|
clear() {
|
|
121
198
|
this._devices.clear();
|
|
122
199
|
}
|
|
200
|
+
/**
|
|
201
|
+
* Converts a MatterbridgeEndpoint to a BaseDevice.
|
|
202
|
+
*
|
|
203
|
+
* @param {MatterbridgeEndpoint} device The MatterbridgeEndpoint to convert.
|
|
204
|
+
* @returns {BaseDevice} The converted BaseDevice.
|
|
205
|
+
*/
|
|
123
206
|
toBaseDevice(device) {
|
|
124
207
|
return toBaseDevice(device);
|
|
125
208
|
}
|
|
209
|
+
/**
|
|
210
|
+
* Gets an array of all devices.
|
|
211
|
+
*
|
|
212
|
+
* @returns {MatterbridgeEndpoint[]} An array of all devices.
|
|
213
|
+
*/
|
|
126
214
|
array() {
|
|
127
215
|
return Array.from(this._devices.values());
|
|
128
216
|
}
|
|
217
|
+
/**
|
|
218
|
+
* Gets a base array of all devices suitable for serialization.
|
|
219
|
+
*
|
|
220
|
+
* @param {string} [pluginName] - Optional plugin name to filter devices.
|
|
221
|
+
* @returns {ApiDevices[]} A base array of all devices.
|
|
222
|
+
*/
|
|
129
223
|
baseArray(pluginName) {
|
|
130
224
|
const devices = [];
|
|
131
225
|
for (const device of Array.from(this._devices.values())) {
|
|
226
|
+
// Filter by pluginName if provided
|
|
132
227
|
if (pluginName && pluginName !== device.plugin)
|
|
133
228
|
continue;
|
|
134
229
|
devices.push(this.toBaseDevice(device));
|
|
135
230
|
}
|
|
136
231
|
return devices;
|
|
137
232
|
}
|
|
233
|
+
/**
|
|
234
|
+
* Iterates over all devices.
|
|
235
|
+
*
|
|
236
|
+
* @returns {IterableIterator<MatterbridgeEndpoint>} An iterator for the devices.
|
|
237
|
+
*/
|
|
138
238
|
[Symbol.iterator]() {
|
|
139
239
|
return this._devices.values();
|
|
140
240
|
}
|
|
241
|
+
/**
|
|
242
|
+
* Asynchronously iterates over each device and calls the provided callback function.
|
|
243
|
+
*
|
|
244
|
+
* @param {(device: MatterbridgeEndpoint) => Promise<void>} callback - The callback function to call with each device.
|
|
245
|
+
* @returns {Promise<void>} A promise that resolves when all callbacks have been called.
|
|
246
|
+
*/
|
|
141
247
|
async forEach(callback) {
|
|
142
248
|
if (this.size === 0)
|
|
143
249
|
return;
|
|
@@ -151,7 +257,13 @@ export class DeviceManager {
|
|
|
151
257
|
});
|
|
152
258
|
await Promise.all(tasks);
|
|
153
259
|
}
|
|
260
|
+
/**
|
|
261
|
+
* Sets the log level.
|
|
262
|
+
*
|
|
263
|
+
* @param {LogLevel} logLevel - The log level to set.
|
|
264
|
+
*/
|
|
154
265
|
set logLevel(logLevel) {
|
|
155
266
|
this.log.logLevel = logLevel;
|
|
156
267
|
}
|
|
157
268
|
}
|
|
269
|
+
//# sourceMappingURL=deviceManager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"deviceManager.js","sourceRoot":"","sources":["../src/deviceManager.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @description This file contains the AirConditioner class.
|
|
3
|
+
* @file src/devices/airConditioner.ts
|
|
4
|
+
* @author Luca Liguori
|
|
5
|
+
* @created 2025-09-04
|
|
6
|
+
* @version 1.0.0
|
|
7
|
+
* @license Apache-2.0
|
|
8
|
+
*
|
|
9
|
+
* Copyright 2025, 2026, 2027 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
|
+
import { ThermostatUserInterfaceConfiguration } from '@matter/types/clusters/thermostat-user-interface-configuration';
|
|
24
|
+
import { FanControl } from '@matter/types/clusters/fan-control';
|
|
25
|
+
import { MatterbridgeEndpoint } from '../matterbridgeEndpoint.js';
|
|
26
|
+
/**
|
|
27
|
+
* Options for configuring an {@link AirConditioner} instance.
|
|
28
|
+
*
|
|
29
|
+
* All temperatures in °C. Typical valid range 0–50 unless otherwise noted.
|
|
30
|
+
*/
|
|
31
|
+
export interface AirConditionerOptions {
|
|
32
|
+
/** Local ambient temperature (°C). Default 23. */
|
|
33
|
+
localTemperature?: number;
|
|
34
|
+
/** Occupied heating setpoint (°C). Default 21. */
|
|
35
|
+
occupiedHeatingSetpoint?: number;
|
|
36
|
+
/** Occupied cooling setpoint (°C). Default 25. */
|
|
37
|
+
occupiedCoolingSetpoint?: number;
|
|
38
|
+
/** Minimum setpoint dead band (°C). Default 1. */
|
|
39
|
+
minSetpointDeadBand?: number;
|
|
40
|
+
/** Minimum heat setpoint limit (°C). Default 0. */
|
|
41
|
+
minHeatSetpointLimit?: number;
|
|
42
|
+
/** Maximum heat setpoint limit (°C). Default 50. */
|
|
43
|
+
maxHeatSetpointLimit?: number;
|
|
44
|
+
/** Minimum cool setpoint limit (°C). Default 0. */
|
|
45
|
+
minCoolSetpointLimit?: number;
|
|
46
|
+
/** Maximum cool setpoint limit (°C). Default 50. */
|
|
47
|
+
maxCoolSetpointLimit?: number;
|
|
48
|
+
/** Temperature display mode. Default Celsius. */
|
|
49
|
+
temperatureDisplayMode?: ThermostatUserInterfaceConfiguration.TemperatureDisplayMode;
|
|
50
|
+
/** Keypad lockout mode. Default NoLockout. */
|
|
51
|
+
keypadLockout?: ThermostatUserInterfaceConfiguration.KeypadLockout;
|
|
52
|
+
/** Schedule programming visibility. Default ScheduleProgrammingPermitted. */
|
|
53
|
+
scheduleProgrammingVisibility?: ThermostatUserInterfaceConfiguration.ScheduleProgrammingVisibility;
|
|
54
|
+
/** Fan mode. Default Off. */
|
|
55
|
+
fanMode?: FanControl.FanMode;
|
|
56
|
+
/** Fan mode sequence. Default OffLowMedHighAuto. */
|
|
57
|
+
fanModeSequence?: FanControl.FanModeSequence;
|
|
58
|
+
/** Target fan percent setting (0–100). Default 0. */
|
|
59
|
+
percentSetting?: number;
|
|
60
|
+
/** Current fan percent (0–100). Default 0. */
|
|
61
|
+
percentCurrent?: number;
|
|
62
|
+
}
|
|
63
|
+
export declare class AirConditioner extends MatterbridgeEndpoint {
|
|
64
|
+
/**
|
|
65
|
+
* Creates an instance of the AirConditioner class.
|
|
66
|
+
*
|
|
67
|
+
* A Room Air Conditioner is a device which at a minimum is capable of being turned on and off and of controlling the temperature in the living space.
|
|
68
|
+
* A Room Air Conditioner MAY also support additional capabilities via endpoint composition.
|
|
69
|
+
* The DF (Dead Front) feature is required for the On/Off cluster in this device type.
|
|
70
|
+
*
|
|
71
|
+
* @param {string} name - The name of the air conditioner.
|
|
72
|
+
* @param {string} serial - The serial number of the air conditioner.
|
|
73
|
+
* @param {AirConditionerOptions} [options] - Optional configuration values. Missing fields use defaults.
|
|
74
|
+
*
|
|
75
|
+
* Options defaults:
|
|
76
|
+
* - localTemperature: 23
|
|
77
|
+
* - occupiedHeatingSetpoint: 21
|
|
78
|
+
* - occupiedCoolingSetpoint: 25
|
|
79
|
+
* - minSetpointDeadBand: 1
|
|
80
|
+
* - minHeatSetpointLimit: 0
|
|
81
|
+
* - maxHeatSetpointLimit: 50
|
|
82
|
+
* - minCoolSetpointLimit: 0
|
|
83
|
+
* - maxCoolSetpointLimit: 50
|
|
84
|
+
* - temperatureDisplayMode: Celsius
|
|
85
|
+
* - keypadLockout: NoLockout
|
|
86
|
+
* - scheduleProgrammingVisibility: ScheduleProgrammingPermitted
|
|
87
|
+
* - fanMode: Off
|
|
88
|
+
* - fanModeSequence: OffLowMedHighAuto
|
|
89
|
+
* - percentSetting: 0
|
|
90
|
+
* - percentCurrent: 0
|
|
91
|
+
*
|
|
92
|
+
* @returns {AirConditioner} The AirConditioner instance.
|
|
93
|
+
*
|
|
94
|
+
* @remarks Not supported by Google Home.
|
|
95
|
+
*/
|
|
96
|
+
constructor(name: string, serial: string, options?: AirConditionerOptions);
|
|
97
|
+
}
|
|
98
|
+
//# sourceMappingURL=airConditioner.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"airConditioner.d.ts","sourceRoot":"","sources":["../../src/devices/airConditioner.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;GAqBG;AAGH,OAAO,EAAE,oCAAoC,EAAE,MAAM,gEAAgE,CAAC;AACtH,OAAO,EAAE,UAAU,EAAE,MAAM,oCAAoC,CAAC;AAIhE,OAAO,EAAE,oBAAoB,EAAE,MAAM,4BAA4B,CAAC;AAElE;;;;GAIG;AACH,MAAM,WAAW,qBAAqB;IACpC,kDAAkD;IAClD,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,kDAAkD;IAClD,uBAAuB,CAAC,EAAE,MAAM,CAAC;IACjC,kDAAkD;IAClD,uBAAuB,CAAC,EAAE,MAAM,CAAC;IACjC,kDAAkD;IAClD,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAC7B,mDAAmD;IACnD,oBAAoB,CAAC,EAAE,MAAM,CAAC;IAC9B,oDAAoD;IACpD,oBAAoB,CAAC,EAAE,MAAM,CAAC;IAC9B,mDAAmD;IACnD,oBAAoB,CAAC,EAAE,MAAM,CAAC;IAC9B,oDAAoD;IACpD,oBAAoB,CAAC,EAAE,MAAM,CAAC;IAC9B,iDAAiD;IACjD,sBAAsB,CAAC,EAAE,oCAAoC,CAAC,sBAAsB,CAAC;IACrF,8CAA8C;IAC9C,aAAa,CAAC,EAAE,oCAAoC,CAAC,aAAa,CAAC;IACnE,6EAA6E;IAC7E,6BAA6B,CAAC,EAAE,oCAAoC,CAAC,6BAA6B,CAAC;IACnG,6BAA6B;IAC7B,OAAO,CAAC,EAAE,UAAU,CAAC,OAAO,CAAC;IAC7B,oDAAoD;IACpD,eAAe,CAAC,EAAE,UAAU,CAAC,eAAe,CAAC;IAC7C,qDAAqD;IACrD,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,8CAA8C;IAC9C,cAAc,CAAC,EAAE,MAAM,CAAC;CACzB;AAED,qBAAa,cAAe,SAAQ,oBAAoB;IACtD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA+BG;gBACS,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,GAAE,qBAA0B;CA2B9E"}
|
|
@@ -1,8 +1,64 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @description This file contains the AirConditioner class.
|
|
3
|
+
* @file src/devices/airConditioner.ts
|
|
4
|
+
* @author Luca Liguori
|
|
5
|
+
* @created 2025-09-04
|
|
6
|
+
* @version 1.0.0
|
|
7
|
+
* @license Apache-2.0
|
|
8
|
+
*
|
|
9
|
+
* Copyright 2025, 2026, 2027 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
|
+
// Imports from @matter
|
|
1
24
|
import { ThermostatUserInterfaceConfiguration } from '@matter/types/clusters/thermostat-user-interface-configuration';
|
|
2
25
|
import { FanControl } from '@matter/types/clusters/fan-control';
|
|
26
|
+
// Matterbridge
|
|
3
27
|
import { airConditioner, powerSource } from '../matterbridgeDeviceTypes.js';
|
|
4
28
|
import { MatterbridgeEndpoint } from '../matterbridgeEndpoint.js';
|
|
5
29
|
export class AirConditioner extends MatterbridgeEndpoint {
|
|
30
|
+
/**
|
|
31
|
+
* Creates an instance of the AirConditioner class.
|
|
32
|
+
*
|
|
33
|
+
* A Room Air Conditioner is a device which at a minimum is capable of being turned on and off and of controlling the temperature in the living space.
|
|
34
|
+
* A Room Air Conditioner MAY also support additional capabilities via endpoint composition.
|
|
35
|
+
* The DF (Dead Front) feature is required for the On/Off cluster in this device type.
|
|
36
|
+
*
|
|
37
|
+
* @param {string} name - The name of the air conditioner.
|
|
38
|
+
* @param {string} serial - The serial number of the air conditioner.
|
|
39
|
+
* @param {AirConditionerOptions} [options] - Optional configuration values. Missing fields use defaults.
|
|
40
|
+
*
|
|
41
|
+
* Options defaults:
|
|
42
|
+
* - localTemperature: 23
|
|
43
|
+
* - occupiedHeatingSetpoint: 21
|
|
44
|
+
* - occupiedCoolingSetpoint: 25
|
|
45
|
+
* - minSetpointDeadBand: 1
|
|
46
|
+
* - minHeatSetpointLimit: 0
|
|
47
|
+
* - maxHeatSetpointLimit: 50
|
|
48
|
+
* - minCoolSetpointLimit: 0
|
|
49
|
+
* - maxCoolSetpointLimit: 50
|
|
50
|
+
* - temperatureDisplayMode: Celsius
|
|
51
|
+
* - keypadLockout: NoLockout
|
|
52
|
+
* - scheduleProgrammingVisibility: ScheduleProgrammingPermitted
|
|
53
|
+
* - fanMode: Off
|
|
54
|
+
* - fanModeSequence: OffLowMedHighAuto
|
|
55
|
+
* - percentSetting: 0
|
|
56
|
+
* - percentCurrent: 0
|
|
57
|
+
*
|
|
58
|
+
* @returns {AirConditioner} The AirConditioner instance.
|
|
59
|
+
*
|
|
60
|
+
* @remarks Not supported by Google Home.
|
|
61
|
+
*/
|
|
6
62
|
constructor(name, serial, options = {}) {
|
|
7
63
|
const { localTemperature = 23, occupiedHeatingSetpoint = 21, occupiedCoolingSetpoint = 25, minSetpointDeadBand = 1, minHeatSetpointLimit = 0, maxHeatSetpointLimit = 50, minCoolSetpointLimit = 0, maxCoolSetpointLimit = 50, temperatureDisplayMode = ThermostatUserInterfaceConfiguration.TemperatureDisplayMode.Celsius, keypadLockout = ThermostatUserInterfaceConfiguration.KeypadLockout.NoLockout, scheduleProgrammingVisibility = ThermostatUserInterfaceConfiguration.ScheduleProgrammingVisibility.ScheduleProgrammingPermitted, fanMode = FanControl.FanMode.Off, fanModeSequence = FanControl.FanModeSequence.OffLowMedHighAuto, percentSetting = 0, percentCurrent = 0, } = options;
|
|
8
64
|
super([airConditioner, powerSource], { id: `${name.replaceAll(' ', '')}-${serial.replaceAll(' ', '')}` });
|
|
@@ -15,3 +71,4 @@ export class AirConditioner extends MatterbridgeEndpoint {
|
|
|
15
71
|
this.createDefaultFanControlClusterServer(fanMode, fanModeSequence, percentSetting, percentCurrent);
|
|
16
72
|
}
|
|
17
73
|
}
|
|
74
|
+
//# sourceMappingURL=airConditioner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"airConditioner.js","sourceRoot":"","sources":["../../src/devices/airConditioner.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;GAqBG;AAEH,uBAAuB;AACvB,OAAO,EAAE,oCAAoC,EAAE,MAAM,gEAAgE,CAAC;AACtH,OAAO,EAAE,UAAU,EAAE,MAAM,oCAAoC,CAAC;AAEhE,eAAe;AACf,OAAO,EAAE,cAAc,EAAE,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAC5E,OAAO,EAAE,oBAAoB,EAAE,MAAM,4BAA4B,CAAC;AAwClE,MAAM,OAAO,cAAe,SAAQ,oBAAoB;IACtD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA+BG;IACH,YAAY,IAAY,EAAE,MAAc,EAAE,UAAiC,EAAE;QAC3E,MAAM,EACJ,gBAAgB,GAAG,EAAE,EACrB,uBAAuB,GAAG,EAAE,EAC5B,uBAAuB,GAAG,EAAE,EAC5B,mBAAmB,GAAG,CAAC,EACvB,oBAAoB,GAAG,CAAC,EACxB,oBAAoB,GAAG,EAAE,EACzB,oBAAoB,GAAG,CAAC,EACxB,oBAAoB,GAAG,EAAE,EACzB,sBAAsB,GAAG,oCAAoC,CAAC,sBAAsB,CAAC,OAAO,EAC5F,aAAa,GAAG,oCAAoC,CAAC,aAAa,CAAC,SAAS,EAC5E,6BAA6B,GAAG,oCAAoC,CAAC,6BAA6B,CAAC,4BAA4B,EAC/H,OAAO,GAAG,UAAU,CAAC,OAAO,CAAC,GAAG,EAChC,eAAe,GAAG,UAAU,CAAC,eAAe,CAAC,iBAAiB,EAC9D,cAAc,GAAG,CAAC,EAClB,cAAc,GAAG,CAAC,GACnB,GAAG,OAAO,CAAC;QACZ,KAAK,CAAC,CAAC,cAAc,EAAE,WAAW,CAAC,EAAE,EAAE,EAAE,EAAE,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;QAC1G,IAAI,CAAC,kCAAkC,EAAE,CAAC;QAC1C,IAAI,CAAC,0CAA0C,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,cAAc,EAAE,MAAM,EAAE,8BAA8B,CAAC,CAAC;QAC9H,IAAI,CAAC,0CAA0C,EAAE,CAAC;QAClD,IAAI,CAAC,iCAAiC,CAAC,IAAI,CAAC,CAAC;QAC7C,IAAI,CAAC,oCAAoC,CAAC,gBAAgB,EAAE,uBAAuB,EAAE,uBAAuB,EAAE,mBAAmB,EAAE,oBAAoB,EAAE,oBAAoB,EAAE,oBAAoB,EAAE,oBAAoB,CAAC,CAAC;QAC3N,IAAI,CAAC,8DAA8D,CAAC,sBAAsB,EAAE,aAAa,EAAE,6BAA6B,CAAC,CAAC;QAC1I,IAAI,CAAC,oCAAoC,CAAC,OAAO,EAAE,eAAe,EAAE,cAAc,EAAE,cAAc,CAAC,CAAC;IACtG,CAAC;CACF"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @description This file contains the BatteryStorage class.
|
|
3
|
+
* @file src/devices/batteryStorage.ts
|
|
4
|
+
* @author Luca Liguori
|
|
5
|
+
* @contributor Ludovic BOUÉ
|
|
6
|
+
* @created 2025-06-20
|
|
7
|
+
* @version 1.0.0
|
|
8
|
+
* @license Apache-2.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
|
+
import { PowerSource } from '@matter/types/clusters/power-source';
|
|
25
|
+
import { MatterbridgeEndpoint } from '../matterbridgeEndpoint.js';
|
|
26
|
+
export declare class BatteryStorage extends MatterbridgeEndpoint {
|
|
27
|
+
/**
|
|
28
|
+
* Creates an instance of the BatteryStorage class.
|
|
29
|
+
*
|
|
30
|
+
* @param {string} name - The name of the BatteryStorage.
|
|
31
|
+
* @param {string} serial - The serial number of the BatteryStorage.
|
|
32
|
+
* @param {number} [batPercentRemaining] - The percentage of battery remaining, defaults to `100` if not provided.
|
|
33
|
+
* @param {PowerSource.BatChargeLevel} [batChargeLevel] - The battery charge level (default: PowerSource.BatChargeLevel.Ok).
|
|
34
|
+
* @param {number} voltage - The voltage value in millivolts.
|
|
35
|
+
* @param {number} current - The current value in milliamperes.
|
|
36
|
+
* @param {number} power - The power value in milliwatts.
|
|
37
|
+
* @param {number} energyImported - The total production value in mW/h.
|
|
38
|
+
* @param {number} energyExported - The total production value in mW/h.
|
|
39
|
+
* @param {number} [absMinPower] - Indicate the minimum electrical power in mw that the ESA can consume when switched on. Defaults to `0` if not provided.
|
|
40
|
+
* @param {number} [absMaxPower] - Indicate the maximum electrical power in mw that the ESA can consume when switched on. Defaults to `0` if not provided.
|
|
41
|
+
*
|
|
42
|
+
* @remarks
|
|
43
|
+
* - A battery storage inverter that can charge its battery at a maximum power of 2000W and can
|
|
44
|
+
* discharge the battery at a maximum power of 3000W, would have a absMinPower: -3000W, absMaxPower: 2000W.
|
|
45
|
+
*/
|
|
46
|
+
constructor(name: string, serial: string, batPercentRemaining?: number, batChargeLevel?: PowerSource.BatChargeLevel, voltage?: number | bigint | null, current?: number | bigint | null, power?: number | bigint | null, energyImported?: number | bigint | null, energyExported?: number | bigint | null, absMinPower?: number, absMaxPower?: number);
|
|
47
|
+
}
|
|
48
|
+
//# sourceMappingURL=batteryStorage.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"batteryStorage.d.ts","sourceRoot":"","sources":["../../src/devices/batteryStorage.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;GAsBG;AAKH,OAAO,EAAE,WAAW,EAAE,MAAM,qCAAqC,CAAC;AAGlE,OAAO,EAAE,oBAAoB,EAAE,MAAM,4BAA4B,CAAC;AAGlE,qBAAa,cAAe,SAAQ,oBAAoB;IACtD;;;;;;;;;;;;;;;;;;OAkBG;gBAED,IAAI,EAAE,MAAM,EACZ,MAAM,EAAE,MAAM,EACd,mBAAmB,GAAE,MAAY,EACjC,cAAc,GAAE,WAAW,CAAC,cAA8C,EAC1E,OAAO,GAAE,MAAM,GAAG,MAAM,GAAG,IAAW,EACtC,OAAO,GAAE,MAAM,GAAG,MAAM,GAAG,IAAW,EACtC,KAAK,GAAE,MAAM,GAAG,MAAM,GAAG,IAAW,EACpC,cAAc,GAAE,MAAM,GAAG,MAAM,GAAG,IAAW,EAC7C,cAAc,GAAE,MAAM,GAAG,MAAM,GAAG,IAAW,EAC7C,WAAW,GAAE,MAAU,EACvB,WAAW,GAAE,MAAU;CA0B1B"}
|
|
@@ -1,9 +1,53 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @description This file contains the BatteryStorage class.
|
|
3
|
+
* @file src/devices/batteryStorage.ts
|
|
4
|
+
* @author Luca Liguori
|
|
5
|
+
* @contributor Ludovic BOUÉ
|
|
6
|
+
* @created 2025-06-20
|
|
7
|
+
* @version 1.0.0
|
|
8
|
+
* @license Apache-2.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
|
+
// @matter
|
|
1
25
|
import { PowerSourceTag } from '@matter/node';
|
|
2
26
|
import { DeviceEnergyManagement } from '@matter/types/clusters/device-energy-management';
|
|
3
27
|
import { PowerSource } from '@matter/types/clusters/power-source';
|
|
28
|
+
// Matterbridge
|
|
4
29
|
import { MatterbridgeEndpoint } from '../matterbridgeEndpoint.js';
|
|
5
30
|
import { deviceEnergyManagement, electricalSensor, batteryStorage, powerSource } from '../matterbridgeDeviceTypes.js';
|
|
6
31
|
export class BatteryStorage extends MatterbridgeEndpoint {
|
|
32
|
+
/**
|
|
33
|
+
* Creates an instance of the BatteryStorage class.
|
|
34
|
+
*
|
|
35
|
+
* @param {string} name - The name of the BatteryStorage.
|
|
36
|
+
* @param {string} serial - The serial number of the BatteryStorage.
|
|
37
|
+
* @param {number} [batPercentRemaining] - The percentage of battery remaining, defaults to `100` if not provided.
|
|
38
|
+
* @param {PowerSource.BatChargeLevel} [batChargeLevel] - The battery charge level (default: PowerSource.BatChargeLevel.Ok).
|
|
39
|
+
* @param {number} voltage - The voltage value in millivolts.
|
|
40
|
+
* @param {number} current - The current value in milliamperes.
|
|
41
|
+
* @param {number} power - The power value in milliwatts.
|
|
42
|
+
* @param {number} energyImported - The total production value in mW/h.
|
|
43
|
+
* @param {number} energyExported - The total production value in mW/h.
|
|
44
|
+
* @param {number} [absMinPower] - Indicate the minimum electrical power in mw that the ESA can consume when switched on. Defaults to `0` if not provided.
|
|
45
|
+
* @param {number} [absMaxPower] - Indicate the maximum electrical power in mw that the ESA can consume when switched on. Defaults to `0` if not provided.
|
|
46
|
+
*
|
|
47
|
+
* @remarks
|
|
48
|
+
* - A battery storage inverter that can charge its battery at a maximum power of 2000W and can
|
|
49
|
+
* discharge the battery at a maximum power of 3000W, would have a absMinPower: -3000W, absMaxPower: 2000W.
|
|
50
|
+
*/
|
|
7
51
|
constructor(name, serial, batPercentRemaining = 100, batChargeLevel = PowerSource.BatChargeLevel.Ok, voltage = null, current = null, power = null, energyImported = null, energyExported = null, absMinPower = 0, absMaxPower = 0) {
|
|
8
52
|
super([batteryStorage, electricalSensor, deviceEnergyManagement], { id: `${name.replaceAll(' ', '')}-${serial.replaceAll(' ', '')}` });
|
|
9
53
|
this.createDefaultIdentifyClusterServer()
|
|
@@ -14,10 +58,12 @@ export class BatteryStorage extends MatterbridgeEndpoint {
|
|
|
14
58
|
.createDefaultDeviceEnergyManagementClusterServer(DeviceEnergyManagement.EsaType.BatteryStorage, true, DeviceEnergyManagement.EsaState.Online, absMinPower, absMaxPower)
|
|
15
59
|
.createDefaultDeviceEnergyManagementModeClusterServer()
|
|
16
60
|
.addRequiredClusterServers();
|
|
61
|
+
// Add separate PowerSource child devices cause in matter.js the PowerSource cluster is not supported with both features Wired and Battery.
|
|
62
|
+
// Probably this is also an error in the specification...
|
|
17
63
|
this.addChildDeviceType('BatteryPowerSource', powerSource, {
|
|
18
64
|
tagList: [{ mfgCode: null, namespaceId: PowerSourceTag.Battery.namespaceId, tag: PowerSourceTag.Battery.tag, label: null }],
|
|
19
65
|
})
|
|
20
|
-
.createDefaultPowerSourceRechargeableBatteryClusterServer(batPercentRemaining, batChargeLevel, 24_000)
|
|
66
|
+
.createDefaultPowerSourceRechargeableBatteryClusterServer(batPercentRemaining, batChargeLevel, 24_000) // Battery voltage in mV (24V).
|
|
21
67
|
.addRequiredClusterServers();
|
|
22
68
|
this.addChildDeviceType('GridPowerSource', powerSource, {
|
|
23
69
|
tagList: [{ mfgCode: null, namespaceId: PowerSourceTag.Grid.namespaceId, tag: PowerSourceTag.Grid.tag, label: null }],
|
|
@@ -26,3 +72,4 @@ export class BatteryStorage extends MatterbridgeEndpoint {
|
|
|
26
72
|
.addRequiredClusterServers();
|
|
27
73
|
}
|
|
28
74
|
}
|
|
75
|
+
//# sourceMappingURL=batteryStorage.js.map
|