@matter/types 0.13.0-alpha.0-20250304-d4a7592a4 → 0.13.0-alpha.0-20250311-3eb0af5f2

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 (807) hide show
  1. package/dist/cjs/clusters/access-control.d.ts +3972 -522
  2. package/dist/cjs/clusters/access-control.d.ts.map +1 -1
  3. package/dist/cjs/clusters/access-control.js +640 -116
  4. package/dist/cjs/clusters/access-control.js.map +2 -2
  5. package/dist/cjs/clusters/actions.d.ts +10 -9
  6. package/dist/cjs/clusters/actions.d.ts.map +1 -1
  7. package/dist/cjs/clusters/actions.js +4 -4
  8. package/dist/cjs/clusters/actions.js.map +1 -1
  9. package/dist/cjs/clusters/administrator-commissioning.d.ts +156 -129
  10. package/dist/cjs/clusters/administrator-commissioning.d.ts.map +1 -1
  11. package/dist/cjs/clusters/administrator-commissioning.js +40 -35
  12. package/dist/cjs/clusters/administrator-commissioning.js.map +1 -1
  13. package/dist/cjs/clusters/alarm-base.d.ts +9 -12
  14. package/dist/cjs/clusters/alarm-base.d.ts.map +1 -1
  15. package/dist/cjs/clusters/alarm-base.js +3 -4
  16. package/dist/cjs/clusters/alarm-base.js.map +1 -1
  17. package/dist/cjs/clusters/application-launcher.d.ts +27 -15
  18. package/dist/cjs/clusters/application-launcher.d.ts.map +1 -1
  19. package/dist/cjs/clusters/application-launcher.js +7 -4
  20. package/dist/cjs/clusters/application-launcher.js.map +1 -1
  21. package/dist/cjs/clusters/ballast-configuration.d.ts +7 -7
  22. package/dist/cjs/clusters/ballast-configuration.js +7 -7
  23. package/dist/cjs/clusters/basic-information.d.ts +29 -21
  24. package/dist/cjs/clusters/basic-information.d.ts.map +1 -1
  25. package/dist/cjs/clusters/basic-information.js +29 -21
  26. package/dist/cjs/clusters/basic-information.js.map +1 -1
  27. package/dist/cjs/clusters/bridged-device-basic-information.d.ts +816 -34
  28. package/dist/cjs/clusters/bridged-device-basic-information.d.ts.map +1 -1
  29. package/dist/cjs/clusters/bridged-device-basic-information.js +182 -29
  30. package/dist/cjs/clusters/bridged-device-basic-information.js.map +2 -2
  31. package/dist/cjs/clusters/channel.d.ts +115 -124
  32. package/dist/cjs/clusters/channel.d.ts.map +1 -1
  33. package/dist/cjs/clusters/channel.js +15 -16
  34. package/dist/cjs/clusters/channel.js.map +1 -1
  35. package/dist/cjs/clusters/color-control.d.ts +3076 -1366
  36. package/dist/cjs/clusters/color-control.d.ts.map +1 -1
  37. package/dist/cjs/clusters/color-control.js +423 -357
  38. package/dist/cjs/clusters/color-control.js.map +2 -2
  39. package/dist/cjs/clusters/commissioner-control.d.ts +268 -0
  40. package/dist/cjs/clusters/commissioner-control.d.ts.map +1 -0
  41. package/dist/cjs/clusters/commissioner-control.js +194 -0
  42. package/dist/cjs/clusters/commissioner-control.js.map +6 -0
  43. package/dist/cjs/clusters/content-control.d.ts +497 -221
  44. package/dist/cjs/clusters/content-control.d.ts.map +1 -1
  45. package/dist/cjs/clusters/content-control.js +59 -41
  46. package/dist/cjs/clusters/content-control.js.map +2 -2
  47. package/dist/cjs/clusters/content-launcher.d.ts +248 -215
  48. package/dist/cjs/clusters/content-launcher.d.ts.map +1 -1
  49. package/dist/cjs/clusters/content-launcher.js +16 -15
  50. package/dist/cjs/clusters/content-launcher.js.map +1 -1
  51. package/dist/cjs/clusters/device-energy-management-mode.d.ts +76 -333
  52. package/dist/cjs/clusters/device-energy-management-mode.d.ts.map +1 -1
  53. package/dist/cjs/clusters/device-energy-management-mode.js +26 -73
  54. package/dist/cjs/clusters/device-energy-management-mode.js.map +1 -1
  55. package/dist/cjs/clusters/device-energy-management.d.ts +1299 -930
  56. package/dist/cjs/clusters/device-energy-management.d.ts.map +1 -1
  57. package/dist/cjs/clusters/device-energy-management.js +189 -160
  58. package/dist/cjs/clusters/device-energy-management.js.map +2 -2
  59. package/dist/cjs/clusters/dishwasher-alarm.d.ts +14 -17
  60. package/dist/cjs/clusters/dishwasher-alarm.d.ts.map +1 -1
  61. package/dist/cjs/clusters/dishwasher-alarm.js +3 -4
  62. package/dist/cjs/clusters/dishwasher-alarm.js.map +1 -1
  63. package/dist/cjs/clusters/dishwasher-mode.d.ts +65 -105
  64. package/dist/cjs/clusters/dishwasher-mode.d.ts.map +1 -1
  65. package/dist/cjs/clusters/dishwasher-mode.js +12 -24
  66. package/dist/cjs/clusters/dishwasher-mode.js.map +1 -1
  67. package/dist/cjs/clusters/door-lock.d.ts +2751 -5427
  68. package/dist/cjs/clusters/door-lock.d.ts.map +1 -1
  69. package/dist/cjs/clusters/door-lock.js +480 -802
  70. package/dist/cjs/clusters/door-lock.js.map +2 -2
  71. package/dist/cjs/clusters/ecosystem-information.d.ts +186 -0
  72. package/dist/cjs/clusters/ecosystem-information.d.ts.map +1 -0
  73. package/dist/cjs/clusters/ecosystem-information.js +154 -0
  74. package/dist/cjs/clusters/ecosystem-information.js.map +6 -0
  75. package/dist/cjs/clusters/electrical-energy-measurement.d.ts +363 -368
  76. package/dist/cjs/clusters/electrical-energy-measurement.d.ts.map +1 -1
  77. package/dist/cjs/clusters/electrical-energy-measurement.js +15 -16
  78. package/dist/cjs/clusters/electrical-energy-measurement.js.map +1 -1
  79. package/dist/cjs/clusters/energy-evse-mode.d.ts +92 -330
  80. package/dist/cjs/clusters/energy-evse-mode.d.ts.map +1 -1
  81. package/dist/cjs/clusters/energy-evse-mode.js +25 -72
  82. package/dist/cjs/clusters/energy-evse-mode.js.map +1 -1
  83. package/dist/cjs/clusters/energy-evse.d.ts +557 -273
  84. package/dist/cjs/clusters/energy-evse.d.ts.map +1 -1
  85. package/dist/cjs/clusters/energy-evse.js +107 -55
  86. package/dist/cjs/clusters/energy-evse.js.map +1 -1
  87. package/dist/cjs/clusters/energy-preference.d.ts +76 -76
  88. package/dist/cjs/clusters/energy-preference.d.ts.map +1 -1
  89. package/dist/cjs/clusters/energy-preference.js +15 -18
  90. package/dist/cjs/clusters/energy-preference.js.map +1 -1
  91. package/dist/cjs/clusters/ethernet-network-diagnostics.d.ts +3 -9
  92. package/dist/cjs/clusters/ethernet-network-diagnostics.d.ts.map +1 -1
  93. package/dist/cjs/clusters/ethernet-network-diagnostics.js +1 -3
  94. package/dist/cjs/clusters/ethernet-network-diagnostics.js.map +1 -1
  95. package/dist/cjs/clusters/fan-control.d.ts +12 -12
  96. package/dist/cjs/clusters/fan-control.js +4 -4
  97. package/dist/cjs/clusters/fixed-label.d.ts +7 -2
  98. package/dist/cjs/clusters/fixed-label.d.ts.map +1 -1
  99. package/dist/cjs/clusters/fixed-label.js.map +1 -1
  100. package/dist/cjs/clusters/flow-measurement.d.ts +4 -4
  101. package/dist/cjs/clusters/flow-measurement.d.ts.map +1 -1
  102. package/dist/cjs/clusters/flow-measurement.js +6 -6
  103. package/dist/cjs/clusters/flow-measurement.js.map +1 -1
  104. package/dist/cjs/clusters/general-commissioning.d.ts +1416 -111
  105. package/dist/cjs/clusters/general-commissioning.d.ts.map +1 -1
  106. package/dist/cjs/clusters/general-commissioning.js +272 -54
  107. package/dist/cjs/clusters/general-commissioning.js.map +2 -2
  108. package/dist/cjs/clusters/general-diagnostics.d.ts +115 -122
  109. package/dist/cjs/clusters/general-diagnostics.d.ts.map +1 -1
  110. package/dist/cjs/clusters/general-diagnostics.js +31 -33
  111. package/dist/cjs/clusters/general-diagnostics.js.map +1 -1
  112. package/dist/cjs/clusters/group-key-management.d.ts +72 -82
  113. package/dist/cjs/clusters/group-key-management.d.ts.map +1 -1
  114. package/dist/cjs/clusters/group-key-management.js +19 -22
  115. package/dist/cjs/clusters/group-key-management.js.map +1 -1
  116. package/dist/cjs/clusters/groups.d.ts +9 -6
  117. package/dist/cjs/clusters/groups.d.ts.map +1 -1
  118. package/dist/cjs/clusters/groups.js +3 -2
  119. package/dist/cjs/clusters/groups.js.map +1 -1
  120. package/dist/cjs/clusters/icd-management.d.ts +223 -66
  121. package/dist/cjs/clusters/icd-management.d.ts.map +1 -1
  122. package/dist/cjs/clusters/icd-management.js +61 -23
  123. package/dist/cjs/clusters/icd-management.js.map +2 -2
  124. package/dist/cjs/clusters/identify.d.ts +12 -13
  125. package/dist/cjs/clusters/identify.d.ts.map +1 -1
  126. package/dist/cjs/clusters/identify.js +9 -10
  127. package/dist/cjs/clusters/identify.js.map +1 -1
  128. package/dist/cjs/clusters/illuminance-measurement.d.ts +7 -8
  129. package/dist/cjs/clusters/illuminance-measurement.d.ts.map +1 -1
  130. package/dist/cjs/clusters/illuminance-measurement.js +9 -10
  131. package/dist/cjs/clusters/illuminance-measurement.js.map +1 -1
  132. package/dist/cjs/clusters/index.d.ts +11 -1
  133. package/dist/cjs/clusters/index.d.ts.map +1 -1
  134. package/dist/cjs/clusters/index.js +33 -3
  135. package/dist/cjs/clusters/index.js.map +1 -1
  136. package/dist/cjs/clusters/joint-fabric-datastore-cluster.d.ts +1239 -0
  137. package/dist/cjs/clusters/joint-fabric-datastore-cluster.d.ts.map +1 -0
  138. package/dist/cjs/clusters/joint-fabric-datastore-cluster.js +490 -0
  139. package/dist/cjs/clusters/joint-fabric-datastore-cluster.js.map +6 -0
  140. package/dist/cjs/clusters/joint-fabric-pki.d.ts +174 -0
  141. package/dist/cjs/clusters/joint-fabric-pki.d.ts.map +1 -0
  142. package/dist/cjs/clusters/joint-fabric-pki.js +120 -0
  143. package/dist/cjs/clusters/joint-fabric-pki.js.map +6 -0
  144. package/dist/cjs/clusters/keypad-input.d.ts +2 -2
  145. package/dist/cjs/clusters/laundry-dryer-controls.d.ts +6 -7
  146. package/dist/cjs/clusters/laundry-dryer-controls.d.ts.map +1 -1
  147. package/dist/cjs/clusters/laundry-dryer-controls.js +5 -9
  148. package/dist/cjs/clusters/laundry-dryer-controls.js.map +1 -1
  149. package/dist/cjs/clusters/laundry-washer-controls.d.ts +74 -62
  150. package/dist/cjs/clusters/laundry-washer-controls.d.ts.map +1 -1
  151. package/dist/cjs/clusters/laundry-washer-controls.js +26 -25
  152. package/dist/cjs/clusters/laundry-washer-controls.js.map +1 -1
  153. package/dist/cjs/clusters/laundry-washer-mode.d.ts +69 -109
  154. package/dist/cjs/clusters/laundry-washer-mode.d.ts.map +1 -1
  155. package/dist/cjs/clusters/laundry-washer-mode.js +13 -25
  156. package/dist/cjs/clusters/laundry-washer-mode.js.map +1 -1
  157. package/dist/cjs/clusters/level-control.d.ts +209 -70
  158. package/dist/cjs/clusters/level-control.d.ts.map +1 -1
  159. package/dist/cjs/clusters/level-control.js +45 -12
  160. package/dist/cjs/clusters/level-control.js.map +1 -1
  161. package/dist/cjs/clusters/localization-configuration.d.ts +5 -6
  162. package/dist/cjs/clusters/localization-configuration.d.ts.map +1 -1
  163. package/dist/cjs/clusters/localization-configuration.js +5 -6
  164. package/dist/cjs/clusters/localization-configuration.js.map +1 -1
  165. package/dist/cjs/clusters/media-input.d.ts +9 -6
  166. package/dist/cjs/clusters/media-input.d.ts.map +1 -1
  167. package/dist/cjs/clusters/media-input.js +3 -2
  168. package/dist/cjs/clusters/media-input.js.map +1 -1
  169. package/dist/cjs/clusters/media-playback.d.ts +29 -24
  170. package/dist/cjs/clusters/media-playback.d.ts.map +1 -1
  171. package/dist/cjs/clusters/media-playback.js +5 -4
  172. package/dist/cjs/clusters/media-playback.js.map +1 -1
  173. package/dist/cjs/clusters/microwave-oven-control.d.ts +54 -48
  174. package/dist/cjs/clusters/microwave-oven-control.d.ts.map +1 -1
  175. package/dist/cjs/clusters/microwave-oven-control.js +19 -17
  176. package/dist/cjs/clusters/microwave-oven-control.js.map +1 -1
  177. package/dist/cjs/clusters/microwave-oven-mode.d.ts +63 -69
  178. package/dist/cjs/clusters/microwave-oven-mode.d.ts.map +1 -1
  179. package/dist/cjs/clusters/microwave-oven-mode.js +14 -11
  180. package/dist/cjs/clusters/microwave-oven-mode.js.map +1 -1
  181. package/dist/cjs/clusters/mode-base.d.ts +27 -46
  182. package/dist/cjs/clusters/mode-base.d.ts.map +1 -1
  183. package/dist/cjs/clusters/mode-base.js +9 -10
  184. package/dist/cjs/clusters/mode-base.js.map +1 -1
  185. package/dist/cjs/clusters/mode-select.d.ts +33 -27
  186. package/dist/cjs/clusters/mode-select.d.ts.map +1 -1
  187. package/dist/cjs/clusters/mode-select.js +14 -13
  188. package/dist/cjs/clusters/mode-select.js.map +1 -1
  189. package/dist/cjs/clusters/network-commissioning.d.ts +263 -240
  190. package/dist/cjs/clusters/network-commissioning.d.ts.map +1 -1
  191. package/dist/cjs/clusters/network-commissioning.js +46 -39
  192. package/dist/cjs/clusters/network-commissioning.js.map +1 -1
  193. package/dist/cjs/clusters/occupancy-sensing.d.ts +1002 -63
  194. package/dist/cjs/clusters/occupancy-sensing.d.ts.map +1 -1
  195. package/dist/cjs/clusters/occupancy-sensing.js +278 -63
  196. package/dist/cjs/clusters/occupancy-sensing.js.map +2 -2
  197. package/dist/cjs/clusters/on-off.d.ts +18 -24
  198. package/dist/cjs/clusters/on-off.d.ts.map +1 -1
  199. package/dist/cjs/clusters/on-off.js +3 -4
  200. package/dist/cjs/clusters/on-off.js.map +1 -1
  201. package/dist/cjs/clusters/operational-credentials.d.ts +98 -85
  202. package/dist/cjs/clusters/operational-credentials.d.ts.map +1 -1
  203. package/dist/cjs/clusters/operational-credentials.js +56 -49
  204. package/dist/cjs/clusters/operational-credentials.js.map +1 -1
  205. package/dist/cjs/clusters/operational-state.d.ts +136 -57
  206. package/dist/cjs/clusters/operational-state.d.ts.map +1 -1
  207. package/dist/cjs/clusters/operational-state.js +62 -36
  208. package/dist/cjs/clusters/operational-state.js.map +2 -2
  209. package/dist/cjs/clusters/ota-software-update-provider.d.ts +43 -42
  210. package/dist/cjs/clusters/ota-software-update-provider.d.ts.map +1 -1
  211. package/dist/cjs/clusters/ota-software-update-provider.js +20 -19
  212. package/dist/cjs/clusters/ota-software-update-provider.js.map +1 -1
  213. package/dist/cjs/clusters/ota-software-update-requestor.d.ts +6 -10
  214. package/dist/cjs/clusters/ota-software-update-requestor.d.ts.map +1 -1
  215. package/dist/cjs/clusters/ota-software-update-requestor.js +4 -6
  216. package/dist/cjs/clusters/ota-software-update-requestor.js.map +1 -1
  217. package/dist/cjs/clusters/oven-cavity-operational-state.d.ts +44 -154
  218. package/dist/cjs/clusters/oven-cavity-operational-state.d.ts.map +1 -1
  219. package/dist/cjs/clusters/oven-cavity-operational-state.js +39 -156
  220. package/dist/cjs/clusters/oven-cavity-operational-state.js.map +1 -1
  221. package/dist/cjs/clusters/oven-mode.d.ts +79 -349
  222. package/dist/cjs/clusters/oven-mode.d.ts.map +1 -1
  223. package/dist/cjs/clusters/oven-mode.js +26 -82
  224. package/dist/cjs/clusters/oven-mode.js.map +1 -1
  225. package/dist/cjs/clusters/power-source.d.ts +169 -44
  226. package/dist/cjs/clusters/power-source.d.ts.map +1 -1
  227. package/dist/cjs/clusters/power-source.js +40 -16
  228. package/dist/cjs/clusters/power-source.js.map +1 -1
  229. package/dist/cjs/clusters/pressure-measurement.js +2 -2
  230. package/dist/cjs/clusters/pressure-measurement.js.map +1 -1
  231. package/dist/cjs/clusters/pump-configuration-and-control.d.ts +73 -63
  232. package/dist/cjs/clusters/pump-configuration-and-control.d.ts.map +1 -1
  233. package/dist/cjs/clusters/pump-configuration-and-control.js +19 -20
  234. package/dist/cjs/clusters/pump-configuration-and-control.js.map +1 -1
  235. package/dist/cjs/clusters/refrigerator-alarm.d.ts +2 -1
  236. package/dist/cjs/clusters/refrigerator-alarm.d.ts.map +1 -1
  237. package/dist/cjs/clusters/refrigerator-alarm.js.map +1 -1
  238. package/dist/cjs/clusters/refrigerator-and-temperature-controlled-cabinet-mode.d.ts +59 -91
  239. package/dist/cjs/clusters/refrigerator-and-temperature-controlled-cabinet-mode.d.ts.map +1 -1
  240. package/dist/cjs/clusters/refrigerator-and-temperature-controlled-cabinet-mode.js +11 -19
  241. package/dist/cjs/clusters/refrigerator-and-temperature-controlled-cabinet-mode.js.map +1 -1
  242. package/dist/cjs/clusters/relative-humidity-measurement.js +1 -1
  243. package/dist/cjs/clusters/relative-humidity-measurement.js.map +1 -1
  244. package/dist/cjs/clusters/rvc-clean-mode.d.ts +59 -103
  245. package/dist/cjs/clusters/rvc-clean-mode.d.ts.map +1 -1
  246. package/dist/cjs/clusters/rvc-clean-mode.js +11 -15
  247. package/dist/cjs/clusters/rvc-clean-mode.js.map +1 -1
  248. package/dist/cjs/clusters/rvc-operational-state.d.ts +81 -25
  249. package/dist/cjs/clusters/rvc-operational-state.d.ts.map +1 -1
  250. package/dist/cjs/clusters/rvc-operational-state.js +49 -20
  251. package/dist/cjs/clusters/rvc-operational-state.js.map +1 -1
  252. package/dist/cjs/clusters/rvc-run-mode.d.ts +85 -129
  253. package/dist/cjs/clusters/rvc-run-mode.d.ts.map +1 -1
  254. package/dist/cjs/clusters/rvc-run-mode.js +16 -15
  255. package/dist/cjs/clusters/rvc-run-mode.js.map +1 -1
  256. package/dist/cjs/clusters/scenes-management.d.ts +328 -181
  257. package/dist/cjs/clusters/scenes-management.d.ts.map +1 -1
  258. package/dist/cjs/clusters/scenes-management.js +37 -22
  259. package/dist/cjs/clusters/scenes-management.js.map +1 -1
  260. package/dist/cjs/clusters/service-area.d.ts +2052 -0
  261. package/dist/cjs/clusters/service-area.d.ts.map +1 -0
  262. package/dist/cjs/clusters/service-area.js +582 -0
  263. package/dist/cjs/clusters/service-area.js.map +6 -0
  264. package/dist/cjs/clusters/smoke-co-alarm.d.ts +10 -18
  265. package/dist/cjs/clusters/smoke-co-alarm.d.ts.map +1 -1
  266. package/dist/cjs/clusters/smoke-co-alarm.js +2 -3
  267. package/dist/cjs/clusters/smoke-co-alarm.js.map +1 -1
  268. package/dist/cjs/clusters/switch.d.ts +478 -191
  269. package/dist/cjs/clusters/switch.d.ts.map +1 -1
  270. package/dist/cjs/clusters/switch.js +145 -57
  271. package/dist/cjs/clusters/switch.js.map +1 -1
  272. package/dist/cjs/clusters/target-navigator.d.ts +1 -1
  273. package/dist/cjs/clusters/target-navigator.js +1 -1
  274. package/dist/cjs/clusters/thermostat.d.ts +3877 -830
  275. package/dist/cjs/clusters/thermostat.d.ts.map +1 -1
  276. package/dist/cjs/clusters/thermostat.js +841 -159
  277. package/dist/cjs/clusters/thermostat.js.map +2 -2
  278. package/dist/cjs/clusters/thread-border-router-management.d.ts +711 -0
  279. package/dist/cjs/clusters/thread-border-router-management.d.ts.map +1 -0
  280. package/dist/cjs/clusters/thread-border-router-management.js +265 -0
  281. package/dist/cjs/clusters/thread-border-router-management.js.map +6 -0
  282. package/dist/cjs/clusters/thread-network-diagnostics.d.ts +81 -55
  283. package/dist/cjs/clusters/thread-network-diagnostics.d.ts.map +1 -1
  284. package/dist/cjs/clusters/thread-network-diagnostics.js +32 -21
  285. package/dist/cjs/clusters/thread-network-diagnostics.js.map +1 -1
  286. package/dist/cjs/clusters/thread-network-directory.d.ts +250 -0
  287. package/dist/cjs/clusters/thread-network-directory.d.ts.map +1 -0
  288. package/dist/cjs/clusters/thread-network-directory.js +187 -0
  289. package/dist/cjs/clusters/thread-network-directory.js.map +6 -0
  290. package/dist/cjs/clusters/time-synchronization.d.ts +101 -76
  291. package/dist/cjs/clusters/time-synchronization.d.ts.map +1 -1
  292. package/dist/cjs/clusters/time-synchronization.js +30 -23
  293. package/dist/cjs/clusters/time-synchronization.js.map +1 -1
  294. package/dist/cjs/clusters/unit-localization.d.ts +3 -4
  295. package/dist/cjs/clusters/unit-localization.d.ts.map +1 -1
  296. package/dist/cjs/clusters/unit-localization.js.map +1 -1
  297. package/dist/cjs/clusters/user-label.d.ts +2 -1
  298. package/dist/cjs/clusters/user-label.d.ts.map +1 -1
  299. package/dist/cjs/clusters/user-label.js.map +1 -1
  300. package/dist/cjs/clusters/water-heater-management.d.ts +1371 -0
  301. package/dist/cjs/clusters/water-heater-management.d.ts.map +1 -0
  302. package/dist/cjs/clusters/water-heater-management.js +336 -0
  303. package/dist/cjs/clusters/water-heater-management.js.map +6 -0
  304. package/dist/cjs/clusters/water-heater-mode.d.ts +491 -0
  305. package/dist/cjs/clusters/water-heater-mode.d.ts.map +1 -0
  306. package/dist/cjs/clusters/water-heater-mode.js +195 -0
  307. package/dist/cjs/clusters/water-heater-mode.js.map +6 -0
  308. package/dist/cjs/clusters/water-tank-level-monitoring.d.ts +162 -0
  309. package/dist/cjs/clusters/water-tank-level-monitoring.d.ts.map +1 -0
  310. package/dist/cjs/clusters/water-tank-level-monitoring.js +47 -0
  311. package/dist/cjs/clusters/water-tank-level-monitoring.js.map +6 -0
  312. package/dist/cjs/clusters/wi-fi-network-diagnostics.d.ts +20 -27
  313. package/dist/cjs/clusters/wi-fi-network-diagnostics.d.ts.map +1 -1
  314. package/dist/cjs/clusters/wi-fi-network-diagnostics.js +6 -8
  315. package/dist/cjs/clusters/wi-fi-network-diagnostics.js.map +1 -1
  316. package/dist/cjs/clusters/wi-fi-network-management.d.ts +91 -0
  317. package/dist/cjs/clusters/wi-fi-network-management.d.ts.map +1 -0
  318. package/dist/cjs/clusters/wi-fi-network-management.js +122 -0
  319. package/dist/cjs/clusters/wi-fi-network-management.js.map +6 -0
  320. package/dist/cjs/clusters/window-covering.d.ts +66 -78
  321. package/dist/cjs/clusters/window-covering.d.ts.map +1 -1
  322. package/dist/cjs/clusters/window-covering.js +26 -37
  323. package/dist/cjs/clusters/window-covering.js.map +1 -1
  324. package/dist/cjs/globals/AtomicAttributeStatus.d.ts +34 -0
  325. package/dist/cjs/globals/AtomicAttributeStatus.d.ts.map +1 -0
  326. package/dist/cjs/globals/AtomicAttributeStatus.js +46 -0
  327. package/dist/cjs/globals/AtomicAttributeStatus.js.map +6 -0
  328. package/dist/cjs/globals/AtomicRequestType.d.ts +24 -0
  329. package/dist/cjs/globals/AtomicRequestType.d.ts.map +1 -0
  330. package/dist/cjs/globals/AtomicRequestType.js +35 -0
  331. package/dist/cjs/globals/AtomicRequestType.js.map +6 -0
  332. package/dist/cjs/globals/Locationdesc.d.ts +79 -0
  333. package/dist/cjs/globals/Locationdesc.d.ts.map +1 -0
  334. package/dist/cjs/globals/Locationdesc.js +89 -0
  335. package/dist/cjs/globals/Locationdesc.js.map +6 -0
  336. package/dist/cjs/globals/Priority.d.ts +1 -1
  337. package/dist/cjs/globals/Semtag.d.ts +6 -6
  338. package/dist/cjs/globals/Semtag.js +4 -4
  339. package/dist/cjs/globals/SoftwareVersionCertificationStatus.d.ts +1 -1
  340. package/dist/cjs/globals/Status.d.ts +18 -3
  341. package/dist/cjs/globals/Status.d.ts.map +1 -1
  342. package/dist/cjs/globals/Status.js +3 -1
  343. package/dist/cjs/globals/Status.js.map +1 -1
  344. package/dist/cjs/globals/Tod.d.ts +2 -2
  345. package/dist/cjs/globals/index.d.ts +3 -0
  346. package/dist/cjs/globals/index.d.ts.map +1 -1
  347. package/dist/cjs/globals/index.js +3 -0
  348. package/dist/cjs/globals/index.js.map +1 -1
  349. package/dist/cjs/schema/QrCodeSchema.d.ts.map +1 -1
  350. package/dist/cjs/schema/QrCodeSchema.js +4 -1
  351. package/dist/cjs/schema/QrCodeSchema.js.map +1 -1
  352. package/dist/esm/clusters/access-control.d.ts +3972 -522
  353. package/dist/esm/clusters/access-control.d.ts.map +1 -1
  354. package/dist/esm/clusters/access-control.js +645 -120
  355. package/dist/esm/clusters/access-control.js.map +2 -2
  356. package/dist/esm/clusters/actions.d.ts +10 -9
  357. package/dist/esm/clusters/actions.d.ts.map +1 -1
  358. package/dist/esm/clusters/actions.js +4 -4
  359. package/dist/esm/clusters/actions.js.map +1 -1
  360. package/dist/esm/clusters/administrator-commissioning.d.ts +156 -129
  361. package/dist/esm/clusters/administrator-commissioning.d.ts.map +1 -1
  362. package/dist/esm/clusters/administrator-commissioning.js +40 -35
  363. package/dist/esm/clusters/administrator-commissioning.js.map +1 -1
  364. package/dist/esm/clusters/alarm-base.d.ts +9 -12
  365. package/dist/esm/clusters/alarm-base.d.ts.map +1 -1
  366. package/dist/esm/clusters/alarm-base.js +3 -4
  367. package/dist/esm/clusters/alarm-base.js.map +1 -1
  368. package/dist/esm/clusters/application-launcher.d.ts +27 -15
  369. package/dist/esm/clusters/application-launcher.d.ts.map +1 -1
  370. package/dist/esm/clusters/application-launcher.js +7 -4
  371. package/dist/esm/clusters/application-launcher.js.map +1 -1
  372. package/dist/esm/clusters/ballast-configuration.d.ts +7 -7
  373. package/dist/esm/clusters/ballast-configuration.js +7 -7
  374. package/dist/esm/clusters/basic-information.d.ts +29 -21
  375. package/dist/esm/clusters/basic-information.d.ts.map +1 -1
  376. package/dist/esm/clusters/basic-information.js +29 -21
  377. package/dist/esm/clusters/basic-information.js.map +1 -1
  378. package/dist/esm/clusters/bridged-device-basic-information.d.ts +816 -34
  379. package/dist/esm/clusters/bridged-device-basic-information.d.ts.map +1 -1
  380. package/dist/esm/clusters/bridged-device-basic-information.js +188 -32
  381. package/dist/esm/clusters/bridged-device-basic-information.js.map +2 -2
  382. package/dist/esm/clusters/channel.d.ts +115 -124
  383. package/dist/esm/clusters/channel.d.ts.map +1 -1
  384. package/dist/esm/clusters/channel.js +15 -16
  385. package/dist/esm/clusters/channel.js.map +1 -1
  386. package/dist/esm/clusters/color-control.d.ts +3076 -1366
  387. package/dist/esm/clusters/color-control.d.ts.map +1 -1
  388. package/dist/esm/clusters/color-control.js +424 -358
  389. package/dist/esm/clusters/color-control.js.map +2 -2
  390. package/dist/esm/clusters/commissioner-control.d.ts +268 -0
  391. package/dist/esm/clusters/commissioner-control.d.ts.map +1 -0
  392. package/dist/esm/clusters/commissioner-control.js +174 -0
  393. package/dist/esm/clusters/commissioner-control.js.map +6 -0
  394. package/dist/esm/clusters/content-control.d.ts +497 -221
  395. package/dist/esm/clusters/content-control.d.ts.map +1 -1
  396. package/dist/esm/clusters/content-control.js +60 -42
  397. package/dist/esm/clusters/content-control.js.map +2 -2
  398. package/dist/esm/clusters/content-launcher.d.ts +248 -215
  399. package/dist/esm/clusters/content-launcher.d.ts.map +1 -1
  400. package/dist/esm/clusters/content-launcher.js +16 -15
  401. package/dist/esm/clusters/content-launcher.js.map +1 -1
  402. package/dist/esm/clusters/device-energy-management-mode.d.ts +76 -333
  403. package/dist/esm/clusters/device-energy-management-mode.d.ts.map +1 -1
  404. package/dist/esm/clusters/device-energy-management-mode.js +26 -80
  405. package/dist/esm/clusters/device-energy-management-mode.js.map +1 -1
  406. package/dist/esm/clusters/device-energy-management.d.ts +1299 -930
  407. package/dist/esm/clusters/device-energy-management.d.ts.map +1 -1
  408. package/dist/esm/clusters/device-energy-management.js +189 -160
  409. package/dist/esm/clusters/device-energy-management.js.map +2 -2
  410. package/dist/esm/clusters/dishwasher-alarm.d.ts +14 -17
  411. package/dist/esm/clusters/dishwasher-alarm.d.ts.map +1 -1
  412. package/dist/esm/clusters/dishwasher-alarm.js +3 -4
  413. package/dist/esm/clusters/dishwasher-alarm.js.map +1 -1
  414. package/dist/esm/clusters/dishwasher-mode.d.ts +65 -105
  415. package/dist/esm/clusters/dishwasher-mode.d.ts.map +1 -1
  416. package/dist/esm/clusters/dishwasher-mode.js +13 -25
  417. package/dist/esm/clusters/dishwasher-mode.js.map +1 -1
  418. package/dist/esm/clusters/door-lock.d.ts +2751 -5427
  419. package/dist/esm/clusters/door-lock.d.ts.map +1 -1
  420. package/dist/esm/clusters/door-lock.js +482 -804
  421. package/dist/esm/clusters/door-lock.js.map +2 -2
  422. package/dist/esm/clusters/ecosystem-information.d.ts +186 -0
  423. package/dist/esm/clusters/ecosystem-information.d.ts.map +1 -0
  424. package/dist/esm/clusters/ecosystem-information.js +134 -0
  425. package/dist/esm/clusters/ecosystem-information.js.map +6 -0
  426. package/dist/esm/clusters/electrical-energy-measurement.d.ts +363 -368
  427. package/dist/esm/clusters/electrical-energy-measurement.d.ts.map +1 -1
  428. package/dist/esm/clusters/electrical-energy-measurement.js +15 -16
  429. package/dist/esm/clusters/electrical-energy-measurement.js.map +1 -1
  430. package/dist/esm/clusters/energy-evse-mode.d.ts +92 -330
  431. package/dist/esm/clusters/energy-evse-mode.d.ts.map +1 -1
  432. package/dist/esm/clusters/energy-evse-mode.js +25 -79
  433. package/dist/esm/clusters/energy-evse-mode.js.map +1 -1
  434. package/dist/esm/clusters/energy-evse.d.ts +557 -273
  435. package/dist/esm/clusters/energy-evse.d.ts.map +1 -1
  436. package/dist/esm/clusters/energy-evse.js +107 -55
  437. package/dist/esm/clusters/energy-evse.js.map +1 -1
  438. package/dist/esm/clusters/energy-preference.d.ts +76 -76
  439. package/dist/esm/clusters/energy-preference.d.ts.map +1 -1
  440. package/dist/esm/clusters/energy-preference.js +15 -18
  441. package/dist/esm/clusters/energy-preference.js.map +1 -1
  442. package/dist/esm/clusters/ethernet-network-diagnostics.d.ts +3 -9
  443. package/dist/esm/clusters/ethernet-network-diagnostics.d.ts.map +1 -1
  444. package/dist/esm/clusters/ethernet-network-diagnostics.js +1 -3
  445. package/dist/esm/clusters/ethernet-network-diagnostics.js.map +1 -1
  446. package/dist/esm/clusters/fan-control.d.ts +12 -12
  447. package/dist/esm/clusters/fan-control.js +4 -4
  448. package/dist/esm/clusters/fixed-label.d.ts +7 -2
  449. package/dist/esm/clusters/fixed-label.d.ts.map +1 -1
  450. package/dist/esm/clusters/fixed-label.js.map +1 -1
  451. package/dist/esm/clusters/flow-measurement.d.ts +4 -4
  452. package/dist/esm/clusters/flow-measurement.d.ts.map +1 -1
  453. package/dist/esm/clusters/flow-measurement.js +6 -6
  454. package/dist/esm/clusters/flow-measurement.js.map +1 -1
  455. package/dist/esm/clusters/general-commissioning.d.ts +1416 -111
  456. package/dist/esm/clusters/general-commissioning.d.ts.map +1 -1
  457. package/dist/esm/clusters/general-commissioning.js +274 -56
  458. package/dist/esm/clusters/general-commissioning.js.map +2 -2
  459. package/dist/esm/clusters/general-diagnostics.d.ts +115 -122
  460. package/dist/esm/clusters/general-diagnostics.d.ts.map +1 -1
  461. package/dist/esm/clusters/general-diagnostics.js +31 -33
  462. package/dist/esm/clusters/general-diagnostics.js.map +1 -1
  463. package/dist/esm/clusters/group-key-management.d.ts +72 -82
  464. package/dist/esm/clusters/group-key-management.d.ts.map +1 -1
  465. package/dist/esm/clusters/group-key-management.js +19 -22
  466. package/dist/esm/clusters/group-key-management.js.map +1 -1
  467. package/dist/esm/clusters/groups.d.ts +9 -6
  468. package/dist/esm/clusters/groups.d.ts.map +1 -1
  469. package/dist/esm/clusters/groups.js +3 -2
  470. package/dist/esm/clusters/groups.js.map +1 -1
  471. package/dist/esm/clusters/icd-management.d.ts +223 -66
  472. package/dist/esm/clusters/icd-management.d.ts.map +1 -1
  473. package/dist/esm/clusters/icd-management.js +61 -23
  474. package/dist/esm/clusters/icd-management.js.map +2 -2
  475. package/dist/esm/clusters/identify.d.ts +12 -13
  476. package/dist/esm/clusters/identify.d.ts.map +1 -1
  477. package/dist/esm/clusters/identify.js +9 -10
  478. package/dist/esm/clusters/identify.js.map +1 -1
  479. package/dist/esm/clusters/illuminance-measurement.d.ts +7 -8
  480. package/dist/esm/clusters/illuminance-measurement.d.ts.map +1 -1
  481. package/dist/esm/clusters/illuminance-measurement.js +9 -10
  482. package/dist/esm/clusters/illuminance-measurement.js.map +1 -1
  483. package/dist/esm/clusters/index.d.ts +11 -1
  484. package/dist/esm/clusters/index.d.ts.map +1 -1
  485. package/dist/esm/clusters/index.js +36 -3
  486. package/dist/esm/clusters/index.js.map +1 -1
  487. package/dist/esm/clusters/joint-fabric-datastore-cluster.d.ts +1239 -0
  488. package/dist/esm/clusters/joint-fabric-datastore-cluster.d.ts.map +1 -0
  489. package/dist/esm/clusters/joint-fabric-datastore-cluster.js +470 -0
  490. package/dist/esm/clusters/joint-fabric-datastore-cluster.js.map +6 -0
  491. package/dist/esm/clusters/joint-fabric-pki.d.ts +174 -0
  492. package/dist/esm/clusters/joint-fabric-pki.d.ts.map +1 -0
  493. package/dist/esm/clusters/joint-fabric-pki.js +100 -0
  494. package/dist/esm/clusters/joint-fabric-pki.js.map +6 -0
  495. package/dist/esm/clusters/keypad-input.d.ts +2 -2
  496. package/dist/esm/clusters/laundry-dryer-controls.d.ts +6 -7
  497. package/dist/esm/clusters/laundry-dryer-controls.d.ts.map +1 -1
  498. package/dist/esm/clusters/laundry-dryer-controls.js +6 -10
  499. package/dist/esm/clusters/laundry-dryer-controls.js.map +1 -1
  500. package/dist/esm/clusters/laundry-washer-controls.d.ts +74 -62
  501. package/dist/esm/clusters/laundry-washer-controls.d.ts.map +1 -1
  502. package/dist/esm/clusters/laundry-washer-controls.js +26 -25
  503. package/dist/esm/clusters/laundry-washer-controls.js.map +1 -1
  504. package/dist/esm/clusters/laundry-washer-mode.d.ts +69 -109
  505. package/dist/esm/clusters/laundry-washer-mode.d.ts.map +1 -1
  506. package/dist/esm/clusters/laundry-washer-mode.js +14 -26
  507. package/dist/esm/clusters/laundry-washer-mode.js.map +1 -1
  508. package/dist/esm/clusters/level-control.d.ts +209 -70
  509. package/dist/esm/clusters/level-control.d.ts.map +1 -1
  510. package/dist/esm/clusters/level-control.js +45 -12
  511. package/dist/esm/clusters/level-control.js.map +1 -1
  512. package/dist/esm/clusters/localization-configuration.d.ts +5 -6
  513. package/dist/esm/clusters/localization-configuration.d.ts.map +1 -1
  514. package/dist/esm/clusters/localization-configuration.js +5 -6
  515. package/dist/esm/clusters/localization-configuration.js.map +1 -1
  516. package/dist/esm/clusters/media-input.d.ts +9 -6
  517. package/dist/esm/clusters/media-input.d.ts.map +1 -1
  518. package/dist/esm/clusters/media-input.js +3 -2
  519. package/dist/esm/clusters/media-input.js.map +1 -1
  520. package/dist/esm/clusters/media-playback.d.ts +29 -24
  521. package/dist/esm/clusters/media-playback.d.ts.map +1 -1
  522. package/dist/esm/clusters/media-playback.js +5 -4
  523. package/dist/esm/clusters/media-playback.js.map +1 -1
  524. package/dist/esm/clusters/microwave-oven-control.d.ts +54 -48
  525. package/dist/esm/clusters/microwave-oven-control.d.ts.map +1 -1
  526. package/dist/esm/clusters/microwave-oven-control.js +19 -17
  527. package/dist/esm/clusters/microwave-oven-control.js.map +1 -1
  528. package/dist/esm/clusters/microwave-oven-mode.d.ts +63 -69
  529. package/dist/esm/clusters/microwave-oven-mode.d.ts.map +1 -1
  530. package/dist/esm/clusters/microwave-oven-mode.js +14 -11
  531. package/dist/esm/clusters/microwave-oven-mode.js.map +1 -1
  532. package/dist/esm/clusters/mode-base.d.ts +27 -46
  533. package/dist/esm/clusters/mode-base.d.ts.map +1 -1
  534. package/dist/esm/clusters/mode-base.js +9 -10
  535. package/dist/esm/clusters/mode-base.js.map +1 -1
  536. package/dist/esm/clusters/mode-select.d.ts +33 -27
  537. package/dist/esm/clusters/mode-select.d.ts.map +1 -1
  538. package/dist/esm/clusters/mode-select.js +14 -13
  539. package/dist/esm/clusters/mode-select.js.map +1 -1
  540. package/dist/esm/clusters/network-commissioning.d.ts +263 -240
  541. package/dist/esm/clusters/network-commissioning.d.ts.map +1 -1
  542. package/dist/esm/clusters/network-commissioning.js +46 -39
  543. package/dist/esm/clusters/network-commissioning.js.map +1 -1
  544. package/dist/esm/clusters/occupancy-sensing.d.ts +1002 -63
  545. package/dist/esm/clusters/occupancy-sensing.d.ts.map +1 -1
  546. package/dist/esm/clusters/occupancy-sensing.js +287 -65
  547. package/dist/esm/clusters/occupancy-sensing.js.map +2 -2
  548. package/dist/esm/clusters/on-off.d.ts +18 -24
  549. package/dist/esm/clusters/on-off.d.ts.map +1 -1
  550. package/dist/esm/clusters/on-off.js +3 -4
  551. package/dist/esm/clusters/on-off.js.map +1 -1
  552. package/dist/esm/clusters/operational-credentials.d.ts +98 -85
  553. package/dist/esm/clusters/operational-credentials.d.ts.map +1 -1
  554. package/dist/esm/clusters/operational-credentials.js +56 -49
  555. package/dist/esm/clusters/operational-credentials.js.map +1 -1
  556. package/dist/esm/clusters/operational-state.d.ts +136 -57
  557. package/dist/esm/clusters/operational-state.d.ts.map +1 -1
  558. package/dist/esm/clusters/operational-state.js +63 -37
  559. package/dist/esm/clusters/operational-state.js.map +2 -2
  560. package/dist/esm/clusters/ota-software-update-provider.d.ts +43 -42
  561. package/dist/esm/clusters/ota-software-update-provider.d.ts.map +1 -1
  562. package/dist/esm/clusters/ota-software-update-provider.js +20 -19
  563. package/dist/esm/clusters/ota-software-update-provider.js.map +1 -1
  564. package/dist/esm/clusters/ota-software-update-requestor.d.ts +6 -10
  565. package/dist/esm/clusters/ota-software-update-requestor.d.ts.map +1 -1
  566. package/dist/esm/clusters/ota-software-update-requestor.js +4 -6
  567. package/dist/esm/clusters/ota-software-update-requestor.js.map +1 -1
  568. package/dist/esm/clusters/oven-cavity-operational-state.d.ts +44 -154
  569. package/dist/esm/clusters/oven-cavity-operational-state.d.ts.map +1 -1
  570. package/dist/esm/clusters/oven-cavity-operational-state.js +41 -166
  571. package/dist/esm/clusters/oven-cavity-operational-state.js.map +1 -1
  572. package/dist/esm/clusters/oven-mode.d.ts +79 -349
  573. package/dist/esm/clusters/oven-mode.d.ts.map +1 -1
  574. package/dist/esm/clusters/oven-mode.js +26 -89
  575. package/dist/esm/clusters/oven-mode.js.map +1 -1
  576. package/dist/esm/clusters/power-source.d.ts +169 -44
  577. package/dist/esm/clusters/power-source.d.ts.map +1 -1
  578. package/dist/esm/clusters/power-source.js +40 -16
  579. package/dist/esm/clusters/power-source.js.map +1 -1
  580. package/dist/esm/clusters/pressure-measurement.js +2 -2
  581. package/dist/esm/clusters/pressure-measurement.js.map +1 -1
  582. package/dist/esm/clusters/pump-configuration-and-control.d.ts +73 -63
  583. package/dist/esm/clusters/pump-configuration-and-control.d.ts.map +1 -1
  584. package/dist/esm/clusters/pump-configuration-and-control.js +19 -20
  585. package/dist/esm/clusters/pump-configuration-and-control.js.map +1 -1
  586. package/dist/esm/clusters/refrigerator-alarm.d.ts +2 -1
  587. package/dist/esm/clusters/refrigerator-alarm.d.ts.map +1 -1
  588. package/dist/esm/clusters/refrigerator-alarm.js.map +1 -1
  589. package/dist/esm/clusters/refrigerator-and-temperature-controlled-cabinet-mode.d.ts +59 -91
  590. package/dist/esm/clusters/refrigerator-and-temperature-controlled-cabinet-mode.d.ts.map +1 -1
  591. package/dist/esm/clusters/refrigerator-and-temperature-controlled-cabinet-mode.js +12 -20
  592. package/dist/esm/clusters/refrigerator-and-temperature-controlled-cabinet-mode.js.map +1 -1
  593. package/dist/esm/clusters/relative-humidity-measurement.js +1 -1
  594. package/dist/esm/clusters/relative-humidity-measurement.js.map +1 -1
  595. package/dist/esm/clusters/rvc-clean-mode.d.ts +59 -103
  596. package/dist/esm/clusters/rvc-clean-mode.d.ts.map +1 -1
  597. package/dist/esm/clusters/rvc-clean-mode.js +11 -15
  598. package/dist/esm/clusters/rvc-clean-mode.js.map +1 -1
  599. package/dist/esm/clusters/rvc-operational-state.d.ts +81 -25
  600. package/dist/esm/clusters/rvc-operational-state.d.ts.map +1 -1
  601. package/dist/esm/clusters/rvc-operational-state.js +49 -20
  602. package/dist/esm/clusters/rvc-operational-state.js.map +1 -1
  603. package/dist/esm/clusters/rvc-run-mode.d.ts +85 -129
  604. package/dist/esm/clusters/rvc-run-mode.d.ts.map +1 -1
  605. package/dist/esm/clusters/rvc-run-mode.js +16 -15
  606. package/dist/esm/clusters/rvc-run-mode.js.map +1 -1
  607. package/dist/esm/clusters/scenes-management.d.ts +328 -181
  608. package/dist/esm/clusters/scenes-management.d.ts.map +1 -1
  609. package/dist/esm/clusters/scenes-management.js +37 -22
  610. package/dist/esm/clusters/scenes-management.js.map +1 -1
  611. package/dist/esm/clusters/service-area.d.ts +2052 -0
  612. package/dist/esm/clusters/service-area.d.ts.map +1 -0
  613. package/dist/esm/clusters/service-area.js +562 -0
  614. package/dist/esm/clusters/service-area.js.map +6 -0
  615. package/dist/esm/clusters/smoke-co-alarm.d.ts +10 -18
  616. package/dist/esm/clusters/smoke-co-alarm.d.ts.map +1 -1
  617. package/dist/esm/clusters/smoke-co-alarm.js +2 -3
  618. package/dist/esm/clusters/smoke-co-alarm.js.map +1 -1
  619. package/dist/esm/clusters/switch.d.ts +478 -191
  620. package/dist/esm/clusters/switch.d.ts.map +1 -1
  621. package/dist/esm/clusters/switch.js +145 -57
  622. package/dist/esm/clusters/switch.js.map +1 -1
  623. package/dist/esm/clusters/target-navigator.d.ts +1 -1
  624. package/dist/esm/clusters/target-navigator.js +1 -1
  625. package/dist/esm/clusters/thermostat.d.ts +3877 -830
  626. package/dist/esm/clusters/thermostat.d.ts.map +1 -1
  627. package/dist/esm/clusters/thermostat.js +842 -160
  628. package/dist/esm/clusters/thermostat.js.map +2 -2
  629. package/dist/esm/clusters/thread-border-router-management.d.ts +711 -0
  630. package/dist/esm/clusters/thread-border-router-management.d.ts.map +1 -0
  631. package/dist/esm/clusters/thread-border-router-management.js +245 -0
  632. package/dist/esm/clusters/thread-border-router-management.js.map +6 -0
  633. package/dist/esm/clusters/thread-network-diagnostics.d.ts +81 -55
  634. package/dist/esm/clusters/thread-network-diagnostics.d.ts.map +1 -1
  635. package/dist/esm/clusters/thread-network-diagnostics.js +32 -21
  636. package/dist/esm/clusters/thread-network-diagnostics.js.map +1 -1
  637. package/dist/esm/clusters/thread-network-directory.d.ts +250 -0
  638. package/dist/esm/clusters/thread-network-directory.d.ts.map +1 -0
  639. package/dist/esm/clusters/thread-network-directory.js +167 -0
  640. package/dist/esm/clusters/thread-network-directory.js.map +6 -0
  641. package/dist/esm/clusters/time-synchronization.d.ts +101 -76
  642. package/dist/esm/clusters/time-synchronization.d.ts.map +1 -1
  643. package/dist/esm/clusters/time-synchronization.js +30 -23
  644. package/dist/esm/clusters/time-synchronization.js.map +1 -1
  645. package/dist/esm/clusters/unit-localization.d.ts +3 -4
  646. package/dist/esm/clusters/unit-localization.d.ts.map +1 -1
  647. package/dist/esm/clusters/unit-localization.js.map +1 -1
  648. package/dist/esm/clusters/user-label.d.ts +2 -1
  649. package/dist/esm/clusters/user-label.d.ts.map +1 -1
  650. package/dist/esm/clusters/user-label.js.map +1 -1
  651. package/dist/esm/clusters/water-heater-management.d.ts +1371 -0
  652. package/dist/esm/clusters/water-heater-management.d.ts.map +1 -0
  653. package/dist/esm/clusters/water-heater-management.js +325 -0
  654. package/dist/esm/clusters/water-heater-management.js.map +6 -0
  655. package/dist/esm/clusters/water-heater-mode.d.ts +491 -0
  656. package/dist/esm/clusters/water-heater-mode.d.ts.map +1 -0
  657. package/dist/esm/clusters/water-heater-mode.js +175 -0
  658. package/dist/esm/clusters/water-heater-mode.js.map +6 -0
  659. package/dist/esm/clusters/water-tank-level-monitoring.d.ts +162 -0
  660. package/dist/esm/clusters/water-tank-level-monitoring.d.ts.map +1 -0
  661. package/dist/esm/clusters/water-tank-level-monitoring.js +27 -0
  662. package/dist/esm/clusters/water-tank-level-monitoring.js.map +6 -0
  663. package/dist/esm/clusters/wi-fi-network-diagnostics.d.ts +20 -27
  664. package/dist/esm/clusters/wi-fi-network-diagnostics.d.ts.map +1 -1
  665. package/dist/esm/clusters/wi-fi-network-diagnostics.js +6 -8
  666. package/dist/esm/clusters/wi-fi-network-diagnostics.js.map +1 -1
  667. package/dist/esm/clusters/wi-fi-network-management.d.ts +91 -0
  668. package/dist/esm/clusters/wi-fi-network-management.d.ts.map +1 -0
  669. package/dist/esm/clusters/wi-fi-network-management.js +102 -0
  670. package/dist/esm/clusters/wi-fi-network-management.js.map +6 -0
  671. package/dist/esm/clusters/window-covering.d.ts +66 -78
  672. package/dist/esm/clusters/window-covering.d.ts.map +1 -1
  673. package/dist/esm/clusters/window-covering.js +26 -37
  674. package/dist/esm/clusters/window-covering.js.map +1 -1
  675. package/dist/esm/globals/AtomicAttributeStatus.d.ts +34 -0
  676. package/dist/esm/globals/AtomicAttributeStatus.d.ts.map +1 -0
  677. package/dist/esm/globals/AtomicAttributeStatus.js +26 -0
  678. package/dist/esm/globals/AtomicAttributeStatus.js.map +6 -0
  679. package/dist/esm/globals/AtomicRequestType.d.ts +24 -0
  680. package/dist/esm/globals/AtomicRequestType.d.ts.map +1 -0
  681. package/dist/esm/globals/AtomicRequestType.js +15 -0
  682. package/dist/esm/globals/AtomicRequestType.js.map +6 -0
  683. package/dist/esm/globals/Locationdesc.d.ts +79 -0
  684. package/dist/esm/globals/Locationdesc.d.ts.map +1 -0
  685. package/dist/esm/globals/Locationdesc.js +69 -0
  686. package/dist/esm/globals/Locationdesc.js.map +6 -0
  687. package/dist/esm/globals/Priority.d.ts +1 -1
  688. package/dist/esm/globals/Semtag.d.ts +6 -6
  689. package/dist/esm/globals/Semtag.js +4 -4
  690. package/dist/esm/globals/SoftwareVersionCertificationStatus.d.ts +1 -1
  691. package/dist/esm/globals/Status.d.ts +18 -3
  692. package/dist/esm/globals/Status.d.ts.map +1 -1
  693. package/dist/esm/globals/Status.js +3 -1
  694. package/dist/esm/globals/Status.js.map +1 -1
  695. package/dist/esm/globals/Tod.d.ts +2 -2
  696. package/dist/esm/globals/index.d.ts +3 -0
  697. package/dist/esm/globals/index.d.ts.map +1 -1
  698. package/dist/esm/globals/index.js +3 -0
  699. package/dist/esm/globals/index.js.map +1 -1
  700. package/dist/esm/schema/QrCodeSchema.d.ts.map +1 -1
  701. package/dist/esm/schema/QrCodeSchema.js +4 -1
  702. package/dist/esm/schema/QrCodeSchema.js.map +1 -1
  703. package/package.json +5 -5
  704. package/src/clusters/access-control.ts +926 -171
  705. package/src/clusters/actions.ts +12 -11
  706. package/src/clusters/administrator-commissioning.ts +54 -35
  707. package/src/clusters/alarm-base.ts +3 -4
  708. package/src/clusters/application-launcher.ts +22 -7
  709. package/src/clusters/ballast-configuration.ts +7 -7
  710. package/src/clusters/basic-information.ts +29 -21
  711. package/src/clusters/bridged-device-basic-information.ts +264 -41
  712. package/src/clusters/channel.ts +20 -17
  713. package/src/clusters/color-control.ts +589 -426
  714. package/src/clusters/commissioner-control.ts +282 -0
  715. package/src/clusters/content-control.ts +48 -54
  716. package/src/clusters/content-launcher.ts +16 -15
  717. package/src/clusters/device-energy-management-mode.ts +63 -161
  718. package/src/clusters/device-energy-management.ts +246 -193
  719. package/src/clusters/dishwasher-alarm.ts +5 -5
  720. package/src/clusters/dishwasher-mode.ts +46 -87
  721. package/src/clusters/door-lock.ts +786 -1235
  722. package/src/clusters/ecosystem-information.ts +200 -0
  723. package/src/clusters/electrical-energy-measurement.ts +15 -16
  724. package/src/clusters/energy-evse-mode.ts +81 -158
  725. package/src/clusters/energy-evse.ts +138 -72
  726. package/src/clusters/energy-preference.ts +34 -28
  727. package/src/clusters/ethernet-network-diagnostics.ts +1 -3
  728. package/src/clusters/fan-control.ts +5 -5
  729. package/src/clusters/fixed-label.ts +7 -2
  730. package/src/clusters/flow-measurement.ts +6 -6
  731. package/src/clusters/general-commissioning.ts +396 -96
  732. package/src/clusters/general-diagnostics.ts +31 -33
  733. package/src/clusters/group-key-management.ts +22 -24
  734. package/src/clusters/groups.ts +3 -2
  735. package/src/clusters/icd-management.ts +88 -31
  736. package/src/clusters/identify.ts +9 -10
  737. package/src/clusters/illuminance-measurement.ts +9 -10
  738. package/src/clusters/index.ts +14 -1
  739. package/src/clusters/joint-fabric-datastore-cluster.ts +657 -0
  740. package/src/clusters/joint-fabric-pki.ts +202 -0
  741. package/src/clusters/keypad-input.ts +2 -2
  742. package/src/clusters/laundry-dryer-controls.ts +6 -10
  743. package/src/clusters/laundry-washer-controls.ts +28 -27
  744. package/src/clusters/laundry-washer-mode.ts +49 -90
  745. package/src/clusters/level-control.ts +45 -12
  746. package/src/clusters/localization-configuration.ts +5 -6
  747. package/src/clusters/media-input.ts +3 -2
  748. package/src/clusters/media-playback.ts +9 -7
  749. package/src/clusters/microwave-oven-control.ts +19 -17
  750. package/src/clusters/microwave-oven-mode.ts +42 -61
  751. package/src/clusters/mode-base.ts +16 -33
  752. package/src/clusters/mode-select.ts +17 -14
  753. package/src/clusters/network-commissioning.ts +47 -40
  754. package/src/clusters/occupancy-sensing.ts +433 -72
  755. package/src/clusters/on-off.ts +6 -8
  756. package/src/clusters/operational-credentials.ts +54 -47
  757. package/src/clusters/operational-state.ts +136 -58
  758. package/src/clusters/ota-software-update-provider.ts +23 -23
  759. package/src/clusters/ota-software-update-requestor.ts +4 -6
  760. package/src/clusters/oven-cavity-operational-state.ts +43 -171
  761. package/src/clusters/oven-mode.ts +76 -178
  762. package/src/clusters/power-source.ts +45 -21
  763. package/src/clusters/pressure-measurement.ts +2 -2
  764. package/src/clusters/pump-configuration-and-control.ts +35 -23
  765. package/src/clusters/refrigerator-alarm.ts +2 -1
  766. package/src/clusters/refrigerator-and-temperature-controlled-cabinet-mode.ts +41 -78
  767. package/src/clusters/relative-humidity-measurement.ts +1 -1
  768. package/src/clusters/rvc-clean-mode.ts +42 -101
  769. package/src/clusters/rvc-operational-state.ts +87 -25
  770. package/src/clusters/rvc-run-mode.ts +62 -126
  771. package/src/clusters/scenes-management.ts +38 -23
  772. package/src/clusters/service-area.ts +904 -0
  773. package/src/clusters/smoke-co-alarm.ts +6 -12
  774. package/src/clusters/switch.ts +177 -78
  775. package/src/clusters/target-navigator.ts +1 -1
  776. package/src/clusters/thermostat.ts +1245 -214
  777. package/src/clusters/thread-border-router-management.ts +355 -0
  778. package/src/clusters/thread-network-diagnostics.ts +34 -21
  779. package/src/clusters/thread-network-directory.ts +256 -0
  780. package/src/clusters/time-synchronization.ts +30 -23
  781. package/src/clusters/unit-localization.ts +3 -4
  782. package/src/clusters/user-label.ts +2 -1
  783. package/src/clusters/water-heater-management.ts +457 -0
  784. package/src/clusters/water-heater-mode.ts +301 -0
  785. package/src/clusters/water-tank-level-monitoring.ts +50 -0
  786. package/src/clusters/wi-fi-network-diagnostics.ts +6 -8
  787. package/src/clusters/wi-fi-network-management.ts +119 -0
  788. package/src/clusters/window-covering.ts +26 -37
  789. package/src/globals/AtomicAttributeStatus.ts +41 -0
  790. package/src/globals/AtomicRequestType.ts +27 -0
  791. package/src/globals/Locationdesc.ts +88 -0
  792. package/src/globals/Priority.ts +1 -1
  793. package/src/globals/Semtag.ts +6 -6
  794. package/src/globals/SoftwareVersionCertificationStatus.ts +1 -1
  795. package/src/globals/Status.ts +20 -3
  796. package/src/globals/Tod.ts +2 -2
  797. package/src/globals/index.ts +3 -0
  798. package/src/schema/QrCodeSchema.ts +7 -2
  799. package/dist/cjs/clusters/pulse-width-modulation.d.ts +0 -2023
  800. package/dist/cjs/clusters/pulse-width-modulation.d.ts.map +0 -1
  801. package/dist/cjs/clusters/pulse-width-modulation.js +0 -51
  802. package/dist/cjs/clusters/pulse-width-modulation.js.map +0 -6
  803. package/dist/esm/clusters/pulse-width-modulation.d.ts +0 -2023
  804. package/dist/esm/clusters/pulse-width-modulation.d.ts.map +0 -1
  805. package/dist/esm/clusters/pulse-width-modulation.js +0 -31
  806. package/dist/esm/clusters/pulse-width-modulation.js.map +0 -6
  807. package/src/clusters/pulse-width-modulation.ts +0 -54
