matterbridge 3.2.4 → 3.2.5-dev-20250831-732330c

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 (267) hide show
  1. package/CHANGELOG.md +21 -2
  2. package/dist/cli.js +2 -91
  3. package/dist/cliEmitter.js +0 -30
  4. package/dist/clusters/export.js +0 -2
  5. package/dist/defaultConfigSchema.js +0 -24
  6. package/dist/deviceManager.js +1 -94
  7. package/dist/devices/batteryStorage.js +1 -48
  8. package/dist/devices/cooktop.js +0 -55
  9. package/dist/devices/dishwasher.js +0 -57
  10. package/dist/devices/evse.js +10 -74
  11. package/dist/devices/export.js +0 -4
  12. package/dist/devices/extractorHood.js +0 -42
  13. package/dist/devices/heatPump.js +2 -50
  14. package/dist/devices/laundryDryer.js +3 -62
  15. package/dist/devices/laundryWasher.js +4 -70
  16. package/dist/devices/microwaveOven.js +5 -88
  17. package/dist/devices/oven.js +0 -85
  18. package/dist/devices/refrigerator.js +32 -83
  19. package/dist/devices/roboticVacuumCleaner.js +7 -93
  20. package/dist/devices/solarPower.js +0 -38
  21. package/dist/devices/temperatureControl.js +3 -25
  22. package/dist/devices/waterHeater.js +2 -82
  23. package/dist/dgram/coap.js +13 -126
  24. package/dist/dgram/dgram.js +2 -113
  25. package/dist/dgram/mb_coap.js +3 -41
  26. package/dist/dgram/mb_mdns.js +13 -51
  27. package/dist/dgram/mdns.js +137 -298
  28. package/dist/dgram/multicast.js +1 -60
  29. package/dist/dgram/unicast.js +0 -54
  30. package/dist/frontend.js +24 -451
  31. package/dist/globalMatterbridge.js +0 -47
  32. package/dist/helpers.js +0 -53
  33. package/dist/index.js +1 -30
  34. package/dist/logger/export.js +0 -1
  35. package/dist/matter/behaviors.js +0 -2
  36. package/dist/matter/clusters.js +0 -2
  37. package/dist/matter/devices.js +0 -2
  38. package/dist/matter/endpoints.js +0 -2
  39. package/dist/matter/export.js +0 -3
  40. package/dist/matter/types.js +0 -3
  41. package/dist/matterbridge.js +50 -789
  42. package/dist/matterbridgeAccessoryPlatform.js +0 -36
  43. package/dist/matterbridgeBehaviors.js +5 -65
  44. package/dist/matterbridgeDeviceTypes.js +15 -579
  45. package/dist/matterbridgeDynamicPlatform.js +0 -36
  46. package/dist/matterbridgeEndpoint.js +54 -1220
  47. package/dist/matterbridgeEndpointHelpers.js +12 -345
  48. package/dist/matterbridgePlatform.js +0 -256
  49. package/dist/matterbridgeTypes.js +0 -25
  50. package/dist/pluginManager.js +3 -249
  51. package/dist/shelly.js +7 -168
  52. package/dist/storage/export.js +0 -1
  53. package/dist/update.js +0 -69
  54. package/dist/utils/colorUtils.js +2 -97
  55. package/dist/utils/commandLine.js +0 -54
  56. package/dist/utils/copyDirectory.js +1 -38
  57. package/dist/utils/createDirectory.js +0 -33
  58. package/dist/utils/createZip.js +2 -47
  59. package/dist/utils/deepCopy.js +0 -39
  60. package/dist/utils/deepEqual.js +1 -72
  61. package/dist/utils/error.js +0 -41
  62. package/dist/utils/export.js +0 -1
  63. package/dist/utils/hex.js +0 -124
  64. package/dist/utils/isvalid.js +0 -101
  65. package/dist/utils/network.js +5 -91
  66. package/dist/utils/spawn.js +0 -40
  67. package/dist/utils/wait.js +8 -60
  68. package/npm-shrinkwrap.json +2 -2
  69. package/package.json +1 -2
  70. package/dist/cli.d.ts +0 -26
  71. package/dist/cli.d.ts.map +0 -1
  72. package/dist/cli.js.map +0 -1
  73. package/dist/cliEmitter.d.ts +0 -34
  74. package/dist/cliEmitter.d.ts.map +0 -1
  75. package/dist/cliEmitter.js.map +0 -1
  76. package/dist/clusters/export.d.ts +0 -2
  77. package/dist/clusters/export.d.ts.map +0 -1
  78. package/dist/clusters/export.js.map +0 -1
  79. package/dist/defaultConfigSchema.d.ts +0 -28
  80. package/dist/defaultConfigSchema.d.ts.map +0 -1
  81. package/dist/defaultConfigSchema.js.map +0 -1
  82. package/dist/deviceManager.d.ts +0 -112
  83. package/dist/deviceManager.d.ts.map +0 -1
  84. package/dist/deviceManager.js.map +0 -1
  85. package/dist/devices/batteryStorage.d.ts +0 -48
  86. package/dist/devices/batteryStorage.d.ts.map +0 -1
  87. package/dist/devices/batteryStorage.js.map +0 -1
  88. package/dist/devices/cooktop.d.ts +0 -60
  89. package/dist/devices/cooktop.d.ts.map +0 -1
  90. package/dist/devices/cooktop.js.map +0 -1
  91. package/dist/devices/dishwasher.d.ts +0 -71
  92. package/dist/devices/dishwasher.d.ts.map +0 -1
  93. package/dist/devices/dishwasher.js.map +0 -1
  94. package/dist/devices/evse.d.ts +0 -75
  95. package/dist/devices/evse.d.ts.map +0 -1
  96. package/dist/devices/evse.js.map +0 -1
  97. package/dist/devices/export.d.ts +0 -15
  98. package/dist/devices/export.d.ts.map +0 -1
  99. package/dist/devices/export.js.map +0 -1
  100. package/dist/devices/extractorHood.d.ts +0 -46
  101. package/dist/devices/extractorHood.d.ts.map +0 -1
  102. package/dist/devices/extractorHood.js.map +0 -1
  103. package/dist/devices/heatPump.d.ts +0 -47
  104. package/dist/devices/heatPump.d.ts.map +0 -1
  105. package/dist/devices/heatPump.js.map +0 -1
  106. package/dist/devices/laundryDryer.d.ts +0 -67
  107. package/dist/devices/laundryDryer.d.ts.map +0 -1
  108. package/dist/devices/laundryDryer.js.map +0 -1
  109. package/dist/devices/laundryWasher.d.ts +0 -81
  110. package/dist/devices/laundryWasher.d.ts.map +0 -1
  111. package/dist/devices/laundryWasher.js.map +0 -1
  112. package/dist/devices/microwaveOven.d.ts +0 -168
  113. package/dist/devices/microwaveOven.d.ts.map +0 -1
  114. package/dist/devices/microwaveOven.js.map +0 -1
  115. package/dist/devices/oven.d.ts +0 -105
  116. package/dist/devices/oven.d.ts.map +0 -1
  117. package/dist/devices/oven.js.map +0 -1
  118. package/dist/devices/refrigerator.d.ts +0 -93
  119. package/dist/devices/refrigerator.d.ts.map +0 -1
  120. package/dist/devices/refrigerator.js.map +0 -1
  121. package/dist/devices/roboticVacuumCleaner.d.ts +0 -112
  122. package/dist/devices/roboticVacuumCleaner.d.ts.map +0 -1
  123. package/dist/devices/roboticVacuumCleaner.js.map +0 -1
  124. package/dist/devices/solarPower.d.ts +0 -40
  125. package/dist/devices/solarPower.d.ts.map +0 -1
  126. package/dist/devices/solarPower.js.map +0 -1
  127. package/dist/devices/temperatureControl.d.ts +0 -166
  128. package/dist/devices/temperatureControl.d.ts.map +0 -1
  129. package/dist/devices/temperatureControl.js.map +0 -1
  130. package/dist/devices/waterHeater.d.ts +0 -111
  131. package/dist/devices/waterHeater.d.ts.map +0 -1
  132. package/dist/devices/waterHeater.js.map +0 -1
  133. package/dist/dgram/coap.d.ts +0 -205
  134. package/dist/dgram/coap.d.ts.map +0 -1
  135. package/dist/dgram/coap.js.map +0 -1
  136. package/dist/dgram/dgram.d.ts +0 -140
  137. package/dist/dgram/dgram.d.ts.map +0 -1
  138. package/dist/dgram/dgram.js.map +0 -1
  139. package/dist/dgram/mb_coap.d.ts +0 -24
  140. package/dist/dgram/mb_coap.d.ts.map +0 -1
  141. package/dist/dgram/mb_coap.js.map +0 -1
  142. package/dist/dgram/mb_mdns.d.ts +0 -24
  143. package/dist/dgram/mb_mdns.d.ts.map +0 -1
  144. package/dist/dgram/mb_mdns.js.map +0 -1
  145. package/dist/dgram/mdns.d.ts +0 -288
  146. package/dist/dgram/mdns.d.ts.map +0 -1
  147. package/dist/dgram/mdns.js.map +0 -1
  148. package/dist/dgram/multicast.d.ts +0 -65
  149. package/dist/dgram/multicast.d.ts.map +0 -1
  150. package/dist/dgram/multicast.js.map +0 -1
  151. package/dist/dgram/unicast.d.ts +0 -56
  152. package/dist/dgram/unicast.d.ts.map +0 -1
  153. package/dist/dgram/unicast.js.map +0 -1
  154. package/dist/frontend.d.ts +0 -313
  155. package/dist/frontend.d.ts.map +0 -1
  156. package/dist/frontend.js.map +0 -1
  157. package/dist/globalMatterbridge.d.ts +0 -59
  158. package/dist/globalMatterbridge.d.ts.map +0 -1
  159. package/dist/globalMatterbridge.js.map +0 -1
  160. package/dist/helpers.d.ts +0 -48
  161. package/dist/helpers.d.ts.map +0 -1
  162. package/dist/helpers.js.map +0 -1
  163. package/dist/index.d.ts +0 -33
  164. package/dist/index.d.ts.map +0 -1
  165. package/dist/index.js.map +0 -1
  166. package/dist/logger/export.d.ts +0 -2
  167. package/dist/logger/export.d.ts.map +0 -1
  168. package/dist/logger/export.js.map +0 -1
  169. package/dist/matter/behaviors.d.ts +0 -2
  170. package/dist/matter/behaviors.d.ts.map +0 -1
  171. package/dist/matter/behaviors.js.map +0 -1
  172. package/dist/matter/clusters.d.ts +0 -2
  173. package/dist/matter/clusters.d.ts.map +0 -1
  174. package/dist/matter/clusters.js.map +0 -1
  175. package/dist/matter/devices.d.ts +0 -2
  176. package/dist/matter/devices.d.ts.map +0 -1
  177. package/dist/matter/devices.js.map +0 -1
  178. package/dist/matter/endpoints.d.ts +0 -2
  179. package/dist/matter/endpoints.d.ts.map +0 -1
  180. package/dist/matter/endpoints.js.map +0 -1
  181. package/dist/matter/export.d.ts +0 -5
  182. package/dist/matter/export.d.ts.map +0 -1
  183. package/dist/matter/export.js.map +0 -1
  184. package/dist/matter/types.d.ts +0 -3
  185. package/dist/matter/types.d.ts.map +0 -1
  186. package/dist/matter/types.js.map +0 -1
  187. package/dist/matterbridge.d.ts +0 -462
  188. package/dist/matterbridge.d.ts.map +0 -1
  189. package/dist/matterbridge.js.map +0 -1
  190. package/dist/matterbridgeAccessoryPlatform.d.ts +0 -42
  191. package/dist/matterbridgeAccessoryPlatform.d.ts.map +0 -1
  192. package/dist/matterbridgeAccessoryPlatform.js.map +0 -1
  193. package/dist/matterbridgeBehaviors.d.ts +0 -1351
  194. package/dist/matterbridgeBehaviors.d.ts.map +0 -1
  195. package/dist/matterbridgeBehaviors.js.map +0 -1
  196. package/dist/matterbridgeDeviceTypes.d.ts +0 -709
  197. package/dist/matterbridgeDeviceTypes.d.ts.map +0 -1
  198. package/dist/matterbridgeDeviceTypes.js.map +0 -1
  199. package/dist/matterbridgeDynamicPlatform.d.ts +0 -42
  200. package/dist/matterbridgeDynamicPlatform.d.ts.map +0 -1
  201. package/dist/matterbridgeDynamicPlatform.js.map +0 -1
  202. package/dist/matterbridgeEndpoint.d.ts +0 -1356
  203. package/dist/matterbridgeEndpoint.d.ts.map +0 -1
  204. package/dist/matterbridgeEndpoint.js.map +0 -1
  205. package/dist/matterbridgeEndpointHelpers.d.ts +0 -407
  206. package/dist/matterbridgeEndpointHelpers.d.ts.map +0 -1
  207. package/dist/matterbridgeEndpointHelpers.js.map +0 -1
  208. package/dist/matterbridgePlatform.d.ts +0 -331
  209. package/dist/matterbridgePlatform.d.ts.map +0 -1
  210. package/dist/matterbridgePlatform.js.map +0 -1
  211. package/dist/matterbridgeTypes.d.ts +0 -198
  212. package/dist/matterbridgeTypes.d.ts.map +0 -1
  213. package/dist/matterbridgeTypes.js.map +0 -1
  214. package/dist/pluginManager.d.ts +0 -270
  215. package/dist/pluginManager.d.ts.map +0 -1
  216. package/dist/pluginManager.js.map +0 -1
  217. package/dist/shelly.d.ts +0 -174
  218. package/dist/shelly.d.ts.map +0 -1
  219. package/dist/shelly.js.map +0 -1
  220. package/dist/storage/export.d.ts +0 -2
  221. package/dist/storage/export.d.ts.map +0 -1
  222. package/dist/storage/export.js.map +0 -1
  223. package/dist/update.d.ts +0 -75
  224. package/dist/update.d.ts.map +0 -1
  225. package/dist/update.js.map +0 -1
  226. package/dist/utils/colorUtils.d.ts +0 -99
  227. package/dist/utils/colorUtils.d.ts.map +0 -1
  228. package/dist/utils/colorUtils.js.map +0 -1
  229. package/dist/utils/commandLine.d.ts +0 -59
  230. package/dist/utils/commandLine.d.ts.map +0 -1
  231. package/dist/utils/commandLine.js.map +0 -1
  232. package/dist/utils/copyDirectory.d.ts +0 -33
  233. package/dist/utils/copyDirectory.d.ts.map +0 -1
  234. package/dist/utils/copyDirectory.js.map +0 -1
  235. package/dist/utils/createDirectory.d.ts +0 -34
  236. package/dist/utils/createDirectory.d.ts.map +0 -1
  237. package/dist/utils/createDirectory.js.map +0 -1
  238. package/dist/utils/createZip.d.ts +0 -39
  239. package/dist/utils/createZip.d.ts.map +0 -1
  240. package/dist/utils/createZip.js.map +0 -1
  241. package/dist/utils/deepCopy.d.ts +0 -32
  242. package/dist/utils/deepCopy.d.ts.map +0 -1
  243. package/dist/utils/deepCopy.js.map +0 -1
  244. package/dist/utils/deepEqual.d.ts +0 -54
  245. package/dist/utils/deepEqual.d.ts.map +0 -1
  246. package/dist/utils/deepEqual.js.map +0 -1
  247. package/dist/utils/error.d.ts +0 -44
  248. package/dist/utils/error.d.ts.map +0 -1
  249. package/dist/utils/error.js.map +0 -1
  250. package/dist/utils/export.d.ts +0 -12
  251. package/dist/utils/export.d.ts.map +0 -1
  252. package/dist/utils/export.js.map +0 -1
  253. package/dist/utils/hex.d.ts +0 -89
  254. package/dist/utils/hex.d.ts.map +0 -1
  255. package/dist/utils/hex.js.map +0 -1
  256. package/dist/utils/isvalid.d.ts +0 -103
  257. package/dist/utils/isvalid.d.ts.map +0 -1
  258. package/dist/utils/isvalid.js.map +0 -1
  259. package/dist/utils/network.d.ts +0 -84
  260. package/dist/utils/network.d.ts.map +0 -1
  261. package/dist/utils/network.js.map +0 -1
  262. package/dist/utils/spawn.d.ts +0 -33
  263. package/dist/utils/spawn.d.ts.map +0 -1
  264. package/dist/utils/spawn.js.map +0 -1
  265. package/dist/utils/wait.d.ts +0 -54
  266. package/dist/utils/wait.d.ts.map +0 -1
  267. package/dist/utils/wait.js.map +0 -1
