matterbridge 3.1.0 → 3.1.1-dev-20250629-cfe9124

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 (194) hide show
  1. package/CHANGELOG.md +25 -4
  2. package/README-DEV.md +17 -3
  3. package/README-DOCKER.md +3 -1
  4. package/README-NGINX.md +30 -22
  5. package/README-PODMAN.md +3 -1
  6. package/README-SERVICE.md +8 -2
  7. package/dist/batteryStorage.js +24 -0
  8. package/dist/cli.js +2 -91
  9. package/dist/clusters/export.js +0 -2
  10. package/dist/defaultConfigSchema.js +0 -24
  11. package/dist/deviceManager.js +1 -94
  12. package/dist/devices/export.js +2 -2
  13. package/dist/evse.js +9 -70
  14. package/dist/frontend.js +16 -413
  15. package/dist/globalMatterbridge.js +0 -47
  16. package/dist/helpers.js +0 -53
  17. package/dist/index.js +3 -32
  18. package/dist/laundryWasher.js +7 -92
  19. package/dist/logger/export.js +0 -1
  20. package/dist/matter/behaviors.js +0 -2
  21. package/dist/matter/clusters.js +0 -2
  22. package/dist/matter/devices.js +0 -2
  23. package/dist/matter/endpoints.js +0 -2
  24. package/dist/matter/export.js +0 -3
  25. package/dist/matter/types.js +0 -3
  26. package/dist/matterbridge.js +50 -797
  27. package/dist/matterbridgeAccessoryPlatform.js +0 -36
  28. package/dist/matterbridgeBehaviors.js +16 -55
  29. package/dist/matterbridgeDeviceTypes.js +15 -579
  30. package/dist/matterbridgeDynamicPlatform.js +0 -36
  31. package/dist/matterbridgeEndpoint.js +66 -1025
  32. package/dist/matterbridgeEndpointHelpers.js +12 -322
  33. package/dist/matterbridgePlatform.js +0 -233
  34. package/dist/matterbridgeTypes.js +0 -25
  35. package/dist/pluginManager.js +3 -269
  36. package/dist/roboticVacuumCleaner.js +6 -83
  37. package/dist/shelly.js +7 -168
  38. package/dist/solarPower.js +20 -0
  39. package/dist/storage/export.js +0 -1
  40. package/dist/update.js +0 -54
  41. package/dist/utils/colorUtils.js +2 -263
  42. package/dist/utils/commandLine.js +0 -54
  43. package/dist/utils/copyDirectory.js +1 -38
  44. package/dist/utils/createDirectory.js +0 -33
  45. package/dist/utils/createZip.js +2 -47
  46. package/dist/utils/deepCopy.js +0 -39
  47. package/dist/utils/deepEqual.js +1 -72
  48. package/dist/utils/export.js +0 -1
  49. package/dist/utils/hex.js +0 -58
  50. package/dist/utils/isvalid.js +0 -101
  51. package/dist/utils/network.js +5 -83
  52. package/dist/utils/spawn.js +0 -18
  53. package/dist/utils/wait.js +9 -62
  54. package/dist/waterHeater.js +2 -77
  55. package/npm-shrinkwrap.json +2 -2
  56. package/package.json +1 -2
  57. package/dist/cli.d.ts +0 -29
  58. package/dist/cli.d.ts.map +0 -1
  59. package/dist/cli.js.map +0 -1
  60. package/dist/clusters/export.d.ts +0 -2
  61. package/dist/clusters/export.d.ts.map +0 -1
  62. package/dist/clusters/export.js.map +0 -1
  63. package/dist/defaultConfigSchema.d.ts +0 -28
  64. package/dist/defaultConfigSchema.d.ts.map +0 -1
  65. package/dist/defaultConfigSchema.js.map +0 -1
  66. package/dist/deviceManager.d.ts +0 -112
  67. package/dist/deviceManager.d.ts.map +0 -1
  68. package/dist/deviceManager.js.map +0 -1
  69. package/dist/devices/export.d.ts +0 -5
  70. package/dist/devices/export.d.ts.map +0 -1
  71. package/dist/devices/export.js.map +0 -1
  72. package/dist/evse.d.ts +0 -72
  73. package/dist/evse.d.ts.map +0 -1
  74. package/dist/evse.js.map +0 -1
  75. package/dist/frontend.d.ts +0 -285
  76. package/dist/frontend.d.ts.map +0 -1
  77. package/dist/frontend.js.map +0 -1
  78. package/dist/globalMatterbridge.d.ts +0 -59
  79. package/dist/globalMatterbridge.d.ts.map +0 -1
  80. package/dist/globalMatterbridge.js.map +0 -1
  81. package/dist/helpers.d.ts +0 -48
  82. package/dist/helpers.d.ts.map +0 -1
  83. package/dist/helpers.js.map +0 -1
  84. package/dist/index.d.ts +0 -38
  85. package/dist/index.d.ts.map +0 -1
  86. package/dist/index.js.map +0 -1
  87. package/dist/laundryWasher.d.ts +0 -243
  88. package/dist/laundryWasher.d.ts.map +0 -1
  89. package/dist/laundryWasher.js.map +0 -1
  90. package/dist/logger/export.d.ts +0 -2
  91. package/dist/logger/export.d.ts.map +0 -1
  92. package/dist/logger/export.js.map +0 -1
  93. package/dist/matter/behaviors.d.ts +0 -2
  94. package/dist/matter/behaviors.d.ts.map +0 -1
  95. package/dist/matter/behaviors.js.map +0 -1
  96. package/dist/matter/clusters.d.ts +0 -2
  97. package/dist/matter/clusters.d.ts.map +0 -1
  98. package/dist/matter/clusters.js.map +0 -1
  99. package/dist/matter/devices.d.ts +0 -2
  100. package/dist/matter/devices.d.ts.map +0 -1
  101. package/dist/matter/devices.js.map +0 -1
  102. package/dist/matter/endpoints.d.ts +0 -2
  103. package/dist/matter/endpoints.d.ts.map +0 -1
  104. package/dist/matter/endpoints.js.map +0 -1
  105. package/dist/matter/export.d.ts +0 -5
  106. package/dist/matter/export.d.ts.map +0 -1
  107. package/dist/matter/export.js.map +0 -1
  108. package/dist/matter/types.d.ts +0 -3
  109. package/dist/matter/types.d.ts.map +0 -1
  110. package/dist/matter/types.js.map +0 -1
  111. package/dist/matterbridge.d.ts +0 -450
  112. package/dist/matterbridge.d.ts.map +0 -1
  113. package/dist/matterbridge.js.map +0 -1
  114. package/dist/matterbridgeAccessoryPlatform.d.ts +0 -42
  115. package/dist/matterbridgeAccessoryPlatform.d.ts.map +0 -1
  116. package/dist/matterbridgeAccessoryPlatform.js.map +0 -1
  117. package/dist/matterbridgeBehaviors.d.ts +0 -1334
  118. package/dist/matterbridgeBehaviors.d.ts.map +0 -1
  119. package/dist/matterbridgeBehaviors.js.map +0 -1
  120. package/dist/matterbridgeDeviceTypes.d.ts +0 -709
  121. package/dist/matterbridgeDeviceTypes.d.ts.map +0 -1
  122. package/dist/matterbridgeDeviceTypes.js.map +0 -1
  123. package/dist/matterbridgeDynamicPlatform.d.ts +0 -42
  124. package/dist/matterbridgeDynamicPlatform.d.ts.map +0 -1
  125. package/dist/matterbridgeDynamicPlatform.js.map +0 -1
  126. package/dist/matterbridgeEndpoint.d.ts +0 -1173
  127. package/dist/matterbridgeEndpoint.d.ts.map +0 -1
  128. package/dist/matterbridgeEndpoint.js.map +0 -1
  129. package/dist/matterbridgeEndpointHelpers.d.ts +0 -3198
  130. package/dist/matterbridgeEndpointHelpers.d.ts.map +0 -1
  131. package/dist/matterbridgeEndpointHelpers.js.map +0 -1
  132. package/dist/matterbridgePlatform.d.ts +0 -310
  133. package/dist/matterbridgePlatform.d.ts.map +0 -1
  134. package/dist/matterbridgePlatform.js.map +0 -1
  135. package/dist/matterbridgeTypes.d.ts +0 -184
  136. package/dist/matterbridgeTypes.d.ts.map +0 -1
  137. package/dist/matterbridgeTypes.js.map +0 -1
  138. package/dist/pluginManager.d.ts +0 -291
  139. package/dist/pluginManager.d.ts.map +0 -1
  140. package/dist/pluginManager.js.map +0 -1
  141. package/dist/roboticVacuumCleaner.d.ts +0 -104
  142. package/dist/roboticVacuumCleaner.d.ts.map +0 -1
  143. package/dist/roboticVacuumCleaner.js.map +0 -1
  144. package/dist/shelly.d.ts +0 -174
  145. package/dist/shelly.d.ts.map +0 -1
  146. package/dist/shelly.js.map +0 -1
  147. package/dist/storage/export.d.ts +0 -2
  148. package/dist/storage/export.d.ts.map +0 -1
  149. package/dist/storage/export.js.map +0 -1
  150. package/dist/update.d.ts +0 -59
  151. package/dist/update.d.ts.map +0 -1
  152. package/dist/update.js.map +0 -1
  153. package/dist/utils/colorUtils.d.ts +0 -117
  154. package/dist/utils/colorUtils.d.ts.map +0 -1
  155. package/dist/utils/colorUtils.js.map +0 -1
  156. package/dist/utils/commandLine.d.ts +0 -59
  157. package/dist/utils/commandLine.d.ts.map +0 -1
  158. package/dist/utils/commandLine.js.map +0 -1
  159. package/dist/utils/copyDirectory.d.ts +0 -33
  160. package/dist/utils/copyDirectory.d.ts.map +0 -1
  161. package/dist/utils/copyDirectory.js.map +0 -1
  162. package/dist/utils/createDirectory.d.ts +0 -34
  163. package/dist/utils/createDirectory.d.ts.map +0 -1
  164. package/dist/utils/createDirectory.js.map +0 -1
  165. package/dist/utils/createZip.d.ts +0 -39
  166. package/dist/utils/createZip.d.ts.map +0 -1
  167. package/dist/utils/createZip.js.map +0 -1
  168. package/dist/utils/deepCopy.d.ts +0 -32
  169. package/dist/utils/deepCopy.d.ts.map +0 -1
  170. package/dist/utils/deepCopy.js.map +0 -1
  171. package/dist/utils/deepEqual.d.ts +0 -54
  172. package/dist/utils/deepEqual.d.ts.map +0 -1
  173. package/dist/utils/deepEqual.js.map +0 -1
  174. package/dist/utils/export.d.ts +0 -12
  175. package/dist/utils/export.d.ts.map +0 -1
  176. package/dist/utils/export.js.map +0 -1
  177. package/dist/utils/hex.d.ts +0 -49
  178. package/dist/utils/hex.d.ts.map +0 -1
  179. package/dist/utils/hex.js.map +0 -1
  180. package/dist/utils/isvalid.d.ts +0 -103
  181. package/dist/utils/isvalid.d.ts.map +0 -1
  182. package/dist/utils/isvalid.js.map +0 -1
  183. package/dist/utils/network.d.ts +0 -76
  184. package/dist/utils/network.d.ts.map +0 -1
  185. package/dist/utils/network.js.map +0 -1
  186. package/dist/utils/spawn.d.ts +0 -14
  187. package/dist/utils/spawn.d.ts.map +0 -1
  188. package/dist/utils/spawn.js.map +0 -1
  189. package/dist/utils/wait.d.ts +0 -56
  190. package/dist/utils/wait.d.ts.map +0 -1
  191. package/dist/utils/wait.js.map +0 -1
  192. package/dist/waterHeater.d.ts +0 -106
  193. package/dist/waterHeater.d.ts.map +0 -1
  194. package/dist/waterHeater.js.map +0 -1
