matterbridge-example-dynamic-platform 1.3.2-dev-20250707-39008e5 → 1.3.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/CHANGELOG.md
CHANGED
@@ -23,6 +23,21 @@ If you like this project and find it useful, please consider giving it a star on
|
|
23
23
|
<img src="bmc-button.svg" alt="Buy me a coffee" width="120">
|
24
24
|
</a>
|
25
25
|
|
26
|
+
## [1.3.3] - 2025-07-20
|
27
|
+
|
28
|
+
### Added
|
29
|
+
|
30
|
+
- [platform]: Add RVC supportedMaps attribute. Thanks Ludovic BOUÉ (#21).
|
31
|
+
|
32
|
+
### Changed
|
33
|
+
|
34
|
+
- [package]: Updated dependencies.
|
35
|
+
- [package]: Required matterbridge 3.1.5.
|
36
|
+
|
37
|
+
<a href="https://www.buymeacoffee.com/luligugithub">
|
38
|
+
<img src="bmc-button.svg" alt="Buy me a coffee" width="80">
|
39
|
+
</a>
|
40
|
+
|
26
41
|
## [1.3.2] - 2025-07-06
|
27
42
|
|
28
43
|
### Added
|
package/dist/platform.js
CHANGED
@@ -1,8 +1,8 @@
|
|
1
1
|
import { MatterbridgeEndpoint, MatterbridgeDynamicPlatform, airQualitySensor, bridgedNode, colorTemperatureLight, coverDevice, dimmableLight, doorLockDevice, fanDevice, flowSensor, humiditySensor, onOffLight, onOffOutlet, onOffSwitch, powerSource, rainSensor, smokeCoAlarm, temperatureSensor, thermostatDevice, waterFreezeDetector, waterLeakDetector, airPurifier, pumpDevice, waterValve, genericSwitch, airConditioner, cooktop, extractorHood, microwaveOven, oven, refrigerator, dishwasher, onOffMountedSwitch, dimmableMountedSwitch, extendedColorLight, } from 'matterbridge';
|
2
2
|
import { RoboticVacuumCleaner, LaundryWasher, WaterHeater, Evse, SolarPower, BatteryStorage, LaundryDryer, HeatPump } from 'matterbridge/devices';
|
3
3
|
import { isValidBoolean, isValidNumber } from 'matterbridge/utils';
|
4
|
-
import { LocationTag, NumberTag, PositionTag } from 'matterbridge/matter';
|
5
|
-
import { PowerSource, BooleanState, OnOff, LevelControl, AirQuality, CarbonDioxideConcentrationMeasurement, CarbonMonoxideConcentrationMeasurement, FlowMeasurement, ColorControl, DoorLock, FanControl, FormaldehydeConcentrationMeasurement, NitrogenDioxideConcentrationMeasurement, OzoneConcentrationMeasurement, Pm10ConcentrationMeasurement, Pm1ConcentrationMeasurement, Pm25ConcentrationMeasurement, RadonConcentrationMeasurement, RelativeHumidityMeasurement, RelativeHumidityMeasurementCluster, SmokeCoAlarm, TemperatureMeasurement, Thermostat, ThermostatCluster, TotalVolatileOrganicCompoundsConcentrationMeasurement, WindowCovering, EnergyEvseMode, EnergyEvse, } from 'matterbridge/matter/clusters';
|
4
|
+
import { AreaNamespaceTag, LocationTag, NumberTag, PositionTag } from 'matterbridge/matter';
|
5
|
+
import { PowerSource, BooleanState, OnOff, LevelControl, AirQuality, CarbonDioxideConcentrationMeasurement, CarbonMonoxideConcentrationMeasurement, FlowMeasurement, ColorControl, DoorLock, FanControl, FormaldehydeConcentrationMeasurement, NitrogenDioxideConcentrationMeasurement, OzoneConcentrationMeasurement, Pm10ConcentrationMeasurement, Pm1ConcentrationMeasurement, Pm25ConcentrationMeasurement, RadonConcentrationMeasurement, RelativeHumidityMeasurement, RelativeHumidityMeasurementCluster, SmokeCoAlarm, TemperatureMeasurement, Thermostat, ThermostatCluster, TotalVolatileOrganicCompoundsConcentrationMeasurement, WindowCovering, EnergyEvseMode, EnergyEvse, RvcRunMode, RvcCleanMode, } from 'matterbridge/matter/clusters';
|
6
6
|
import { Appliances } from './appliances.js';
|
7
7
|
export class ExampleMatterbridgeDynamicPlatform extends MatterbridgeDynamicPlatform {
|
8
8
|
switch;
|
@@ -65,8 +65,8 @@ export class ExampleMatterbridgeDynamicPlatform extends MatterbridgeDynamicPlatf
|
|
65
65
|
fanModeLookup = ['Off', 'Low', 'Medium', 'High', 'On', 'Auto', 'Smart'];
|
66
66
|
constructor(matterbridge, log, config) {
|
67
67
|
super(matterbridge, log, config);
|
68
|
-
if (this.verifyMatterbridgeVersion === undefined || typeof this.verifyMatterbridgeVersion !== 'function' || !this.verifyMatterbridgeVersion('3.1.
|
69
|
-
throw new Error(`This plugin requires Matterbridge version >= "3.1.
|
68
|
+
if (this.verifyMatterbridgeVersion === undefined || typeof this.verifyMatterbridgeVersion !== 'function' || !this.verifyMatterbridgeVersion('3.1.5')) {
|
69
|
+
throw new Error(`This plugin requires Matterbridge version >= "3.1.5". Please update Matterbridge from ${this.matterbridge.matterbridgeVersion} to the latest version in the frontend.`);
|
70
70
|
}
|
71
71
|
this.log.info('Initializing platform:', this.config.name);
|
72
72
|
if (config.whiteList === undefined)
|
@@ -1000,7 +1000,54 @@ export class ExampleMatterbridgeDynamicPlatform extends MatterbridgeDynamicPlatf
|
|
1000
1000
|
else {
|
1001
1001
|
this.latchingSwitch = undefined;
|
1002
1002
|
}
|
1003
|
-
const robot = new RoboticVacuumCleaner('Robot Vacuum', 'RVC1238777820', this.config.enableServerRvc === true ? 'server' : undefined
|
1003
|
+
const robot = new RoboticVacuumCleaner('Robot Vacuum', 'RVC1238777820', this.config.enableServerRvc === true ? 'server' : undefined, 1, [
|
1004
|
+
{ label: 'Idle', mode: 1, modeTags: [{ value: RvcRunMode.ModeTag.Idle }] },
|
1005
|
+
{ label: 'Cleaning', mode: 2, modeTags: [{ value: RvcRunMode.ModeTag.Cleaning }] },
|
1006
|
+
{ label: 'Mapping', mode: 3, modeTags: [{ value: RvcRunMode.ModeTag.Mapping }] },
|
1007
|
+
{ label: 'SpotCleaning', mode: 4, modeTags: [{ value: RvcRunMode.ModeTag.Cleaning }, { value: RvcRunMode.ModeTag.Max }] },
|
1008
|
+
], 1, [
|
1009
|
+
{ label: 'Vacuum', mode: 1, modeTags: [{ value: RvcCleanMode.ModeTag.Vacuum }] },
|
1010
|
+
{ label: 'Mop', mode: 2, modeTags: [{ value: RvcCleanMode.ModeTag.Mop }] },
|
1011
|
+
{ label: 'Clean', mode: 3, modeTags: [{ value: RvcCleanMode.ModeTag.DeepClean }] },
|
1012
|
+
], null, null, undefined, undefined, [
|
1013
|
+
{
|
1014
|
+
areaId: 1,
|
1015
|
+
mapId: 1,
|
1016
|
+
areaInfo: { locationInfo: { locationName: 'Living', floorNumber: 0, areaType: AreaNamespaceTag.LivingRoom.tag }, landmarkInfo: null },
|
1017
|
+
},
|
1018
|
+
{
|
1019
|
+
areaId: 2,
|
1020
|
+
mapId: 2,
|
1021
|
+
areaInfo: { locationInfo: { locationName: 'Kitchen', floorNumber: 0, areaType: AreaNamespaceTag.Kitchen.tag }, landmarkInfo: null },
|
1022
|
+
},
|
1023
|
+
{
|
1024
|
+
areaId: 3,
|
1025
|
+
mapId: 3,
|
1026
|
+
areaInfo: { locationInfo: { locationName: 'Bedroom', floorNumber: 1, areaType: AreaNamespaceTag.Bedroom.tag }, landmarkInfo: null },
|
1027
|
+
},
|
1028
|
+
{
|
1029
|
+
areaId: 4,
|
1030
|
+
mapId: 4,
|
1031
|
+
areaInfo: { locationInfo: { locationName: 'Bathroom', floorNumber: 1, areaType: AreaNamespaceTag.Bathroom.tag }, landmarkInfo: null },
|
1032
|
+
},
|
1033
|
+
], [], 1, [
|
1034
|
+
{
|
1035
|
+
mapId: 1,
|
1036
|
+
name: 'Ground floor',
|
1037
|
+
},
|
1038
|
+
{
|
1039
|
+
mapId: 2,
|
1040
|
+
name: 'First floor',
|
1041
|
+
},
|
1042
|
+
{
|
1043
|
+
mapId: 3,
|
1044
|
+
name: 'Bedroom',
|
1045
|
+
},
|
1046
|
+
{
|
1047
|
+
mapId: 4,
|
1048
|
+
name: 'Bathroom',
|
1049
|
+
},
|
1050
|
+
]);
|
1004
1051
|
if (this.config.enableServerRvc === true) {
|
1005
1052
|
this.log.notice('RVC is in server mode');
|
1006
1053
|
}
|
@@ -1,10 +1,10 @@
|
|
1
1
|
{
|
2
2
|
"name": "matterbridge-example-dynamic-platform",
|
3
3
|
"type": "DynamicPlatform",
|
4
|
-
"version": "1.1.7",
|
5
4
|
"whiteList": [],
|
6
5
|
"blackList": [],
|
7
6
|
"useInterval": true,
|
8
|
-
"
|
7
|
+
"enableServerRvc": true,
|
8
|
+
"debug": false,
|
9
9
|
"unregisterOnShutdown": false
|
10
10
|
}
|
package/npm-shrinkwrap.json
CHANGED
@@ -1,12 +1,12 @@
|
|
1
1
|
{
|
2
2
|
"name": "matterbridge-example-dynamic-platform",
|
3
|
-
"version": "1.3.
|
3
|
+
"version": "1.3.3",
|
4
4
|
"lockfileVersion": 3,
|
5
5
|
"requires": true,
|
6
6
|
"packages": {
|
7
7
|
"": {
|
8
8
|
"name": "matterbridge-example-dynamic-platform",
|
9
|
-
"version": "1.3.
|
9
|
+
"version": "1.3.3",
|
10
10
|
"license": "Apache-2.0",
|
11
11
|
"dependencies": {
|
12
12
|
"node-ansi-logger": "3.1.1",
|