@@ -1,709 +0,0 @@
1
- /**
2
- * This file contains the class MatterbridgeDevice.
3
- *
4
- * @file matterbridgeDeviceTypes.ts
5
- * @author Luca Liguori
6
- * @created 2024-11-08
7
- * @version 1.0.0
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 { ClusterId, DeviceTypeId, EndpointNumber } from '@matter/main';
25
- import { Semtag } from '@matter/main/types';
26
- export declare enum DeviceClasses {
27
- /** Node device type. */
28
- Node = "Node",
29
- /**
30
- * Application device type.
31
- * Application devices types are typically the most datatype endpoints on a node and in the network.
32
- */
33
- App = "App",
34
- /**
35
- * Utility device type.
36
- * A Utility device type supports configuration and settings.
37
- */
38
- Utility = "Utility",
39
- /**
40
- * Simple device type.
41
- * A Simple device type supports local control that is persistent, independent, and unsupervised.
42
- */
43
- Simple = "Simple",
44
- /**
45
- * Dynamic device type.
46
- * A Dynamic device type supports intelligent and supervisory services, such as commissioning,
47
- * monitoring, trend analysis, scheduling and central management. A dynamic device type is an
48
- * application device type.
49
- */
50
- Dynamic = "Dynamic",
51
- /** There exists a client application cluster on the endpoint. */
52
- Client = "Client",
53
- /** There exists a server application cluster on the endpoint. */
54
- Server = "Server",
55
- /** The device type is composed of 2 or more device types. */
56
- Composed = "Composed",
57
- /** The endpoint and at least one of its sibling endpoints have an overlap in application device type(s). */
58
- Duplicate = "Duplicate",
59
- /**
60
- * The endpoint represents a Bridged Device, for which information about the state of
61
- * its power source is available to the Bridge
62
- */
63
- BridgedPowerSourceInfo = "BridgedPowerSourceInfo"
64
- }
65
- export interface DeviceTypeDefinition {
66
- name: string;
67
- code: DeviceTypeId;
68
- deviceClass: DeviceClasses;
69
- revision: number;
70
- requiredServerClusters: ClusterId[];
71
- optionalServerClusters: ClusterId[];
72
- requiredClientClusters: ClusterId[];
73
- optionalClientClusters: ClusterId[];
74
- }
75
- export declare const DeviceTypeDefinition: ({ name, code, deviceClass, revision, requiredServerClusters, optionalServerClusters, requiredClientClusters, optionalClientClusters, }: {
76
- name: string;
77
- code: number;
78
- deviceClass: DeviceClasses;
79
- revision: number;
80
- requiredServerClusters?: ClusterId[];
81
- optionalServerClusters?: ClusterId[];
82
- requiredClientClusters?: ClusterId[];
83
- optionalClientClusters?: ClusterId[];
84
- }) => DeviceTypeDefinition;
85
- /**
86
- * MatterbridgeEndpointOptions interface is used to define the options for a Matterbridge endpoint.
87
- *
88
- * @remarks
89
- * - tagList?: Semtag[]. It is used to disambiguate the sibling child endpoints (9.2.3. Disambiguation rule).
90
- * - mfgCode: VendorId | null,
91
- * - namespaceId: number,
92
- * - tag: number,
93
- * - label: string | undefined | null
94
- * - mode?: 'server' | 'matter'. It is used to activate a special mode for the endpoint.
95
- * - id?: string. It is the unique storage key for the endpoint.
96
- * - number?: EndpointNumber. It is the endpoint number for the endpoint.
97
- */
98
- export interface MatterbridgeEndpointOptions extends EndpointOptions {
99
- /**
100
- * The semantic tags array for the endpoint.
101
- * The tagList is used to disambiguate the sibling child endpoints (9.2.3. Disambiguation rule).
102
- * The tagList is used to identify the endpoint and to provide additional information about the endpoint.
103
- *
104
- * @remarks
105
- * - mfgCode: VendorId | null,
106
- * - namespaceId: number,
107
- * - tag: number,
108
- * - label: string | undefined | null
109
- */
110
- tagList?: Semtag[];
111
- /**
112
- * Activates a special mode for this endpoint.
113
- * - 'server': it creates the device server node and add the device as Matter device that needs to be paired individually.
114
- * In this case the Matterbridge bridge mode (bridge or childbridge) is not relevant. The device is independent.
115
- *
116
- * - 'matter': it adds the device directly to the Matterbridge server node as Matter device alongside the aggregator. In this case the implementation must respect
117
- * the 9.2.3. Disambiguation rule (i.e. use taglist if needed cause the device doesn't have nodeLabel).
118
- * Furthermore the device will be a part of the bridge (i.e. will have the same name and will be in the same room).
119
- * See 9.12.2.2. Native Matter functionality in Bridge.
120
- *
121
- * @remarks
122
- * Always use createDefaultBasicInformationClusterServer() to create the BasicInformation cluster server when using mode 'server' or 'matter'.
123
- */
124
- mode?: 'server' | 'matter';
125
- /**
126
- * The unique storage key for the endpoint.
127
- * If not provided, a default key will be used.
128
- */
129
- id?: string;
130
- /**
131
- * The endpoint number for the endpoint.
132
- * If not provided, the endpoint will be created with the next available endpoint number.
133
- * If provided, the endpoint will be created with the specified endpoint number.
134
- */
135
- number?: EndpointNumber;
136
- }
137
- /**
138
- * EndpointOptions interface is used to define the options for an endpoint.
139
- *
140
- * @deprecated Use `MatterbridgeEndpointOptions` instead.
141
- */
142
- export interface EndpointOptions {
143
- /**
144
- * Old API compatibility replaced by number.
145
- *
146
- * @deprecated Use `number` instead.
147
- */
148
- endpointId?: EndpointNumber;
149
- /**
150
- * Old API compatibility replaced by id.
151
- *
152
- * @deprecated Use `id` instead.
153
- */
154
- uniqueStorageKey?: string;
155
- }
156
- export declare const powerSource: DeviceTypeDefinition;
157
- export declare const OTARequestor: DeviceTypeDefinition;
158
- export declare const OTAProvider: DeviceTypeDefinition;
159
- /**
160
- 2.5.3. Conditions
161
- Please see the Base Device Type definition for conformance tags.
162
- This device type SHALL only be used for Nodes which have a device type of Bridge.
163
-
164
- 2.5.5. Cluster Requirements
165
- Each endpoint supporting this device type SHALL include these clusters based on the conformance
166
- defined below.
167
- - 0x0039 Bridged Device Basic Information Server
168
-
169
- 2.5.6. Endpoint Composition
170
- • A Bridged Node endpoint SHALL support one of the following composition patterns:
171
- ◦ Separate Endpoints: All application device types are supported on separate endpoints, and
172
- not on the Bridged Node endpoint. The Bridged Node endpoint’s Descriptor cluster PartsList
173
- attribute SHALL indicate a list of all endpoints representing the functionality of the bridged
174
- device, including the endpoints supporting the application device types, i.e. the full-family
175
- pattern defined in the System Model specification.
176
- ◦ One Endpoint: Both the Bridged Node and one or more application device types are sup
177
- ported on the same endpoint (following application device type rules). Endpoint composi
178
- tion SHALL conform to the application device type(s) definition
179
- */
180
- export declare const bridgedNode: DeviceTypeDefinition;
181
- /**
182
- * An Electrical Sensor device measures the electrical power and/or energy being imported and/or
183
- * exported.
184
- * It is a utility device type that provides information about the electrical power and/or energy
185
- * consumption and generation.
186
- *
187
- * 2.6.3. Device Type Requirements
188
- * Electrical measurements made by either the Electrical Power Measurement cluster, the Electrical
189
- * Energy Measurement cluster, or both SHALL apply to the endpoints indicated by the Power Topology
190
- * cluster.
191
- */
192
- export declare const electricalSensor: DeviceTypeDefinition;
193
- /**
194
- * A Device Energy Management device provides reporting and optionally adjustment of the electrical
195
- * power planned on being consumed or produced by the device.
196
- */
197
- export declare const deviceEnergyManagement: DeviceTypeDefinition;
198
- /**
199
- * Element Requirements:
200
- * - Identify Command TriggerEffect
201
- * - Scenes Management Command CopyScene
202
- * - On/Off Feature Lighting
203
- * - Level Control Feature OnOff
204
- * - Level Control Feature Lighting
205
- * - Level Control Attribute CurrentLevel 1 to 254
206
- * - Level Control Attribute MinLevel 1
207
- * - Level Control Attribute MaxLevel 254
208
- */
209
- export declare const onOffLight: DeviceTypeDefinition;
210
- /**
211
- * Element Requirements:
212
- * - Identify Command TriggerEffect
213
- * - Scenes Management Command CopyScene
214
- * - On/Off Feature Lighting
215
- * - Level Control Feature OnOff
216
- * - Level Control Feature Lighting
217
- * - Level Control Attribute CurrentLevel 1 to 254
218
- * - Level Control Attribute MinLevel 1
219
- * - Level Control Attribute MaxLevel 254
220
- */
221
- export declare const dimmableLight: DeviceTypeDefinition;
222
- /**
223
- * Element Requirements:
224
- * - Identify Command TriggerEffect
225
- * - Scenes Management Command CopyScene
226
- * - On/Off Feature Lighting
227
- * - Level Control Feature OnOff
228
- * - Level Control Feature Lighting
229
- * - Level Control Attribute CurrentLevel 1 to 254
230
- * - Level Control Attribute MinLevel 1
231
- * - Level Control Attribute MaxLevel 254
232
- * - Color Control Feature ColorTemperature
233
- * - Color Control Attribute RemainingTime
234
- */
235
- export declare const colorTemperatureLight: DeviceTypeDefinition;
236
- /**
237
- * Element Requirements:
238
- * - Identify Command TriggerEffect
239
- * - Scenes Management Command CopyScene
240
- * - On/Off Feature Lighting
241
- * - Level Control Feature OnOff
242
- * - Level Control Feature Lighting
243
- * - Level Control Attribute CurrentLevel 1 to 254
244
- * - Level Control Attribute MinLevel 1
245
- * - Level Control Attribute MaxLevel 254
246
- * - Color Control Feature XY
247
- * - Color Control Feature ColorTemperature
248
- * - Color Control Attribute RemainingTime
249
- */
250
- export declare const extendedColorLight: DeviceTypeDefinition;
251
- /**
252
- * Element Requirements:
253
- * - Identify Command TriggerEffect
254
- * - Scenes Management Command CopyScene
255
- * - On/Off Feature Lighting
256
- * - Level Control Feature OnOff
257
- * - Level Control Feature Lighting
258
- * - Level Control Attribute CurrentLevel 1 to 254
259
- * - Level Control Attribute MinLevel 1
260
- * - Level Control Attribute MaxLevel 254
261
- */
262
- export declare const onOffOutlet: DeviceTypeDefinition;
263
- /**
264
- * Element Requirements:
265
- * - Identify Command TriggerEffect
266
- * - Scenes Management Command CopyScene
267
- * - On/Off Feature Lighting
268
- * - Level Control Feature OnOff
269
- * - Level Control Feature Lighting
270
- * - Level Control Attribute CurrentLevel 1 to 254
271
- * - Level Control Attribute MinLevel 1
272
- * - Level Control Attribute MaxLevel 254
273
- */
274
- export declare const dimmableOutlet: DeviceTypeDefinition;
275
- /**
276
- * A Mounted On/Off Control is a fixed device that provides power to another device that is plugged
277
- * into it, and is capable of switching that provided power on or off.
278
- * It is a simple device type that does not require any client clusters.
279
- * Element Requirements:
280
- * - Identify Command TriggerEffect
281
- * - Scenes Management Command CopyScene
282
- * - On/Off Feature Lighting
283
- * - Level Control Feature OnOff
284
- * - Level Control Feature Lighting
285
- * - Level Control Attribute CurrentLevel 1 to 254
286
- * - Level Control Attribute MinLevel 1
287
- * - Level Control Attribute MaxLevel 254
288
- */
289
- export declare const onOffMountedSwitch: DeviceTypeDefinition;
290
- /**
291
- * A Mounted Dimmable Load Control is a fixed device that provides power to another device that is
292
- * plugged into it, and is capable of being switched on or off and have its level adjusted. The Mounted
293
- * Dimmable Load Control is typically used to control a conventional non-communicating light
294
- * through its mains connection using phase cutting.
295
- * It is a simple device type that does not require any client clusters.
296
- * Element Requirements:
297
- * - Identify Command TriggerEffect
298
- * - Scenes Management Command CopyScene
299
- * - On/Off Feature Lighting
300
- * - Level Control Feature OnOff
301
- * - Level Control Feature Lighting
302
- * - Level Control Attribute CurrentLevel 1 to 254
303
- * - Level Control Attribute MinLevel 1
304
- * - Level Control Attribute MaxLevel 254
305
- */
306
- export declare const dimmableMountedSwitch: DeviceTypeDefinition;
307
- /**
308
- * Remark:
309
- * On/Off Cluster:
310
- * - Off If the pump is powered on, store the current level then immediately power it off.
311
- * - On If the pump is powered off, power it on and move immediately to the level stored by a previous Off command. If no such level has been stored,
312
- * move immediately to the maximum level allowed for the pump.
313
- * - Toggle If the pump is powered on, proceed as for the Off command. If the device is powered off, proceed as for the On command.
314
- *
315
- * LevelControl cluster:
316
- * Level Setpoint Meaning
317
- * 0 N/A Pump is stopped,
318
- * 1–200 Level / 2 (0.5–100.0%) Pump setpoint in percent
319
- * 201–255 100.0% Pump setpoint is 100.0%
320
- */
321
- export declare const pumpDevice: DeviceTypeDefinition;
322
- export declare const waterValve: DeviceTypeDefinition;
323
- export declare const onOffSwitch: DeviceTypeDefinition;
324
- export declare const dimmableSwitch: DeviceTypeDefinition;
325
- export declare const colorTemperatureSwitch: DeviceTypeDefinition;
326
- export declare const genericSwitch: DeviceTypeDefinition;
327
- /**
328
- * Closed or contact: state true
329
- * Open or no contact: state false
330
- */
331
- export declare const contactSensor: DeviceTypeDefinition;
332
- export declare const lightSensor: DeviceTypeDefinition;
333
- export declare const occupancySensor: DeviceTypeDefinition;
334
- export declare const temperatureSensor: DeviceTypeDefinition;
335
- export declare const pressureSensor: DeviceTypeDefinition;
336
- export declare const flowSensor: DeviceTypeDefinition;
337
- export declare const humiditySensor: DeviceTypeDefinition;
338
- export declare const smokeCoAlarm: DeviceTypeDefinition;
339
- export declare const airQualitySensor: DeviceTypeDefinition;
340
- export declare const waterFreezeDetector: DeviceTypeDefinition;
341
- export declare const waterLeakDetector: DeviceTypeDefinition;
342
- export declare const rainSensor: DeviceTypeDefinition;
343
- /**
344
- * A Door Lock is a device used to secure a door. It is possible to actuate a door lock either by means of a manual or a remote method.
345
- * Element Requirements:
346
- *
347
- * - AccessControl Attribute Extension
348
- * - DoorLock Feature User
349
- * - DoorLock Attribute AlarmMask
350
- */
351
- export declare const doorLockDevice: DeviceTypeDefinition;
352
- export declare const coverDevice: DeviceTypeDefinition;
353
- /**
354
- * A Thermostat device is capable of having either built-in or separate sensors for temperature,
355
- * humidity or occupancy. It allows the desired temperature to be set either remotely or locally. The
356
- * thermostat is capable of sending heating and/or cooling requirement notifications to a heating/cooling
357
- * unit (for example, an indoor air handler) or is capable of including a mechanism to control a
358
- * heating or cooling unit directly.
359
- *
360
- */
361
- export declare const thermostatDevice: DeviceTypeDefinition;
362
- /**
363
- * A Fan device is typically standalone or mounted on a ceiling or wall and is used to circulate air in a room.
364
- * Remark: it may have a thermostat device type.
365
- * Additional device types MAY also be included in device compositions.
366
- * Element Requirements:
367
- * The FanControl cluster must have the FanModeSequence attribute.
368
- *
369
- * The On/Off cluster is independent from the Fan Control Cluster’s FanMode attribute, which also
370
- * includes an Off setting.
371
- * If the FanMode attribute of the Fan Control cluster is set to a value other than Off when the OnOff
372
- * attribute of the On/Off cluster transitions from TRUE to FALSE, it may be desirable to restore the
373
- * FanMode, SpeedSetting and PercentSetting attribute values of the Fan Control cluster when the OnOff
374
- * attribute of the On/Off cluster later transitions from FALSE to TRUE. If the FanMode is set to Off when
375
- * the device is turned off, this information is lost, as the SpeedSetting and PercentSetting will be set to
376
- * zero. Using the On/Off cluster alongside the Fan Control cluster allows the FanMode, SpeedSetting and
377
- * PercentSetting to remain unchanged when the device is turned off. In this case, the On/Off cluster
378
- * would be set to Off, and the SpeedCurrent and PercentCurrent set to zero, without changing FanMode,
379
- * SpeedSetting and PercentSetting.
380
- */
381
- export declare const fanDevice: DeviceTypeDefinition;
382
- /**
383
- * An Air Purifier is a standalone device that is designed to clean the air in a room.
384
- * It is a device that has a fan to control the air speed while it is operating. Optionally, it can report on
385
- * the condition of its filters.
386
- *
387
- * Remark:
388
- * An Air Purifier MAY expose elements of its functionality through one or more additional device
389
- * types on different endpoints. All devices used in compositions SHALL adhere to the disambiguation
390
- * requirements of the System Model. Other device types, not explicitly listed in the table, MAY also be
391
- * included in device compositions but are not considered part of the core functionality of the device.
392
- * 0x0301 Thermostat O
393
- * 0x0302 Temperature Sensor O
394
- * 0x0307 Humidity Sensor O
395
- * 0x002C Air Quality Sensor O
396
- *
397
- * Cluster Restrictions:
398
- * The On/Off cluster is independent from the Fan Control Cluster’s FanMode attribute, which also
399
- * includes an Off setting.
400
- * If the FanMode attribute of the Fan Control cluster is set to a value other than Off when the OnOff
401
- * attribute of the On/Off cluster transitions from TRUE to FALSE, it may be desirable to restore the
402
- * FanMode, SpeedSetting and PercentSetting attribute values of the Fan Control cluster when the OnOff
403
- * attribute of the On/Off cluster later transitions from FALSE to TRUE. If the FanMode is set to Off when
404
- * the device is turned off, this information is lost, as the SpeedSetting and PercentSetting will be set to
405
- * zero. Using the On/Off cluster alongside the Fan Control cluster allows the FanMode, SpeedSetting and
406
- * PercentSetting to remain unchanged when the device is turned off. In this case, the On/Off cluster
407
- * would be set to Off, and the SpeedCurrent and PercentCurrent set to zero, without changing FanMode,
408
- * SpeedSetting and PercentSetting.
409
- *
410
- */
411
- export declare const airPurifier: DeviceTypeDefinition;
412
- export declare const modeSelect: DeviceTypeDefinition;
413
- /**
414
- * This device type aggregates endpoints as a collection. Clusters on the endpoint indicating this
415
- * device type provide functionality for the collection of descendant endpoints present in the PartsList
416
- * of the endpoint’s descriptor, for example the Actions cluster.
417
- *
418
- * Endpoint Composition:
419
- * An Aggregator endpoint’s Descriptor cluster PartsList attribute SHALL list the collection of all endpoints
420
- * aggregated by the Aggregator device type, i.e. the full-family pattern defined in the System Model specification.
421
- *
422
- * Disambiguation:
423
- * If the Duplicate condition applies to child endpoints of an Aggregator endpoint that represent multiple
424
- * independent bridged devices, the endpoints SHOULD make available metadata to allow a
425
- * client to disambiguate distinct bridged devices with an overlap in application device types.
426
- *
427
- * Typically this is done using the NodeLabel attribute of the Bridged Device Basic Information cluster
428
- * - thus reusing the naming information which the bridge already has to allow disambiguation to the
429
- * user when using a direct user interface to the bridge.
430
- *
431
- * Actions cluster (9.14 Matter specification):
432
- * If a Bridge has (such) information on topology or logical grouping, it SHOULD expose such information
433
- * in the EndpointLists attribute of an Actions cluster (the ActionLists of which MAY be empty if
434
- * no actions are exposed). 9.12 Matter specification
435
- *
436
- * 9.12.5. New features for Bridged Devices
437
- * Bridged Devices can have their software updated independently of the Bridge, through Bridge Manufacturer-
438
- * specific means. These updates MAY result in one or more changes to their capabilities,
439
- * such as supported clusters and/or attributes, for an endpoint. Like every Matter Node, every endpoint
440
- * on the Bridge’s Node contains a Descriptor cluster that contains attributes for the device types
441
- * (DeviceTypeList), endpoints (PartsList) and supported clusters (ServerList and ClientList). Nodes
442
- * that wish to be notified of such changes SHOULD monitor changes of these attributes.
443
- */
444
- export declare const aggregator: DeviceTypeDefinition;
445
- export declare const bridge: DeviceTypeDefinition;
446
- /**
447
- * A Robotic Vacuum Cleaner is a device that is capable of cleaning floors and other surfaces
448
- * in a home or office environment. It is typically a mobile device that can navigate around
449
- * obstacles and can be controlled remotely.
450
- *
451
- * Cluster Usage:
452
- * The RVC Operational State cluster’s OperationalState attribute SHALL be updated according to the
453
- * state of the device, and therefore it SHOULD be used for monitoring purposes.
454
- *
455
- * To attempt starting a cleaning operation, the RVC Run Mode cluster can be sent a ChangeToMode
456
- * command with the NewMode field set to a mode that has the Cleaning mode tag associated with it.
457
- *
458
- * To attempt stopping a cleaning operation, the RVC Run Mode cluster can be sent a ChangeToMode
459
- * command with the NewMode field set to a mode that has the Idle mode tag associated with it.
460
- *
461
- * To attempt pausing a cleaning operation, the RVC Operational State cluster can be sent a Pause command.
462
- *
463
- * To attempt resuming a cleaning operation, the RVC Operational State cluster can be sent a Resume
464
- * command.
465
- *
466
- *
467
- */
468
- export declare const roboticVacuumCleaner: DeviceTypeDefinition;
469
- /**
470
- * Cluster Restrictions:
471
- * On/Off Cluster: the DF (Dead Front) feature is required
472
- */
473
- export declare const laundryWasher: DeviceTypeDefinition;
474
- /**
475
- * A refrigerator represents a device that contains one or more cabinets that are capable of chilling or freezing food.
476
- * A Refrigerator SHALL be composed of at least one endpoint with the Temperature Controlled Cabinet device type.
477
- *
478
- * Device Type Requirements:
479
- * 0x0071 Temperature Controlled Cabinet
480
- */
481
- export declare const refrigerator: DeviceTypeDefinition;
482
- /**
483
- * A Room Air Conditioner is a device with the primary function of controlling the air temperature in a single room.
484
- *
485
- * A Room Air Conditioner MAY have zero or more of each device type listed in this table subject to
486
- * the conformance column of the table. All devices used in compositions SHALL adhere to the disambiguation
487
- * requirements of the System Model. Additional device types not listed in this table MAY also be included in device compositions.
488
- * 0x0302 Temperature Sensor O
489
- * 0x0307 Humidity Sensor O
490
- *
491
- * Remark:
492
- * The DF (Dead Front) feature is required for the On/Off cluster in this device type:
493
- * - Thermostat LocalTemperature null
494
- * - Temperature Measurement MeasuredValue null
495
- * - Relative Humidity Measurement MeasuredValue null
496
- * - Fan Control SpeedSetting null
497
- * - Fan Control PercentSetting null
498
- */
499
- export declare const airConditioner: DeviceTypeDefinition;
500
- /**
501
- * A Temperature Controlled Cabinet only exists composed as part of another device type. It represents
502
- * a single cabinet that is capable of having its temperature controlled. Such a cabinet may be
503
- * chilling or freezing food, for example as part of a refrigerator, freezer, wine chiller, or other similar
504
- * device. Equally, such a cabinet may be warming or heating food, for example as part of an oven,
505
- * range, or similar device.
506
- * Conditions:
507
- * Cooler The device has cooling functionality.
508
- */
509
- export declare const temperatureControlledCabinetCooler: DeviceTypeDefinition;
510
- /**
511
- * A Temperature Controlled Cabinet only exists composed as part of another device type. It represents
512
- * a single cabinet that is capable of having its temperature controlled. Such a cabinet may be
513
- * chilling or freezing food, for example as part of a refrigerator, freezer, wine chiller, or other similar
514
- * device. Equally, such a cabinet may be warming or heating food, for example as part of an oven,
515
- * range, or similar device.
516
- * Conditions:
517
- * Heater The device has heating functionality.
518
- */
519
- export declare const temperatureControlledCabinetHeater: DeviceTypeDefinition;
520
- /**
521
- * Cluster Restrictions:
522
- * On/Off Cluster: the DF (Dead Front) feature is required
523
- */
524
- export declare const dishwasher: DeviceTypeDefinition;
525
- /**
526
- * Cluster Restrictions:
527
- * On/Off Cluster: the DF (Dead Front) feature is required
528
- */
529
- export declare const laundryDryer: DeviceTypeDefinition;
530
- /**
531
- * A Cook Surface device type represents a heating object on a cooktop or other similar device. It
532
- * SHALL only be used when composed as part of another device type (cooktop).
533
- *
534
- * Cluster Restrictions:
535
- * The OffOnly feature is required for the On/Off cluster in this device type due to safety requirements.
536
- */
537
- export declare const cookSurface: DeviceTypeDefinition;
538
- /**
539
- * A cooktop is a cooking surface that heats food either by transferring currents from an electromagnetic
540
- * field located below the glass surface directly to the magnetic induction cookware placed
541
- * above or through traditional gas or electric burners.
542
- *
543
- * Device Type Requirements:
544
- * A Cooktop SHALL be composed of zero or more endpoints with the Cook Surface device type as defined by the conformance below.
545
- * 0x0077 Cook Surface min 1 O
546
- *
547
- * Cluster Restrictions:
548
- * The OffOnly feature is required for the On/Off cluster in this device type due to safety requirements.
549
- */
550
- export declare const cooktop: DeviceTypeDefinition;
551
- /**
552
- * An oven represents a device that contains one or more cabinets, and optionally a single cooktop, that are all capable of heating food.
553
- * An oven is always defined via endpoint composition.
554
- * Conditions:
555
- * An Oven SHALL have the Heater condition applied to at least one endpoint containing the Temperature Control Cluster.
556
- * Device Type Requirements:
557
- * - 0x0071 Temperature Controlled Cabinet min 1
558
- * - 0x0078 Cooktop
559
- */
560
- export declare const oven: DeviceTypeDefinition;
561
- /**
562
- * An Extractor Hood is a device that is generally installed above a cooking surface in residential kitchens.
563
- * Additional device types not listed in this table MAY also be included in device compositions.
564
- * Device Type Requirements:
565
- * 0x0100+ On/Off Light+ O
566
- *
567
- *
568
- * Element Requirements:
569
- * - 0x0202 Fan Control Feature Rocking X
570
- * - 0x0202 Fan Control Feature Wind X
571
- * - 0x0202 Fan Control Feature AirflowDirection X
572
- */
573
- export declare const extractorHood: DeviceTypeDefinition;
574
- /**
575
- * A Microwave Oven is a device with the primary function of heating foods and beverages using a magnetron.
576
- * A Microwave Oven is a device which at a minimum is capable of being started and stopped and of setting a power level.
577
- * A Microwave Oven MAY also support additional capabilities via endpoint composition.
578
- *
579
- */
580
- export declare const microwaveOven: DeviceTypeDefinition;
581
- /**
582
- * An EVSE (Electric Vehicle Supply Equipment) is a device that allows an EV (Electric Vehicle) to be
583
- * connected to the mains electricity supply to allow it to be charged (or discharged in case of Vehicle
584
- * to Grid / Vehicle to Home applications).
585
- *
586
- * 14.1.5. Device Type Requirements
587
- * An EVSE SHALL be composed of at least one endpoint with device types as defined by the conformance
588
- * below. There MAY be more endpoints with other device types existing in the EVSE.
589
- * - ID Name Constraint Conformance
590
- * - 0x0011 Power Source min 1 M
591
- * - 0x0510 Electrical Sensor min 1 M
592
- * - 0x050D Device Energy Management min 1 M
593
- *
594
- * The Electrical Sensor device SHALL include both the Electrical Energy Measurement and Electrical
595
- * Power Measurement clusters, measuring the total energy and power of the EVSE.
596
- *
597
- * The Device Energy Management cluster included in the Device Energy Management device SHALL
598
- * support the Power Forecast Reporting (PFR) feature.
599
- */
600
- export declare const evse: DeviceTypeDefinition;
601
- /**
602
- * A water heater is a device that is generally installed in properties to heat water for showers, baths etc.
603
- * A Water Heater is always defined via endpoint composition.
604
- *
605
- * 14.2.5. Device Type Requirements
606
- * A Water Heater SHALL be composed of at least one endpoint with device types as defined by the
607
- * conformance below. There MAY be more endpoints with other device types existing in the Water Heater.
608
- * - ID Name Constraint Conformance
609
- * - 0x0011 Power Source O
610
- * - 0x0302 Temperature Sensor O
611
- * - 0x0510 Electrical Sensor desc
612
- * - 0x050D Device Energy Management O
613
- *
614
- * 14.2.7. Element Requirements
615
- * 0x0201 Thermostat Feature Heating M
616
- *
617
- * The Energy Management feature of the Water Heater cluster SHALL be supported if the Device
618
- * Energy Management device type is included.
619
- * If Off is a supported SystemMode in the Thermostat cluster, setting the SystemMode of the Thermostat
620
- * cluster to Off SHALL set the CurrentMode attribute of the Water Heater Mode cluster to a mode
621
- * having the Off mode tag value and vice versa.
622
- * At least one entry in the SupportedModes attribute of the Water Heater Mode cluster SHALL
623
- * include the Timed mode tag in the ModeTags field list.
624
- *
625
- * WaterHeaterMode Cluster
626
- * 9.6.6.1. SupportedModes Attribute
627
- * At least one entry in the SupportedModes attribute SHALL include the Manual mode tag in the
628
- * ModeTags field list.
629
- * At least one entry in the SupportedModes attribute SHALL include the Off mode tag in the ModeTags
630
- * field list.
631
- * An entry in the SupportedModes attribute that includes one of an Off, Manual, or Timed tag SHALL
632
- * NOT also include an additional instance of any one of these tag types.
633
- */
634
- export declare const waterHeater: DeviceTypeDefinition;
635
- /**
636
- * A Solar Power device is a device that allows a solar panel array, which can optionally be comprised
637
- * of a set parallel strings of solar panels, and its associated controller and, if appropriate, inverter, to
638
- * be monitored and controlled by an Energy Management System.
639
- *
640
- * 14.3.5. Device Type Requirements
641
- * A Solar Power device SHALL be composed of at least one endpoint with device types as defined by
642
- * the conformance below. There MAY be more endpoints with additional instances of these device
643
- * types or additional device types existing in the Solar Power device.
644
- *
645
- * - ID Name Constraint Conformance
646
- * - 0x0011 Power Source min 1 M
647
- * - 0x0510 Electrical Sensor min 1 M
648
- * - 0x050D Device Energy Management O
649
- * - 0x0302 Temperature Sensor O
650
- *
651
- * 14.3.5.1. Cluster Requirements on Composing Device Types
652
- *
653
- * - 0x0011 Power Source 0x002F Power Source Feature Wired M
654
- * - 0x0011 Power Source 0x001D Descriptor Feature TagList M
655
- * - 0x0510 Electrical Sensor 0x0090 Electrical Power Measurement M
656
- * - 0x0510 Electrical Sensor 0x0090 Electrical Power Measurement Attribute Voltage M
657
- * - 0x0510 Electrical Sensor 0x0090 Electrical Power Measurement Attribute ActiveCurrent M
658
- * - 0x0510 Electrical Sensor 0x0091 Electrical Energy Measurement M
659
- * - 0x0510 Electrical Sensor 0x0091 Electrical Energy Measurement Feature ExportedEnergy M
660
- * - 0x050D Device Energy Management 0x0098 Device Energy Management Feature PowerAdjustment M
661
- * - 0x0302 Temperature Sensor 0x001D Descriptor Feature TagList M
662
- */
663
- export declare const solarPower: DeviceTypeDefinition;
664
- /**
665
- * A Battery Storage device is a device that allows a DC battery, which can optionally be comprised of
666
- * a set parallel strings of battery packs and associated controller, and an AC inverter, to be monitored
667
- * and controlled by an Energy Management System in order to manage the peaks and troughs of supply
668
- * and demand, and/or to optimize cost of the energy consumed in premises. It is not intended to
669
- * be used for a UPS directly supplying a set of appliances, nor for portable battery storage devices.
670
- *
671
- * 14.4.5. Device Type Requirements
672
- * A Battery Storage device SHALL be composed of at least one endpoint with device types as defined by
673
- * the conformance below. There MAY be more endpoints with additional instances of these device
674
- * types or additional device types existing in the Battery Storage device.
675
- * - ID Name Constraint Conformance
676
- * - 0x0011 Power Source min 1 M
677
- * - 0x0510 Electrical Sensor min 1 M
678
- * - 0x050D Device Energy Management M
679
- * - 0x0302 Temperature Sensor O
680
- * - 0x0017 Solar Power O
681
- *
682
- * See 14.4.5.1. Cluster Requirements on Composing Device Types
683
- */
684
- export declare const batteryStorage: DeviceTypeDefinition;
685
- /**
686
- * A Heat Pump device is a device that uses electrical energy to heat either spaces or water tanks using
687
- * ground, water or air as the heat source. These typically can heat the air or can pump water via central
688
- * heating radiators or underfloor heating systems. It is typical to also heat hot water and store
689
- * the heat in a hot water tank.
690
- *
691
- * 14.5.1. Heat Pump Architecture
692
- * A Heat Pump device is always defined via endpoint composition.
693
- *
694
- * 14.5.5. Device Type Requirements
695
- * A Heat Pump device SHALL be composed of at least one endpoint with device types as defined by
696
- * the conformance below. There MAY be more endpoints with additional instances of these device
697
- * types or additional device types existing in the Heat Pump device.
698
- * - ID Name Constraint Conformance
699
- * - 0x0011 Power Source M
700
- * - 0x0510 Electrical Sensor min 1 M
701
- * - 0x050D Device Energy Management M
702
- * - 0x0301 Thermostat O
703
- * - 0x050f Water Heater O
704
- * - 0x0302 Temperature Sensor O
705
- *
706
- * See 14.5.5.1. Cluster Requirements on Composing Device Types
707
- */
708
- export declare const heatPump: DeviceTypeDefinition;
709
- //# sourceMappingURL=matterbridgeDeviceTypes.d.ts.map