@@ -6,26 +6,386 @@
6
6
  import { MutableCluster } from "../cluster/mutation/MutableCluster.js";
7
7
  import {
8
8
  WritableFabricScopedAttribute,
9
- OptionalWritableFabricScopedAttribute,
10
- FixedAttribute,
11
9
  Event,
12
- EventPriority
10
+ EventPriority,
11
+ FixedAttribute,
12
+ FabricScopedAttribute,
13
+ Command
13
14
  } from "../cluster/Cluster.js";
14
15
  import { TlvArray } from "../tlv/TlvArray.js";
15
- import { TlvField, TlvObject } from "../tlv/TlvObject.js";
16
- import { TlvEnum, TlvUInt16 } from "../tlv/TlvNumber.js";
17
- import { TlvSubjectId } from "../datatype/SubjectId.js";
18
- import { TlvNullable } from "../tlv/TlvNullable.js";
19
- import { TlvClusterId } from "../datatype/ClusterId.js";
20
- import { TlvEndpointNumber } from "../datatype/EndpointNumber.js";
21
- import { TlvDeviceTypeId } from "../datatype/DeviceTypeId.js";
16
+ import { TlvField, TlvObject, TlvOptionalField } from "../tlv/TlvObject.js";
17
+ import { TlvByteString, TlvString } from "../tlv/TlvString.js";
22
18
  import { TlvFabricIndex } from "../datatype/FabricIndex.js";