@@ -1,87 +1,26 @@
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.0.11
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
25
1
  import { AnsiLogger, BLUE, er } from 'node-ansi-logger';
26
2
  import { dev } from './matterbridgeTypes.js';
27
- /**
28
- * Manages Matterbridge devices.
29
- */
30
3
  export class DeviceManager {
31
4
  _devices = new Map();
32
5
  matterbridge;
33
6
  log;
34
- /**
35
- * Creates an instance of DeviceManager.
36
- *
37
- * @param {Matterbridge} matterbridge - The Matterbridge instance.
38
- */
39
7
  constructor(matterbridge) {
40
8
  this.matterbridge = matterbridge;
41
- this.log = new AnsiLogger({ logName: 'DeviceManager', logTimestampFormat: 4 /* TimestampFormat.TIME_MILLIS */, logLevel: matterbridge.log.logLevel });
9
+ this.log = new AnsiLogger({ logName: 'DeviceManager', logTimestampFormat: 4, logLevel: matterbridge.log.logLevel });
42
10
  this.log.debug('Matterbridge device manager starting...');
43
11
  }
44
- /**
45
- * Gets the number of devices.
46
- *
47
- * @returns {number} The number of devices.
48
- */
49
12
  get length() {
50
13
  return this._devices.size;
51
14
  }
52
- /**
53
- * Gets the number of devices.
54
- *
55
- * @returns {number} The number of devices.
56
- */
57
15
  get size() {
58
16
  return this._devices.size;
59
17
  }
60
- /**
61
- * Checks if a device with the specified unique ID exists.
62
- *
63
- * @param {string} uniqueId - The unique ID of the device.
64
- * @returns {boolean} True if the device exists, false otherwise.
65
- */
66
18
  has(uniqueId) {
67
19
  return this._devices.has(uniqueId);
68
20
  }
69
- /**
70
- * Gets a device by its unique ID.
71
- *
72
- * @param {string} uniqueId - The unique ID of the device.
73
- * @returns {MatterbridgeEndpoint | undefined} The device, or undefined if not found.
74
- */
75
21
  get(uniqueId) {
76
22
  return this._devices.get(uniqueId);
77
23
  }
78
- /**
79
- * Adds a device to the manager.
80
- *
81
- * @param {MatterbridgeEndpoint} device - The device to add.
82
- * @returns {MatterbridgeEndpoint} The added device.
83
- * @throws {Error} If the device does not have a unique ID.
84
- */
85
24
  set(device) {
86
25
  if (!device.uniqueId)
87
26
  throw new Error(`The device ${dev}${device.deviceName}${er} has not been initialized: uniqueId is required`);
@@ -90,13 +29,6 @@ export class DeviceManager {
90
29
  this._devices.set(device.uniqueId, device);
91
30
  return device;
92
31
  }
93
- /**
94
- * Removes a device from the manager.
95
- *
96
- * @param {MatterbridgeEndpoint} device - The device to remove.
97
- * @returns {boolean} True if the device was removed, false otherwise.
98
- * @throws {Error} If the device does not have a unique ID.
99
- */
100
32
  remove(device) {
101
33
  if (!device.uniqueId)
102
34
  throw new Error(`The device ${dev}${device.deviceName}${er} has not been initialized: uniqueId is required`);
@@ -104,34 +36,15 @@ export class DeviceManager {
104
36
  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`);
105
37
  return this._devices.delete(device.uniqueId);
106
38
  }
107
- /**
108
- * Clears all devices from the manager.
109
- */
110
39
  clear() {
111
40
  this._devices.clear();
112
41
  }
113
- /**
114
- * Gets an array of all devices.
115
- *
116
- * @returns {MatterbridgeEndpoint[]} An array of all devices.
117
- */
118
42
  array() {
119
43
  return Array.from(this._devices.values());
120
44
  }
121
- /**
122
- * Iterates over all devices.
123
- *
124
- * @returns {IterableIterator<MatterbridgeEndpoint>} An iterator for the devices.
125
- */
126
45
  [Symbol.iterator]() {
127
46
  return this._devices.values();
128
47
  }
129
- /**
130
- * Asynchronously iterates over each device and calls the provided callback function.
131
- *
132
- * @param {(device: MatterbridgeEndpoint) => Promise<void>} callback - The callback function to call with each device.
133
- * @returns {Promise<void>} A promise that resolves when all callbacks have been called.
134
- */
135
48
  async forEach(callback) {
136
49
  if (this.size === 0)
137
50
  return;
@@ -145,13 +58,7 @@ export class DeviceManager {
145
58
  });
146
59
  await Promise.all(tasks);
147
60
  }
148
- /**
149
- * Sets the log level.
150
- *
151
- * @param {LogLevel} logLevel - The log level to set.
152
- */
153
61
  set logLevel(logLevel) {
154
62
  this.log.logLevel = logLevel;
155
63
  }
156
64
  }
157
- //# sourceMappingURL=deviceManager.js.map
@@ -1,6 +1,6 @@
1
- // Single class device types
2
1
  export * from '../roboticVacuumCleaner.js';
3
2
  export * from '../laundryWasher.js';
4
3
  export * from '../waterHeater.js';
5
4
  export * from '../evse.js';
6
- //# sourceMappingURL=export.js.map
5
+ export * from '../solarPower.js';
6
+ export * from '../batteryStorage.js';
package/dist/evse.js CHANGED
@@ -1,50 +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
- * @created 2025-05-27
8
- * @version 1.1.0
9
- * @license Apache-2.0
10
- *
11
- * Copyright 2025, 2026, 2027 Luca Liguori.
12
- *
13
- * Licensed under the Apache License, Version 2.0 (the "License");
14
- * you may not use this file except in compliance with the License.
15
- * You may obtain a copy of the License at
16
- *
17
- * http://www.apache.org/licenses/LICENSE-2.0
18
- *
19
- * Unless required by applicable law or agreed to in writing, software
20
- * distributed under the License is distributed on an "AS IS" BASIS,
21
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
22
- * See the License for the specific language governing permissions and
23
- * limitations under the License.
24
- */
25
1
  import { EnergyEvseServer } from '@matter/main/behaviors/energy-evse';
26
2
  import { EnergyEvseModeServer } from '@matter/main/behaviors/energy-evse-mode';
27
3
  import { EnergyEvse, EnergyEvseMode } from '@matter/main/clusters';
28
4
  import { DeviceEnergyManagement } from '@matter/main/clusters/device-energy-management';
29
5
  import { ModeBase } from '@matter/main/clusters/mode-base';
30
- // Matterbridge
31
6
  import { MatterbridgeEndpoint } from './matterbridgeEndpoint.js';
32
7
  import { MatterbridgeServer } from './matterbridgeBehaviors.js';
33
8
  import { deviceEnergyManagement, electricalSensor, evse, powerSource } from './matterbridgeDeviceTypes.js';
34
9
  export class Evse extends MatterbridgeEndpoint {
35
- /**
36
- * Creates an instance of the EVSE class.
37
- *
38
- * @param {string} name - The name of the EVSE.
39
- * @param {string} serial - The serial number of the EVSE.
40
- * @param {number} [currentMode] - The current mode of the EnergyEvseMode cluster. Defaults to mode 1 (EnergyEvseMode.ModeTag.Manual).
41
- * @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.
42
- * @param {EnergyEvse.State} [state] - The current state of the EVSE. Defaults to NotPluggedIn.
43
- * @param {EnergyEvse.SupplyState} [supplyState] - The supply state of the EVSE. Defaults to Disabled.
44
- * @param {EnergyEvse.FaultState} [faultState] - The fault state of the EVSE. Defaults to NoError.
45
- * @param {number} [absMinPower] - Indicate the minimum electrical power that the ESA can consume when switched on. Defaults to `0` if not provided.
46
- * @param {number} [absMaxPower] - Indicate the maximum electrical power that the ESA can consume when switched on. Defaults to `0` if not provided.
47
- */
48
10
  constructor(name, serial, currentMode, supportedModes, state, supplyState, faultState, absMinPower, absMaxPower) {
49
11
  super([evse, powerSource, electricalSensor, deviceEnergyManagement], { uniqueStorageKey: `${name.replaceAll(' ', '')}-${serial.replaceAll(' ', '')}` }, true);
50
12
  this.createDefaultIdentifyClusterServer()
@@ -58,46 +20,29 @@ export class Evse extends MatterbridgeEndpoint {
58
20
  .createDefaultEnergyEvseModeClusterServer(currentMode, supportedModes)
59
21
  .addRequiredClusterServers();
60
22
  }
61
- /**
62
- * Creates a default EnergyEvseServer Cluster Server.
63
- *
64
- * @param {EnergyEvse.State} [state] - The initial state of the EnergyEvse cluster. Defaults to EnergyEvse.State.NotPluggedIn.
65
- * @param {EnergyEvse.SupplyState} [supplyState] - The initial supply state of the EnergyEvse cluster. Defaults to EnergyEvse.SupplyState.ChargingEnabled.
66
- * @param {EnergyEvse.FaultState} [faultState] - The initial fault state of the EnergyEvse cluster. Defaults to EnergyEvse.FaultState.NoError.
67
- * @returns {this} The current MatterbridgeEndpoint instance for chaining.
68
- */
69
23
  createDefaultEnergyEvseClusterServer(state, supplyState, faultState) {
70
24
  this.behaviors.require(MatterbridgeEnergyEvseServer, {
71
25
  state: state ?? EnergyEvse.State.NotPluggedIn,
72
26
  supplyState: supplyState ?? EnergyEvse.SupplyState.ChargingEnabled,
73
27
  faultState: faultState ?? EnergyEvse.FaultState.NoError,
74
- chargingEnabledUntil: 0, // Persistent attribute
75
- circuitCapacity: 0, // Persistent attribute in mA
76
- minimumChargeCurrent: 6000, // Persistent attribute in mA
77
- maximumChargeCurrent: 0, // Persistent attribute in mA
78
- sessionId: null, // Persistent attribute
79
- sessionDuration: 0, // Persistent attribute
80
- 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,
81
35
  });
82
36
  return this;
83
37
  }
84
- /**
85
- * Creates a default EnergyEvseMode Cluster Server.
86
- *
87
- * @param {number} [currentMode] - The current mode of the EnergyEvseMode cluster. Defaults to mode 1 (EnergyEvseMode.ModeTag.Manual).
88
- * @param {EnergyEvseMode.ModeOption[]} [supportedModes] - The supported modes for the EnergyEvseMode cluster. Defaults all EnergyEvseMode cluster modes.
89
- *
90
- * @returns {this} The current MatterbridgeEndpoint instance for chaining.
91
- */
92
38
  createDefaultEnergyEvseModeClusterServer(currentMode, supportedModes) {
93
39
  this.behaviors.require(MatterbridgeEnergyEvseModeServer, {
94
40
  supportedModes: supportedModes ?? [
95
41
  { label: 'On demand', mode: 1, modeTags: [{ value: EnergyEvseMode.ModeTag.Manual }] },
96
42
  { label: 'Scheduled', mode: 2, modeTags: [{ value: EnergyEvseMode.ModeTag.TimeOfUse }] },
97
43
  { label: 'Solar charging', mode: 3, modeTags: [{ value: EnergyEvseMode.ModeTag.SolarCharging }] },
98
- // { label: 'Home to vehicle and Vehicle to home', mode: 4, modeTags: [{ value: EnergyEvseMode.ModeTag.V2X }] }, // This mode is not valid in charging only EVSEs
99
- ], // FixedAttribute
100
- currentMode: currentMode ?? 1, // Persistent attribute
44
+ ],
45
+ currentMode: currentMode ?? 1,
101
46
  });
102
47
  return this;
103
48
  }
@@ -113,8 +58,6 @@ export class MatterbridgeEnergyEvseServer extends EnergyEvseServer {
113
58
  this.state.state = EnergyEvse.State.PluggedInDemand;
114
59
  }
115
60
  this.state.chargingEnabledUntil = 0;
116
- // super.disable();
117
- // disable is not implemented in matter.js
118
61
  }
119
62
  enableCharging(request) {
120
63
  const device = this.endpoint.stateOf(MatterbridgeServer);
@@ -128,9 +71,6 @@ export class MatterbridgeEnergyEvseServer extends EnergyEvseServer {
128
71
  this.state.chargingEnabledUntil = request.chargingEnabledUntil;
129
72
  this.state.minimumChargeCurrent = request.minimumChargeCurrent;
130
73
  this.state.maximumChargeCurrent = request.maximumChargeCurrent;
131
- // The implementation should also stop the charging session at the required time and update the sessionId, sessionDuration, and sessionEnergyCharged attributes if needed.
132
- // super.enableCharging();
133
- // enableCharging is not implemented in matter.js
134
74
  }
135
75
  }
136
76
  export class MatterbridgeEnergyEvseModeServer extends EnergyEvseModeServer {
@@ -148,4 +88,3 @@ export class MatterbridgeEnergyEvseModeServer extends EnergyEvseModeServer {
148
88
  return { status: ModeBase.ModeChangeStatus.Success, statusText: 'Success' };
149
89
  }
150
90
  }
151
- //# sourceMappingURL=evse.js.map