23
19
  import { AccessLevel } from "#model";
24
- import { TlvByteString } from "../tlv/TlvString.js";
25
20
  import { TlvNodeId } from "../datatype/NodeId.js";
21
+ import { TlvNullable } from "../tlv/TlvNullable.js";
22
+ import { TlvUInt16, TlvEnum, TlvUInt32, TlvUInt64 } from "../tlv/TlvNumber.js";
23
+ import { TlvEndpointNumber } from "../datatype/EndpointNumber.js";
24
+ import { TlvClusterId } from "../datatype/ClusterId.js";
25
+ import { BitFlag } from "../schema/BitmapSchema.js";
26
+ import { TlvSubjectId } from "../datatype/SubjectId.js";
27
+ import { TlvDeviceTypeId } from "../datatype/DeviceTypeId.js";
26
28
  import { ClusterRegistry } from "../cluster/ClusterRegistry.js";
27
29
  var AccessControl;
28
30
  ((AccessControl2) => {
31
+ let Feature;
32
+ ((Feature2) => {
33
+ Feature2["Extension"] = "Extension";
34
+ Feature2["ManagedDevice"] = "ManagedDevice";
35
+ })(Feature = AccessControl2.Feature || (AccessControl2.Feature = {}));
36
+ AccessControl2.TlvAccessControlExtension = TlvObject({
37
+ /**
38
+ * This field may be used by manufacturers to store arbitrary TLV-encoded data related to a fabric’s
39
+ *
40
+ * Access Control Entries.
41
+ *
42
+ * The contents shall consist of a top-level anonymous list; each list element shall include a profile-specific
43
+ * tag encoded in fully-qualified form.
44
+ *
45
+ * Administrators may iterate over this list of elements, and interpret selected elements at their discretion.
46
+ * The content of each element is not specified, but may be coordinated among manufacturers at their discretion.
47
+ *
48
+ * @see {@link MatterSpecification.v13.Core} § 9.10.5.7.1
49
+ */
50
+ data: TlvField(1, TlvByteString.bound({ maxLength: 128 })),
51
+ fabricIndex: TlvField(254, TlvFabricIndex)
52
+ });
53
+ let ChangeType;
54
+ ((ChangeType2) => {
55
+ ChangeType2[ChangeType2["Changed"] = 0] = "Changed";
56
+ ChangeType2[ChangeType2["Added"] = 1] = "Added";
57
+ ChangeType2[ChangeType2["Removed"] = 2] = "Removed";
58
+ })(ChangeType = AccessControl2.ChangeType || (AccessControl2.ChangeType = {}));
59
+ AccessControl2.TlvAccessControlExtensionChangedEvent = TlvObject({
60
+ /**
61
+ * The Node ID of the Administrator that made the change, if the change occurred via a CASE session.
62
+ *
63
+ * Exactly one of AdminNodeID and AdminPasscodeID shall be set, depending on whether the change occurred via a
64
+ * CASE or PASE session; the other shall be null.
65
+ *
66
+ * @see {@link MatterSpecification.v13.Core} § 9.10.9.2.1
67
+ */
68
+ adminNodeId: TlvField(1, TlvNullable(TlvNodeId)),
69
+ /**
70
+ * The Passcode ID of the Administrator that made the change, if the change occurred via a PASE session.
71
+ * Non-zero values are reserved for future use (see PasscodeId generation in PBKDFParamRequest).
72
+ *
73
+ * Exactly one of AdminNodeID and AdminPasscodeID shall be set, depending on whether the change occurred via a
74
+ * CASE or PASE session; the other shall be null.
75
+ *
76
+ * @see {@link MatterSpecification.v13.Core} § 9.10.9.2.2
77
+ */
78
+ adminPasscodeId: TlvField(2, TlvNullable(TlvUInt16)),
79
+ /**
80
+ * The type of change as appropriate.
81
+ *
82
+ * @see {@link MatterSpecification.v13.Core} § 9.10.9.2.3
83
+ */
84
+ changeType: TlvField(3, TlvEnum()),
85
+ /**
86
+ * The latest value of the changed extension.
87
+ *
88
+ * This field SHOULD be set if resources are adequate for it; otherwise it shall be set to NULL if resources
89
+ * are scarce.
90
+ *
91
+ * @see {@link MatterSpecification.v13.Core} § 9.10.9.2.4
92
+ */
93
+ latestValue: TlvField(4, TlvNullable(AccessControl2.TlvAccessControlExtension)),
94
+ fabricIndex: TlvField(254, TlvFabricIndex)
95
+ });
96
+ let AccessRestrictionType;
97
+ ((AccessRestrictionType2) => {
98
+ AccessRestrictionType2[AccessRestrictionType2["AttributeAccessForbidden"] = 0] = "AttributeAccessForbidden";
99
+ AccessRestrictionType2[AccessRestrictionType2["AttributeWriteForbidden"] = 1] = "AttributeWriteForbidden";
100
+ AccessRestrictionType2[AccessRestrictionType2["CommandForbidden"] = 2] = "CommandForbidden";
101
+ AccessRestrictionType2[AccessRestrictionType2["EventForbidden"] = 3] = "EventForbidden";
102
+ })(AccessRestrictionType = AccessControl2.AccessRestrictionType || (AccessControl2.AccessRestrictionType = {}));
103
+ AccessControl2.TlvAccessRestriction = TlvObject({
104
+ /**
105
+ * This field shall indicate the type of restriction, for example, AttributeAccessForbidden.
106
+ *
107
+ * @see {@link MatterSpecification.v13.Core} § 9.10.5.8.1
108
+ */
109
+ type: TlvField(0, TlvEnum()),
110
+ /**
111
+ * This field shall indicate the element Manufacturer Extensible Identifier (MEI) associated with the element
112
+ * type subject to the access restriction, based upon the AccessRestrictionTypeEnum. When the Type is
113
+ * AttributeAccessForbidden or AttributeWriteForbidden, this value shall be considered of type attrib-id (i.e.
114
+ * an attribute identifier). When the Type is CommandForbidden, this value shall be considered of type
115
+ * command-id (i.e. an attribute identifier). When the Type is EventForbidden, this value shall be considered
116
+ * of type event-id (i.e. an event identifier).
117
+ *
118
+ * A null value shall indicate the wildcard value for the given value of Type (i.e. all elements associated
119
+ * with the Type under the associated endpoint and cluster for the containing AccessRestrictionEntryStruct).
120
+ *
121
+ * @see {@link MatterSpecification.v13.Core} § 9.10.5.8.2
122
+ */
123
+ id: TlvField(1, TlvNullable(TlvUInt32))
124
+ });
125
+ AccessControl2.TlvCommissioningAccessRestrictionEntry = TlvObject({
126
+ /**
127
+ * This field shall indicate the endpoint having associated access restrictions scoped to the associated fabric
128
+ * of the list containing the entry.
129
+ *
130
+ * @see {@link MatterSpecification.v13.Core} § 9.10.5.10.1
131
+ */
132
+ endpoint: TlvField(0, TlvEndpointNumber),
133
+ /**
134
+ * This field shall indicate the cluster having associated access restrictions under the entry’s Endpoint,
135
+ * scoped to the associated fabric of the list containing the entry.
136
+ *
137
+ * @see {@link MatterSpecification.v13.Core} § 9.10.5.10.2
138
+ */
139
+ cluster: TlvField(1, TlvClusterId),
140
+ /**
141
+ * This field shall indicate the set of restrictions applying to the Cluster under the given Endpoint, scoped
142
+ * to the associated fabric of the list containing the entry.
143
+ *
144
+ * This list shall NOT be empty.
145
+ *
146
+ * @see {@link MatterSpecification.v13.Core} § 9.10.5.10.3
147
+ */
148
+ restrictions: TlvField(2, TlvArray(AccessControl2.TlvAccessRestriction, { minLength: 1 }))
149
+ });
150
+ AccessControl2.TlvAccessRestrictionEntry = TlvObject({
151
+ /**
152
+ * This field shall indicate the endpoint having associated access restrictions scoped to the associated fabric
153
+ * of the list containing the entry.
154
+ *
155
+ * @see {@link MatterSpecification.v13.Core} § 9.10.5.9.1
156
+ */
157
+ endpoint: TlvField(0, TlvEndpointNumber),
158
+ /**
159
+ * This field shall indicate the cluster having associated access restrictions under the entry’s Endpoint,
160
+ * scoped to the associated fabric of the list containing the entry.
161
+ *
162
+ * @see {@link MatterSpecification.v13.Core} § 9.10.5.9.2
163
+ */
164
+ cluster: TlvField(1, TlvClusterId),
165
+ /**
166
+ * This field shall indicate the set of restrictions applying to the Cluster under the given Endpoint, scoped
167
+ * to the associated fabric of the list containing the entry.
168
+ *
169
+ * This list shall NOT be empty.
170
+ *
171
+ * @see {@link MatterSpecification.v13.Core} § 9.10.5.9.3
172
+ */
173
+ restrictions: TlvField(2, TlvArray(AccessControl2.TlvAccessRestriction, { minLength: 1 })),
174
+ fabricIndex: TlvField(254, TlvFabricIndex)
175
+ });
176
+ AccessControl2.TlvReviewFabricRestrictionsRequest = TlvObject({
177
+ /**
178
+ * When the ARL field is provided, it indicates the specific restrictions that are requested for review. An
179
+ * empty list represents a generic request for review of all restrictions.
180
+ *
181
+ * @see {@link MatterSpecification.v13.Core} § 9.10.8.1.1
182
+ */
183
+ arl: TlvField(0, TlvArray(AccessControl2.TlvCommissioningAccessRestrictionEntry))
184
+ });
185
+ AccessControl2.TlvReviewFabricRestrictionsResponse = TlvObject({
186
+ /**
187
+ * This field shall specify a Token that can be used to correlate a ReviewFabricRestrictionsResponse with a
188
+ * FabricRestrictionReviewUpdate event.
189
+ *
190
+ * @see {@link MatterSpecification.v13.Core} § 9.10.8.2.1
191
+ */
192
+ token: TlvField(0, TlvUInt64)
193
+ });
194
+ AccessControl2.TlvFabricRestrictionReviewUpdateEvent = TlvObject({
195
+ /**
196
+ * This field shall indicate the Token that can be used to correlate a ReviewFabricRestrictionsResponse with a
197
+ * FabricRestrictionReviewUpdate event.
198
+ *
199
+ * @see {@link MatterSpecification.v13.Core} § 9.10.9.3.1
200
+ */
201
+ token: TlvField(0, TlvUInt64),
202
+ /**
203
+ * This field shall provide human readable text that may be displayed to the user to help them locate the user
204
+ * interface for managing access restrictions for each fabric.
205
+ *
206
+ * A device SHOULD implement the Localization Configuration Cluster when it has no other means to determine the
207
+ * locale to use for this text.
208
+ *
209
+ * Examples include "Please try again and immediately access device display for further instructions." or
210
+ * "Please check email associated with your Acme account."
211
+ *
212
+ * @see {@link MatterSpecification.v13.Core} § 9.10.9.3.2
213
+ */
214
+ instruction: TlvOptionalField(1, TlvString.bound({ maxLength: 512 })),
215
+ /**
216
+ * This field shall indicate the URL for the service associated with the device maker which the user can visit
217
+ * to manage fabric limitations. The syntax of this field shall follow the syntax as specified in RFC 1738 and
218
+ * shall use the https scheme for internet-hosted URLs.
219
+ *
220
+ * • The URL may embed the token, fabric index, fabric vendor, or other information transparently in order to
221
+ * pass context about the originating ReviewFabricRestrictions command to the service associated with the
222
+ * URL. The service associated with the device vendor may perform vendor ID verification on the fabric from
223
+ * which the ReviewFabricRestrictions command originated.
224
+ *
225
+ * • If the device grants the request, the ARL attribute in the Access Control Cluster shall be updated to
226
+ * reflect the new access rights and a successful response shall be returned to the device making the
227
+ * request using the MTaer field of the callbackUrl. If the request is denied, the ARL attribute shall
228
+ * remain unchanged and a failure response shall be returned to the device making the request using the
229
+ * MTaer field of the callbackUrl.
230
+ *
231
+ * • The device using this mechanism shall provide a service at the URL that can accept requests for
232
+ * additional access and return responses indicating whether the requests were granted or denied.
233
+ *
234
+ * • This URL will typically lead to a server which (e.g. by looking at the User-Agent) redirects the user to
235
+ * allow viewing, downloading, installing or using a manufacturer-provided means for guiding the user
236
+ * through the process to review and approve or deny the request. The device manufacturer may choose to use
237
+ * a constructed URL which is valid in a HTTP GET request (i.e. dedicated for the product) such as, for
238
+ * example, https://domain.example/arl-app?vid=FFF1& pid=1234. If a client follows or launches the
239
+ * ARLRequestFlowUrl, it shall expand it as described in Section 9.10.9.3.4, “ARLRequestFlowUrl format”.
240
+ *
241
+ * • A manufacturer contemplating using this flow should realize that
242
+ *
243
+ * ◦ This flow typically requires internet access to access the URL, and access extension may fail when
244
+ * internet connectivity is not available.
245
+ *
246
+ * ◦ If the flow prefers to redirect the user to an app which is available on popular platforms, it SHOULD
247
+ * also provide a fallback option such as a web browser interface to ensure users can complete access
248
+ * extension.
249
+ *
250
+ * ### ARLRequestFlowUrl format
251
+ *
252
+ * The ARLRequestFlowUrl shall contain a query component (see RFC 3986 section 3.4) composed of one or more
253
+ * key-value pairs:
254
+ *
255
+ * • The query shall use the & delimiter between key/value pairs.
256
+ *
257
+ * • The key-value pairs shall in the format name=<value> where name is the key name, and <value>
258
+ *
259
+ * is the contents of the value encoded with proper URL-encoded escaping.
260
+ *
261
+ * • If key MTcu is present, it shall have a value of "_" (i.e. MTcu=_). This is the "callback URL
262
+ *
263
+ * backUrl) placeholder".
264
+ *
265
+ * • Any key whose name begins with MT not mentioned in the previous bullets shall be reserved for future use
266
+ * by this specification. Manufacturers shall NOT include query keys starting with MT in the
267
+ * ARLRequestFlowUrl unless they are referenced by a version of this specification.
268
+ *
269
+ * Any other element in the ARLRequestFlowUrl query field not covered by the above rules, as well as the
270
+ * fragment field (if present), shall remain including the order of query key/value pairs present.
271
+ *
272
+ * Expansion of ARLRequestFlowUrl by client
273
+ *
274
+ * Once the URL is obtained, it shall be expanded to form a final URL (ExpandedARLRequestFlowUrl) by proceeding
275
+ * with the following substitution algorithm on the original ARLRequestFlowUrl:
276
+ *
277
+ * 1. If key MTcu is present, compute the CallbackUrl desired (see Section 9.10.9.3.5, “CallbackUrl format
278
+ * for ARL Request Flow response”), and substitute the placeholder value "_" (i.e. in MTcu=_) in the
279
+ * ARLRequestFlowUrl with the desired contents, encoded with proper URL-encoded escaping (see RFC 3986
280
+ * section 2).
281
+ *
282
+ * The final URL after expansion (ExpandedARLRequestFlowUrl) shall be the one to follow, rather than the
283
+ * original value obtained from the FabricRestrictionReviewUpdate event.
284
+ *
285
+ * ### CallbackUrl format for ARL Request Flow response
286
+ *
287
+ * If a CallbackUrl field (i.e. MTcu=) query field placeholder is present in the ARLRequestFlowUrl, the client
288
+ * may replace the placeholder value "_" in the ExpandedARLRequestFlowUrl with a URL that the manufacturer flow
289
+ * can use to make a smooth return to the client when the ARL flow has terminated.
290
+ *
291
+ * This URL field may contain a query component (see RFC 3986 section 3.4). If a query is present, it shall be
292
+ * composed of one or more key-value pairs:
293
+ *
294
+ * • The query shall use the & delimiter between key/value pairs.
295
+ *
296
+ * • The key-value pairs shall follow the format name=<value> where name is the key name, and
297
+ *
298
+ * <value> is the contents of the value encoded with proper URL-encoded escaping.
299
+ *
300
+ * • If key MTaer is present, it shall have a value of "_" (i.e. MTaer=_). This is the placeholder for a
301
+ * "access extension response" provided by the manufacturer flow to the client. The manufacturer flow shall
302
+ * replace this placeholder with the final status of the access extension request, which shall be formatted
303
+ * following Expansion of CallbackUrl by the manufacturer custom flow and encoded with proper URL-encoded
304
+ * escaping.
305
+ *
306
+ * • Any key whose name begins with MT not mentioned in the previous bullets shall be reserved for future use
307
+ * by this specification.
308
+ *
309
+ * Any other element in the CallbackUrl query field not covered by the above rules, as well as the frag
310
+ *
311
+ * ment field (if present), shall remain as provided by the client through embedding within the
312
+ *
313
+ * ExpandedARLRequestFlowUrl, including the order of query key/value pairs present.
314
+ *
315
+ * ### Expansion of CallbackUrl by the manufacturer custom flow
316
+ *
317
+ * Once the CallbackUrl is obtained by the manufacturer flow, it may be expanded to form a final
318
+ * ExpandedARLRequestCallbackUrl URL to be used by proceeding with the following substitution algorithm on the
319
+ * provided CallbackUrl:
320
+ *
321
+ * • If key MTaer is present, the manufacturer custom flow having received the initial query containing the
322
+ * CallbackUrl shall substitute the placeholder value "_" (i.e. in MTaer=_) in the CallbackUrl with the
323
+ * final status of the access extension request flow which shall be one of the following. Any value
324
+ * returned in the MTaer field not listed above shall be considered an error and shall be treated as
325
+ * GeneralFailure.
326
+ *
327
+ * ◦ Success - The flow completed successfully and the ARL attribute was updated. The client may now read
328
+ * the ARL attribute to determine the new access restrictions.
329
+ *
330
+ * ◦ NoChange - The ARL attribute was already listing minimum restrictions for the requesting fabric.
331
+ *
332
+ * ◦ GeneralFailure - The flow failed for an unspecified reason.
333
+ *
334
+ * ◦ FlowAuthFailure - The user failed to authenticate to the flow.
335
+ *
336
+ * ◦ NotFound - Access extension failed because the target fabric was not found.
337
+ *
338
+ * A manufacturer custom flow having received an ExpandedARLRequestFlowUrl SHOULD attempt to open the
339
+ * ExpandedARLRequestCallbackUrl, on completion of the request, if an ExpandedARLRequestCallbackUrl was
340
+ * computed from the CallbackUrl and opening such a URL is supported.
341
+ *
342
+ * Examples of ARLRequestFlowUrl URLs
343
+ *
344
+ * Below are some examples of valid ExpandedARLRequestFlowUrl for several valid values of ARLRequestFlowUrl, as
345
+ * well as some examples of invalid values of ARLRequestFlowUrl:
346
+ *
347
+ * • Invalid URL with no query string: http scheme is not allowed:
348
+ *
349
+ * ◦ http://company.domain.example/matter/arl/vFFF1p1234
350
+ *
351
+ * • Valid URL :
352
+ *
353
+ * ◦ https://company.domain.example/matter/arl/vFFF1p1234
354
+ *
355
+ * • Valid URL, CallbackUrl requested:
356
+ *
357
+ * ◦ Before expansion:
358
+ *
359
+ * https://company.domain.example/matter/arl?vid=FFF1&pid=1234&MTcu=_
360
+ *
361
+ * ◦ After expansion:
362
+ *
363
+ * https://company.domain.example/matter/arl?vid=FFF1&pid=1234&MTcu=https%3A%2F%2Fc
364
+ * lient.domain.example%2Fcb%3Ftoken%3DmAsJ6_vqbr-vjDiG_w%253D%253D%26MTaer%3D_
365
+ *
366
+ * ◦ The ExpandedARLRequestFlowUrl URL contains:
367
+ *
368
+ * ▪ A CallbackUrl with a client-provided arbitrary token= key/value pair and the MTaer= key/value pair
369
+ * place-holder to indicate support for a return access extension completion status:
370
+ * https://client.domain.example/cb?token=mAsJ6_vqbr-vjDiG_w%3D%3D&MTaer=_
371
+ *
372
+ * ▪ After expansion of the CallbackUrl (MTcu key) into an ExpandedCallbackUrl, with an example return
373
+ * access extension completion status of Success, the ExpandedARLRequestCallbackUrl would be:
374
+ *
375
+ * https://client.domain.example/cb?token=mAsJ6_vqbr- vjDiG_w%3D%3D&MTaer=Success
376
+ *
377
+ * Note that the MTcu key/value pair was initially provided URL-encoded within the ExpandedARLRequestFlowUrl
378
+ * URL and the MTaer=_ key/value pair placeholder now contains a substituted returned completion status.
379
+ *
380
+ * • Invalid URL, due to MTza=79 key/value pair in reserved MT-prefixed keys reserved for future use:
381
+ *
382
+ * ◦ https://company.domain.example/matter/arl?vid=FFF1&pid=1234&MTop=_&MTza=79
383
+ *
384
+ * @see {@link MatterSpecification.v13.Core} § 9.10.9.3.3
385
+ */
386
+ arlRequestFlowUrl: TlvOptionalField(2, TlvString.bound({ maxLength: 256 })),
387
+ fabricIndex: TlvField(254, TlvFabricIndex)
388
+ });
29
389
  let AccessControlEntryPrivilege;
30
390
  ((AccessControlEntryPrivilege2) => {
31
391
  AccessControlEntryPrivilege2[AccessControlEntryPrivilege2["View"] = 1] = "View";
@@ -59,7 +419,7 @@ var AccessControl;
59
419
  * levels as well. The following diagram illustrates how the higher privilege levels subsume the lower
60
420
  * privilege levels:
61
421
  *
62
- * Figure 43. Access Control Privilege Levels
422
+ * Figure 46. Access Control Privilege Levels
63
423
  *
64
424
  * Individual clusters shall define whether attributes are readable, writable, or both readable and writable.
65
425
  * Clusters also shall define which privilege is minimally required to be able to perform a particular read or
@@ -70,13 +430,13 @@ var AccessControl;
70
430
  * Cluster itself. The Administer privilege shall NOT be used on Access Control Entries which use the Group
71
431
  * auth mode.
72
432
  *
73
- * @see {@link MatterSpecification.v13.Core} § 9.10.4.5.1
433
+ * @see {@link MatterSpecification.v13.Core} § 9.10.5.6.1
74
434
  */
75
435
  privilege: TlvField(1, TlvEnum()),
76
436
  /**
77
437
  * The AuthMode field shall specify the authentication mode required by this Access Control Entry.
78
438
  *
79
- * @see {@link MatterSpecification.v13.Core} § 9.10.4.5.2
439
+ * @see {@link MatterSpecification.v13.Core} § 9.10.5.6.2
80
440
  */
81
441
  authMode: TlvField(2, TlvEnum()),
82
442
  /**
@@ -95,7 +455,7 @@ var AccessControl;
95
455
  * successfully authenticates via AuthMode. The subjects list shall NOT be empty if the entry’s AuthMode is
96
456
  * PASE.
97
457
  *
98
- * The PASE AuthMode is reserved for future use (see Section 6.6.2.8, “Bootstrapping of the Access Control
458
+ * The PASE AuthMode is reserved for future use (see Section 6.6.2.9, “Bootstrapping of the Access Control
99
459
  * Cluster”). An attempt to write an entry with AuthMode set to PASE shall fail with a status code of
100
460
  * CONSTRAINT_ERROR.
101
461
  *
@@ -112,7 +472,7 @@ var AccessControl;
112
472
  * For Group authentication, the Group ID identifies the required group, as defined in the Group Key Management
113
473
  * Cluster.
114
474
  *
115
- * @see {@link MatterSpecification.v13.Core} § 9.10.4.5.3
475
+ * @see {@link MatterSpecification.v13.Core} § 9.10.5.6.3
116
476
  */
117
477
  subjects: TlvField(3, TlvNullable(TlvArray(TlvSubjectId))),
118
478
  /**
@@ -134,33 +494,11 @@ var AccessControl;
134
494
  * An empty targets list indicates a wildcard: that is, this entry shall grant access to all cluster instances
135
495
  * on all endpoints on this Node.
136
496
  *
137
- * @see {@link MatterSpecification.v13.Core} § 9.10.4.5.4
497
+ * @see {@link MatterSpecification.v13.Core} § 9.10.5.6.4
138
498
  */
139
499
  targets: TlvField(4, TlvNullable(TlvArray(AccessControl2.TlvAccessControlTarget))),
140
500
  fabricIndex: TlvField(254, TlvFabricIndex)
141
501
  });
142
- AccessControl2.TlvAccessControlExtension = TlvObject({
143
- /**
144
- * This field may be used by manufacturers to store arbitrary TLV-encoded data related to a fabric’s Access
145
- * Control Entries.
146
- *
147
- * The contents shall consist of a top-level anonymous list; each list element shall include a profile-specific
148
- * tag encoded in fully-qualified form.
149
- *
150
- * Administrators may iterate over this list of elements, and interpret selected elements at their discretion.
151
- * The content of each element is not specified, but may be coordinated among manufacturers at their discretion.
152
- *
153
- * @see {@link MatterSpecification.v13.Core} § 9.10.4.6.1
154
- */
155
- data: TlvField(1, TlvByteString.bound({ maxLength: 128 })),
156
- fabricIndex: TlvField(254, TlvFabricIndex)
157
- });
158
- let ChangeType;
159
- ((ChangeType2) => {
160
- ChangeType2[ChangeType2["Changed"] = 0] = "Changed";
161
- ChangeType2[ChangeType2["Added"] = 1] = "Added";
162
- ChangeType2[ChangeType2["Removed"] = 2] = "Removed";
163
- })(ChangeType = AccessControl2.ChangeType || (AccessControl2.ChangeType = {}));
164
502
  AccessControl2.TlvAccessControlEntryChangedEvent = TlvObject({
165
503
  /**
166
504
  * The Node ID of the Administrator that made the change, if the change occurred via a CASE session.
@@ -168,7 +506,7 @@ var AccessControl;
168
506
  * Exactly one of AdminNodeID and AdminPasscodeID shall be set, depending on whether the change occurred via a
169
507
  * CASE or PASE session; the other shall be null.
170
508
  *
171
- * @see {@link MatterSpecification.v13.Core} § 9.10.7.1.1
509
+ * @see {@link MatterSpecification.v13.Core} § 9.10.9.1.1
172
510
  */
173
511
  adminNodeId: TlvField(1, TlvNullable(TlvNodeId)),
174
512
  /**
@@ -178,13 +516,13 @@ var AccessControl;
178
516
  * Exactly one of AdminNodeID and AdminPasscodeID shall be set, depending on whether the change occurred via a
179
517
  * CASE or PASE session; the other shall be null.
180
518
  *
181
- * @see {@link MatterSpecification.v13.Core} § 9.10.7.1.2
519
+ * @see {@link MatterSpecification.v13.Core} § 9.10.9.1.2
182
520
  */
183
521
  adminPasscodeId: TlvField(2, TlvNullable(TlvUInt16)),
184
522
  /**
185
523
  * The type of change as appropriate.
186
524
  *
187
- * @see {@link MatterSpecification.v13.Core} § 9.10.7.1.3
525
+ * @see {@link MatterSpecification.v13.Core} § 9.10.9.1.3
188
526
  */
189
527
  changeType: TlvField(3, TlvEnum()),
190
528
  /**
@@ -193,52 +531,227 @@ var AccessControl;
193
531
  * This field SHOULD be set if resources are adequate for it; otherwise it shall be set to NULL if resources
194
532
  * are scarce.
195
533
  *
196
- * @see {@link MatterSpecification.v13.Core} § 9.10.7.1.4
534
+ * @see {@link MatterSpecification.v13.Core} § 9.10.9.1.4
197
535
  */
198
536
  latestValue: TlvField(4, TlvNullable(AccessControl2.TlvAccessControlEntry)),
199
537
  fabricIndex: TlvField(254, TlvFabricIndex)
200
538
  });
201
- AccessControl2.TlvAccessControlExtensionChangedEvent = TlvObject({
202
- /**
203
- * The Node ID of the Administrator that made the change, if the change occurred via a CASE session.
204
- *
205
- * Exactly one of AdminNodeID and AdminPasscodeID shall be set, depending on whether the change occurred via a
206
- * CASE or PASE session; the other shall be null.
207
- *
208
- * @see {@link MatterSpecification.v13.Core} § 9.10.7.2.1
209
- */
210
- adminNodeId: TlvField(1, TlvNullable(TlvNodeId)),
211
- /**
212
- * The Passcode ID of the Administrator that made the change, if the change occurred via a PASE session.
213
- * Non-zero values are reserved for future use (see PasscodeId generation in PBKDFParamRequest).
214
- *
215
- * Exactly one of AdminNodeID and AdminPasscodeID shall be set, depending on whether the change occurred via a
216
- * CASE or PASE session; the other shall be null.
217
- *
218
- * @see {@link MatterSpecification.v13.Core} § 9.10.7.2.2
219
- */
220
- adminPasscodeId: TlvField(2, TlvNullable(TlvUInt16)),
221
- /**
222
- * The type of change as appropriate.
223
- *
224
- * @see {@link MatterSpecification.v13.Core} § 9.10.7.2.3
225
- */
226
- changeType: TlvField(3, TlvEnum()),
227
- /**
228
- * The latest value of the changed extension.
229
- *
230
- * This field SHOULD be set if resources are adequate for it; otherwise it shall be set to NULL if resources
231
- * are scarce.
232
- *
233
- * @see {@link MatterSpecification.v13.Core} § 9.10.7.2.4
234
- */
235
- latestValue: TlvField(4, TlvNullable(AccessControl2.TlvAccessControlExtension)),
236
- fabricIndex: TlvField(254, TlvFabricIndex)
539
+ AccessControl2.ExtensionComponent = MutableCluster.Component({
540
+ attributes: {
541
+ /**
542
+ * If present, the Access Control Extensions may be used by Administrators to store arbitrary data related
543
+ * to fabric’s Access Control Entries.
544
+ *
545
+ * The Access Control Extension list shall support a single extension entry per supported fabric.
546
+ *
547
+ * @see {@link MatterSpecification.v13.Core} § 9.10.6.4
548
+ */
549
+ extension: WritableFabricScopedAttribute(
550
+ 1,
551
+ TlvArray(AccessControl2.TlvAccessControlExtension),
552
+ { default: [], readAcl: AccessLevel.Administer, writeAcl: AccessLevel.Administer }
553
+ )
554
+ },
555
+ events: {
556
+ /**
557
+ * The cluster shall generate AccessControlExtensionChanged events whenever its extension attribute data is
558
+ * changed by an Administrator.
559
+ *
560
+ * Each added extension shall generate an event with ChangeType Added.
561
+ *
562
+ * Each changed extension shall generate an event with ChangeType Changed.
563
+ *
564
+ * • Each removed extension shall generate an event with ChangeType Removed.
565
+ *
566
+ * @see {@link MatterSpecification.v13.Core} § 9.10.9.2
567
+ */
568
+ accessControlExtensionChanged: Event(
569
+ 1,
570
+ EventPriority.Info,
571
+ AccessControl2.TlvAccessControlExtensionChangedEvent,
572
+ { readAcl: AccessLevel.Administer }
573
+ )
574
+ }
575
+ });
576
+ AccessControl2.ManagedDeviceComponent = MutableCluster.Component({
577
+ attributes: {
578
+ /**
579
+ * This attribute shall provide the set of CommissioningAccessRestrictionEntryStruct applied during
580
+ * commissioning on a managed device.
581
+ *
582
+ * When present, the CommissioningARL attribute shall indicate the access restrictions applying during
583
+ * commissioning.
584
+ *
585
+ * Attempts to access data model elements described by an entry in the CommissioningARL attribute during
586
+ * commissioning shall result in an error of ACCESS_RESTRICTED. See Access Control Model for more
587
+ * information about the features related to controlling access to a Node’s Endpoint Clusters ("Targets"
588
+ * hereafter) from other Nodes.
589
+ *
590
+ * See Section 9.10.4.2.1, “Managed Device Feature Usage Restrictions” for limitations on the use of access
591
+ * restrictions.
592
+ *
593
+ * @see {@link MatterSpecification.v13.Core} § 9.10.6.8
594
+ */
595
+ commissioningArL: FixedAttribute(5, TlvArray(AccessControl2.TlvCommissioningAccessRestrictionEntry), { default: [] }),
596
+ /**
597
+ * This attribute shall provide the set of AccessRestrictionEntryStruct applied to the associated fabric on
598
+ * a managed device.
599
+ *
600
+ * When present, the ARL attribute shall indicate the access restrictions applying to the accessing fabric.
601
+ * In contrast, the CommissioningARL attribute indicates the accessing restrictions that apply when there
602
+ * is no accessing fabric, such as during commissioning.
603
+ *
604
+ * The access restrictions are externally added/removed based on the particular relationship the device
605
+ * hosting this server has with external entities such as its owner, external service provider, or end-user.
606
+ *
607
+ * Attempts to access data model elements described by an entry in the ARL attribute for the accessing
608
+ * fabric shall result in an error of ACCESS_RESTRICTED. See Access Control Model for more information
609
+ * about the features related to controlling access to a Node’s Endpoint Clusters ("Targets" hereafter)
610
+ * from other Nodes.
611
+ *
612
+ * See Section 9.10.4.2.1, “Managed Device Feature Usage Restrictions” for limitations on the use of access
613
+ * restrictions.
614
+ *
615
+ * @see {@link MatterSpecification.v13.Core} § 9.10.6.9
616
+ */
617
+ arl: FabricScopedAttribute(6, TlvArray(AccessControl2.TlvAccessRestrictionEntry), { default: [] })
618
+ },
619
+ commands: {
620
+ /**
621
+ * This command signals to the service associated with the device vendor that the fabric administrator
622
+ * would like a review of the current restrictions on the accessing fabric. This command includes an
623
+ * optional list of ARL entries that the fabric administrator would like removed.
624
+ *
625
+ * In response, a ReviewFabricRestrictionsResponse is sent which contains a token that can be used to
626
+ * correlate a review request with a FabricRestrictionReviewUpdate event.
627
+ *
628
+ * Within 1 hour of the ReviewFabricRestrictionsResponse, the FabricRestrictionReviewUpdate event shall be
629
+ * generated, in order to indicate completion of the review and any additional steps required by the user
630
+ * for the review.
631
+ *
632
+ * A review may include obtaining consent from the user, which can take time. For example, the user may
633
+ * need to respond to an email or a push notification.
634
+ *
635
+ * The ARL attribute may change at any time due to actions taken by the user, or the service associated
636
+ * with the device vendor.
637
+ *
638
+ * @see {@link MatterSpecification.v13.Core} § 9.10.8.1
639
+ */
640
+ reviewFabricRestrictions: Command(
641
+ 0,
642
+ AccessControl2.TlvReviewFabricRestrictionsRequest,
643
+ 1,
644
+ AccessControl2.TlvReviewFabricRestrictionsResponse,
645
+ { invokeAcl: AccessLevel.Administer }
646
+ )
647
+ },
648
+ events: {
649
+ /**
650
+ * The cluster shall generate a FabricRestrictionReviewUpdate event to indicate completion of a fabric
651
+ * restriction review. Due to the requirement to generate this event within a bound time frame of
652
+ * successful receipt of the ReviewFabricRestrictions command, this event may include additional steps that
653
+ * the client may present to the user in order to help the user locate the user interface for the Managed
654
+ * Device feature.
655
+ *
656
+ * @see {@link MatterSpecification.v13.Core} § 9.10.9.3
657
+ */
658
+ fabricRestrictionReviewUpdate: Event(
659
+ 2,
660
+ EventPriority.Info,
661
+ AccessControl2.TlvFabricRestrictionReviewUpdateEvent,
662
+ { readAcl: AccessLevel.Administer }
663
+ )
664
+ }
237
665
  });
238
- AccessControl2.ClusterInstance = MutableCluster({
666
+ AccessControl2.Base = MutableCluster.Component({
239
667
  id: 31,
240
668
  name: "AccessControl",
241
- revision: 1,
669
+ revision: 2,
670
+ features: {
671
+ /**
672
+ * Extension
673
+ *
674
+ * This feature indicates the device supports ACL Extension attribute.
675
+ *
676
+ * @see {@link MatterSpecification.v13.Core} § 9.10.4.1
677
+ */
678
+ extension: BitFlag(0),
679
+ /**
680
+ * ManagedDevice
681
+ *
682
+ * This feature is for a device that is managed by a service associated with the device vendor and which
683
+ * imposes default access restrictions upon each new fabric added to it. This could arise, for example, if
684
+ * the device is managed by a service provider under contract to an end-user, in such a way that the
685
+ * manager of the device does not unconditionally grant universal access to all of a device’s
686
+ * functionality, even for fabric administrators. For example, many Home Routers are managed by an Internet
687
+ * Service Provider (a service), and these services often have a policy that requires them to obtain user
688
+ * consent before certain administrative functions can be delegated to a third party (e.g., a fabric
689
+ * Administrator). These restrictions are expressed using an Access Restriction List (ARL).
690
+ *
691
+ * The purpose of this feature on the Access Control cluster is to indicate to a fabric Administrator that
692
+ * access by it to specific attributes, commands and/or events for specific clusters is currently
693
+ * prohibited. Attempts to access these restricted data model elements shall result in an error of
694
+ * ACCESS_RESTRICTED.
695
+ *
696
+ * A device that implements this feature shall have a mechanism to honor the ReviewFabricRestrictions
697
+ * command, such as user interfaces or service interactions associated with a service provider or the
698
+ * device manufacturer, which allows the owner (or subscriber) to manage access restrictions for each
699
+ * fabric. The user interface design, which includes the way restrictions are organized and presented to
700
+ * the user, is not specified, but SHOULD be usable by non-expert end-users from common mobile devices,
701
+ * personal computers, or an on-device user interface.
702
+ *
703
+ * Controllers and clients SHOULD incorporate generic handling of the ACCESS_RESTRICTED error code, when it
704
+ * appears in allowed contexts, in order to gracefully handle situations where this feature is encountered.
705
+ * Device vendors that adopt this feature SHOULD be judicious in its use given the risk of unexpected
706
+ * behavior in controllers and clients.
707
+ *
708
+ * For certification testing, a device that implements this feature shall provide a way for all
709
+ * restrictions to be removed.
710
+ *
711
+ * The ARL attribute provides the set of restrictions currently applied to this fabric.
712
+ *
713
+ * The ReviewFabricRestrictions command provides a way for the fabric Administrator to request that the
714
+ * server triggers a review of the current fabric restrictions, by involving external entities such as
715
+ * end-users, or other services associated with the manager of the device hosting the server. This review
716
+ * process may involve communication between external services and the user, and may take an unpredictable
717
+ * amount of time to complete since an end-user may need to visit some resources, such as a mobile
718
+ * application or web site. A FabricRestrictionReviewUpdate event will be generated by the device within a
719
+ * predictable time period of the ReviewFabricRestrictionsResponse (see ReviewFabricRestrictions for
720
+ * specification of this time period), and this event can be correlated with the
721
+ * ReviewFabricRestrictionsResponse using a token provided in both. The device may provide instructions or
722
+ * a Redirect URL in the FabricRestrictionReviewUpdate event in order to help the user access the features
723
+ * required for managing per-fabric restrictions.
724
+ *
725
+ * See Section 6.6.2, “Model” for a description of how access control is impacted by the ARL attribute.
726
+ *
727
+ * ### Managed Device Feature Usage Restrictions
728
+ *
729
+ * Use of this feature shall be limited to the mandatory clusters of endpoints having a device type that
730
+ * explicitly permits its use in the Device Library Specification. As a reminder, the device types
731
+ * associated with an endpoint are listed in the Descriptor cluster of the endpoint.
732
+ *
733
+ * In addition, use of this feature shall NOT restrict the following clusters on any endpoint:
734
+ *
735
+ * 1. the Descriptor Cluster (0x001D)
736
+ *
737
+ * 2. the Binding Cluster (0x001E)
738
+ *
739
+ * 3. the Network Commissioning Cluster (0x0031)
740
+ *
741
+ * 4. the Identify Cluster (0x0003)
742
+ *
743
+ * 5. the Groups Cluster (0x0004)
744
+ *
745
+ * In addition, use of this feature shall NOT restrict the global attributes of any cluster.
746
+ *
747
+ * Because ARLs cannot be used to restrict root node access or access to any clusters required for
748
+ * commissioning, administrators may determine the current restrictions of the ARL at any point, including
749
+ * during commissioning after joining the fabric.
750
+ *
751
+ * @see {@link MatterSpecification.v13.Core} § 9.10.4.2
752
+ */
753
+ managedDevice: BitFlag(1)
754
+ },
242
755
  attributes: {
243
756
  /**
244
757
  * An attempt to add an Access Control Entry when no more entries are available shall result in a
@@ -252,26 +765,13 @@ var AccessControl;
252
765
  * Control Privilege Granting algorithm to determine if a subject has privilege to interact with targets on
253
766
  * the Node.
254
767
  *
255
- * @see {@link MatterSpecification.v13.Core} § 9.10.5.3
768
+ * @see {@link MatterSpecification.v13.Core} § 9.10.6.3
256
769
  */
257
770
  acl: WritableFabricScopedAttribute(
258
771
  0,
259
772
  TlvArray(AccessControl2.TlvAccessControlEntry),
260
773
  { default: [], readAcl: AccessLevel.Administer, writeAcl: AccessLevel.Administer }
261
774
  ),
262
- /**
263
- * If present, the Access Control Extensions may be used by Administrators to store arbitrary data related
264
- * to fabric’s Access Control Entries.
265
- *
266
- * The Access Control Extension list shall support a single extension entry per supported fabric.
267
- *
268
- * @see {@link MatterSpecification.v13.Core} § 9.10.5.4
269
- */
270
- extension: OptionalWritableFabricScopedAttribute(
271
- 1,
272
- TlvArray(AccessControl2.TlvAccessControlExtension),
273
- { default: [], readAcl: AccessLevel.Administer, writeAcl: AccessLevel.Administer }
274
- ),
275
775
  /**
276
776
  * This attribute shall provide the minimum number of Subjects per entry that are supported by this server.
277
777
  *
@@ -280,7 +780,7 @@ var AccessControl;
280
780
  * given implementation, it is recommended to only use the minimum value required and avoid reporting a
281
781
  * higher value than the required minimum.
282
782
  *
283
- * @see {@link MatterSpecification.v13.Core} § 9.10.5.5
783
+ * @see {@link MatterSpecification.v13.Core} § 9.10.6.5
284
784
  */
285
785
  subjectsPerAccessControlEntry: FixedAttribute(2, TlvUInt16.bound({ min: 4 }), { default: 4 }),
286
786
  /**
@@ -291,7 +791,7 @@ var AccessControl;
291
791
  * given implementation, it is recommended to only use the minimum value required and avoid reporting a
292
792
  * higher value than the required minimum.
293
793
  *
294
- * @see {@link MatterSpecification.v13.Core} § 9.10.5.6
794
+ * @see {@link MatterSpecification.v13.Core} § 9.10.6.6
295
795
  */
296
796
  targetsPerAccessControlEntry: FixedAttribute(3, TlvUInt16.bound({ min: 3 }), { default: 3 }),
297
797
  /**
@@ -303,14 +803,14 @@ var AccessControl;
303
803
  * given implementation, it is recommended to only use the minimum value required and avoid reporting a
304
804
  * higher value than the required minimum.
305
805
  *
306
- * @see {@link MatterSpecification.v13.Core} § 9.10.5.7
806
+ * @see {@link MatterSpecification.v13.Core} § 9.10.6.7
307
807
  */
308
808
  accessControlEntriesPerFabric: FixedAttribute(4, TlvUInt16.bound({ min: 4 }), { default: 4 })
309
809
  },
310
810
  events: {
311
811
  /**
312
- * The cluster shall send AccessControlEntryChanged events whenever its ACL attribute data is changed by an
313
- * Administrator.
812
+ * The cluster shall generate AccessControlEntryChanged events whenever its ACL attribute data is changed
813
+ * by an Administrator.
314
814
  *
315
815
  * • Each added entry shall generate an event with ChangeType Added.
316
816
  *
@@ -318,36 +818,61 @@ var AccessControl;
318
818
  *
319
819
  * • Each removed entry shall generate an event with ChangeType Removed.
320
820
  *
321
- * @see {@link MatterSpecification.v13.Core} § 9.10.7.1
821
+ * @see {@link MatterSpecification.v13.Core} § 9.10.9.1
322
822
  */
323
823
  accessControlEntryChanged: Event(
324
824
  0,
325
825
  EventPriority.Info,
326
826
  AccessControl2.TlvAccessControlEntryChangedEvent,
327
827
  { readAcl: AccessLevel.Administer }
828
+ )
829
+ },
830
+ /**
831
+ * This metadata controls which AccessControlCluster elements matter.js activates for specific feature
832
+ * combinations.
833
+ */
834
+ extensions: MutableCluster.Extensions(
835
+ { flags: { extension: true }, component: AccessControl2.ExtensionComponent },
836
+ { flags: { managedDevice: true }, component: AccessControl2.ManagedDeviceComponent }
837
+ )
838
+ });
839
+ AccessControl2.ClusterInstance = MutableCluster(AccessControl2.Base);
840
+ AccessControl2.Cluster = AccessControl2.ClusterInstance;
841
+ const EXTS = { extension: true };
842
+ const MNGD = { managedDevice: true };
843
+ AccessControl2.CompleteInstance = MutableCluster({
844
+ id: AccessControl2.Cluster.id,
845
+ name: AccessControl2.Cluster.name,
846
+ revision: AccessControl2.Cluster.revision,
847
+ features: AccessControl2.Cluster.features,
848
+ attributes: {
849
+ ...AccessControl2.Cluster.attributes,
850
+ extension: MutableCluster.AsConditional(AccessControl2.ExtensionComponent.attributes.extension, { mandatoryIf: [EXTS] }),
851
+ commissioningArL: MutableCluster.AsConditional(
852
+ AccessControl2.ManagedDeviceComponent.attributes.commissioningArL,
853
+ { mandatoryIf: [MNGD] }
328
854
  ),
329
- /**
330
- * The cluster shall send AccessControlExtensionChanged events whenever its extension attribute data is
331
- * changed by an Administrator.
332
- *
333
- * • Each added extension shall generate an event with ChangeType Added.
334
- *
335
- * • Each changed extension shall generate an event with ChangeType Changed.
336
- *
337
- * • Each removed extension shall generate an event with ChangeType Removed.
338
- *
339
- * @see {@link MatterSpecification.v13.Core} § 9.10.7.2
340
- */
341
- accessControlExtensionChanged: Event(
342
- 1,
343
- EventPriority.Info,
344
- AccessControl2.TlvAccessControlExtensionChangedEvent,
345
- { readAcl: AccessLevel.Administer }
855
+ arl: MutableCluster.AsConditional(AccessControl2.ManagedDeviceComponent.attributes.arl, { mandatoryIf: [MNGD] })
856
+ },
857
+ commands: {
858
+ reviewFabricRestrictions: MutableCluster.AsConditional(
859
+ AccessControl2.ManagedDeviceComponent.commands.reviewFabricRestrictions,
860
+ { mandatoryIf: [MNGD] }
861
+ )
862
+ },
863
+ events: {
864
+ ...AccessControl2.Cluster.events,
865
+ accessControlExtensionChanged: MutableCluster.AsConditional(
866
+ AccessControl2.ExtensionComponent.events.accessControlExtensionChanged,
867
+ { mandatoryIf: [EXTS] }
868
+ ),
869
+ fabricRestrictionReviewUpdate: MutableCluster.AsConditional(
870
+ AccessControl2.ManagedDeviceComponent.events.fabricRestrictionReviewUpdate,
871
+ { mandatoryIf: [MNGD] }
346
872
  )
347
873
  }
348
874
  });
349
- AccessControl2.Cluster = AccessControl2.ClusterInstance;
350
- AccessControl2.Complete = AccessControl2.Cluster;
875
+ AccessControl2.Complete = AccessControl2.CompleteInstance;
351
876
  })(AccessControl || (AccessControl = {}));
352
877
  const AccessControlCluster = AccessControl.Cluster;
353
878
  ClusterRegistry.register(AccessControl.Complete);