@project-chip/matter.js 0.2.1 → 0.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +58 -12
- package/dist/cjs/MatterController.d.ts +46 -0
- package/dist/cjs/MatterController.d.ts.map +1 -0
- package/dist/cjs/MatterController.js +211 -0
- package/dist/cjs/MatterDevice.d.ts +64 -0
- package/dist/cjs/MatterDevice.d.ts.map +1 -0
- package/dist/cjs/MatterDevice.js +198 -0
- package/dist/cjs/certificate/AttestationCertificateManager.d.ts +28 -0
- package/dist/cjs/certificate/AttestationCertificateManager.d.ts.map +1 -0
- package/dist/cjs/certificate/AttestationCertificateManager.js +146 -0
- package/dist/cjs/certificate/CertificateManager.d.ts +202 -0
- package/dist/cjs/certificate/CertificateManager.d.ts.map +1 -0
- package/dist/cjs/certificate/CertificateManager.js +344 -0
- package/dist/cjs/certificate/CertificationDeclarationManager.d.ts +5 -0
- package/dist/cjs/certificate/CertificationDeclarationManager.d.ts.map +1 -0
- package/dist/cjs/certificate/CertificationDeclarationManager.js +30 -0
- package/dist/cjs/certificate/ChipPAAuthorities.d.ts +9 -0
- package/dist/cjs/certificate/ChipPAAuthorities.d.ts.map +1 -0
- package/dist/cjs/certificate/ChipPAAuthorities.js +20 -0
- package/dist/cjs/certificate/RootCertificateManager.d.ts +20 -0
- package/dist/cjs/certificate/RootCertificateManager.d.ts.map +1 -0
- package/dist/cjs/certificate/RootCertificateManager.js +98 -0
- package/dist/cjs/certificate/index.d.ts +11 -0
- package/dist/cjs/certificate/index.d.ts.map +1 -0
- package/dist/cjs/certificate/index.js +26 -0
- package/dist/{dts → cjs}/cluster/AccessControlCluster.d.ts +19 -14
- package/dist/cjs/cluster/AccessControlCluster.d.ts.map +1 -0
- package/dist/cjs/cluster/AccessControlCluster.js +11 -11
- package/dist/cjs/cluster/ActionsCluster.d.ts +206 -0
- package/dist/cjs/cluster/ActionsCluster.d.ts.map +1 -0
- package/dist/cjs/cluster/ActionsCluster.js +225 -0
- package/dist/cjs/cluster/AdminCommissioningCluster.d.ts +63 -0
- package/dist/cjs/cluster/AdminCommissioningCluster.d.ts.map +1 -0
- package/dist/cjs/cluster/AdminCommissioningCluster.js +69 -0
- package/dist/{dts → cjs}/cluster/BasicInformationCluster.d.ts +10 -5
- package/dist/cjs/cluster/BasicInformationCluster.d.ts.map +1 -0
- package/dist/cjs/cluster/BasicInformationCluster.js +10 -10
- package/dist/cjs/cluster/BindingCluster.d.ts +28 -0
- package/dist/cjs/cluster/BindingCluster.d.ts.map +1 -0
- package/dist/cjs/cluster/BindingCluster.js +6 -6
- package/dist/cjs/cluster/BooleanStateCluster.d.ts +26 -0
- package/dist/cjs/cluster/BooleanStateCluster.d.ts.map +1 -0
- package/dist/cjs/cluster/BooleanStateCluster.js +34 -0
- package/dist/{dts → cjs}/cluster/BridgedDeviceBasicInformationCluster.d.ts +10 -5
- package/dist/cjs/cluster/BridgedDeviceBasicInformationCluster.d.ts.map +1 -0
- package/dist/cjs/cluster/BridgedDeviceBasicInformationCluster.js +8 -8
- package/dist/{dts → cjs}/cluster/Cluster.d.ts +25 -10
- package/dist/cjs/cluster/Cluster.d.ts.map +1 -0
- package/dist/cjs/cluster/Cluster.js +17 -13
- package/dist/cjs/cluster/ClusterHelper.d.ts +1083 -0
- package/dist/cjs/cluster/ClusterHelper.d.ts.map +1 -0
- package/dist/cjs/cluster/ClusterHelper.js +86 -0
- package/dist/cjs/cluster/DescriptorCluster.d.ts +30 -0
- package/dist/cjs/cluster/DescriptorCluster.d.ts.map +1 -0
- package/dist/cjs/cluster/DescriptorCluster.js +5 -5
- package/dist/cjs/cluster/FlowMeasurementCluster.d.ts +24 -0
- package/dist/cjs/cluster/FlowMeasurementCluster.d.ts.map +1 -0
- package/dist/cjs/cluster/FlowMeasurementCluster.js +31 -0
- package/dist/{dts → cjs}/cluster/GeneralCommissioningCluster.d.ts +12 -7
- package/dist/cjs/cluster/GeneralCommissioningCluster.d.ts.map +1 -0
- package/dist/cjs/cluster/GeneralCommissioningCluster.js +7 -6
- package/dist/cjs/cluster/GeneralDiagnosticsCluster.d.ts +116 -0
- package/dist/cjs/cluster/GeneralDiagnosticsCluster.d.ts.map +1 -0
- package/dist/cjs/cluster/GeneralDiagnosticsCluster.js +129 -0
- package/dist/cjs/cluster/GroupKeyManagementCluster.d.ts +91 -0
- package/dist/cjs/cluster/GroupKeyManagementCluster.d.ts.map +1 -0
- package/dist/cjs/cluster/GroupKeyManagementCluster.js +98 -0
- package/dist/{dts → cjs}/cluster/GroupsCluster.d.ts +18 -23
- package/dist/cjs/cluster/GroupsCluster.d.ts.map +1 -0
- package/dist/cjs/cluster/GroupsCluster.js +5 -22
- package/dist/{dts → cjs}/cluster/IdentifyCluster.d.ts +13 -6
- package/dist/cjs/cluster/IdentifyCluster.d.ts.map +1 -0
- package/dist/cjs/cluster/IdentifyCluster.js +12 -6
- package/dist/cjs/cluster/IlluminanceMeasurementCluster.d.ts +25 -0
- package/dist/cjs/cluster/IlluminanceMeasurementCluster.d.ts.map +1 -0
- package/dist/cjs/cluster/IlluminanceMeasurementCluster.js +33 -0
- package/dist/cjs/cluster/LabelCluster.d.ts +43 -0
- package/dist/cjs/cluster/LabelCluster.d.ts.map +1 -0
- package/dist/cjs/cluster/LabelCluster.js +5 -5
- package/dist/cjs/cluster/LevelControlCluster.d.ts +379 -0
- package/dist/cjs/cluster/LevelControlCluster.d.ts.map +1 -0
- package/dist/cjs/cluster/LevelControlCluster.js +138 -0
- package/dist/cjs/cluster/NetworkCommissioningCluster.d.ts +170 -0
- package/dist/cjs/cluster/NetworkCommissioningCluster.d.ts.map +1 -0
- package/dist/cjs/cluster/NetworkCommissioningCluster.js +178 -0
- package/dist/cjs/cluster/OccupancySensingCluster.d.ts +56 -0
- package/dist/cjs/cluster/OccupancySensingCluster.d.ts.map +1 -0
- package/dist/cjs/cluster/OccupancySensingCluster.js +62 -0
- package/dist/{dts → cjs}/cluster/OnOffCluster.d.ts +10 -5
- package/dist/cjs/cluster/OnOffCluster.d.ts.map +1 -0
- package/dist/cjs/cluster/OnOffCluster.js +45 -23
- package/dist/{dts → cjs}/cluster/OperationalCredentialsCluster.d.ts +44 -29
- package/dist/cjs/cluster/OperationalCredentialsCluster.d.ts.map +1 -0
- package/dist/cjs/cluster/OperationalCredentialsCluster.js +70 -56
- package/dist/cjs/cluster/PowerSourceCluster.d.ts +301 -0
- package/dist/cjs/cluster/PowerSourceCluster.d.ts.map +1 -0
- package/dist/cjs/cluster/PowerSourceCluster.js +132 -0
- package/dist/cjs/cluster/PowerSourceConfigurationCluster.d.ts +26 -0
- package/dist/cjs/cluster/PowerSourceConfigurationCluster.d.ts.map +1 -0
- package/dist/cjs/cluster/PowerSourceConfigurationCluster.js +31 -0
- package/dist/cjs/cluster/PressureMeasurementCluster.d.ts +36 -0
- package/dist/cjs/cluster/PressureMeasurementCluster.d.ts.map +1 -0
- package/dist/cjs/cluster/PressureMeasurementCluster.js +64 -0
- package/dist/{dts → cjs}/cluster/ScenesCluster.d.ts +46 -41
- package/dist/cjs/cluster/ScenesCluster.d.ts.map +1 -0
- package/dist/cjs/cluster/ScenesCluster.js +9 -9
- package/dist/cjs/cluster/TemperatureMeasurementCluster.d.ts +24 -0
- package/dist/cjs/cluster/TemperatureMeasurementCluster.d.ts.map +1 -0
- package/dist/cjs/cluster/TemperatureMeasurementCluster.js +31 -0
- package/dist/cjs/cluster/WaterContentMeasurementCluster.d.ts +58 -0
- package/dist/cjs/cluster/WaterContentMeasurementCluster.d.ts.map +1 -0
- package/dist/cjs/cluster/WaterContentMeasurementCluster.js +58 -0
- package/dist/cjs/cluster/client/ClusterClient.d.ts +28 -0
- package/dist/cjs/cluster/client/ClusterClient.d.ts.map +1 -0
- package/dist/cjs/cluster/client/ClusterClient.js +2 -0
- package/dist/cjs/cluster/index.d.ts +46 -0
- package/dist/cjs/cluster/index.d.ts.map +1 -0
- package/dist/cjs/cluster/index.js +66 -0
- package/dist/cjs/cluster/server/AdminCommissioningServer.d.ts +10 -0
- package/dist/cjs/cluster/server/AdminCommissioningServer.d.ts.map +1 -0
- package/dist/cjs/cluster/server/AdminCommissioningServer.js +39 -0
- package/dist/cjs/cluster/server/AttributeServer.d.ts +43 -0
- package/dist/cjs/cluster/server/AttributeServer.d.ts.map +1 -0
- package/dist/cjs/cluster/server/AttributeServer.js +81 -0
- package/dist/cjs/cluster/server/ClusterServer.d.ts +62 -0
- package/dist/cjs/cluster/server/ClusterServer.d.ts.map +1 -0
- package/dist/cjs/cluster/server/ClusterServer.js +19 -0
- package/dist/cjs/cluster/server/CommandServer.d.ts +25 -0
- package/dist/cjs/cluster/server/CommandServer.d.ts.map +1 -0
- package/dist/cjs/cluster/server/CommandServer.js +39 -0
- package/dist/cjs/cluster/server/GeneralCommissioningServer.d.ts +9 -0
- package/dist/cjs/cluster/server/GeneralCommissioningServer.d.ts.map +1 -0
- package/dist/cjs/cluster/server/GeneralCommissioningServer.js +69 -0
- package/dist/cjs/cluster/server/GroupsServer.d.ts +9 -0
- package/dist/cjs/cluster/server/GroupsServer.d.ts.map +1 -0
- package/dist/cjs/cluster/server/GroupsServer.js +149 -0
- package/dist/cjs/cluster/server/LevelControlServer.d.ts +9 -0
- package/dist/cjs/cluster/server/LevelControlServer.d.ts.map +1 -0
- package/dist/cjs/cluster/server/LevelControlServer.js +58 -0
- package/dist/cjs/cluster/server/NetworkCommissioningServer.d.ts +9 -0
- package/dist/cjs/cluster/server/NetworkCommissioningServer.d.ts.map +1 -0
- package/dist/cjs/cluster/server/NetworkCommissioningServer.js +40 -0
- package/dist/cjs/cluster/server/OnOffServer.d.ts +9 -0
- package/dist/cjs/cluster/server/OnOffServer.d.ts.map +1 -0
- package/dist/cjs/cluster/server/OnOffServer.js +47 -0
- package/dist/cjs/cluster/server/OperationalCredentialsServer.d.ts +16 -0
- package/dist/cjs/cluster/server/OperationalCredentialsServer.d.ts.map +1 -0
- package/dist/cjs/cluster/server/OperationalCredentialsServer.js +107 -0
- package/dist/cjs/codec/DerCodec.d.ts +82 -0
- package/dist/cjs/codec/DerCodec.d.ts.map +1 -0
- package/dist/cjs/codec/DerCodec.js +176 -0
- package/dist/cjs/codec/DnsCodec.d.ts +71 -0
- package/dist/cjs/codec/DnsCodec.d.ts.map +1 -0
- package/dist/cjs/codec/DnsCodec.js +249 -0
- package/dist/cjs/codec/MessageCodec.d.ts +48 -0
- package/dist/cjs/codec/MessageCodec.d.ts.map +1 -0
- package/dist/cjs/codec/MessageCodec.js +117 -0
- package/dist/cjs/codec/index.d.ts +9 -0
- package/dist/cjs/codec/index.d.ts.map +1 -0
- package/dist/cjs/codec/index.js +24 -0
- package/dist/cjs/common/Broadcaster.d.ts +14 -0
- package/dist/cjs/common/Broadcaster.d.ts.map +1 -0
- package/dist/cjs/common/Broadcaster.js +7 -0
- package/dist/cjs/common/DeviceTypes.d.ts +73 -0
- package/dist/cjs/common/DeviceTypes.d.ts.map +1 -0
- package/dist/cjs/common/DeviceTypes.js +998 -0
- package/dist/cjs/common/MatterError.d.ts +9 -0
- package/dist/cjs/common/MatterError.d.ts.map +1 -0
- package/dist/cjs/common/MatterError.js +12 -0
- package/dist/cjs/common/Scanner.d.ts +16 -0
- package/dist/cjs/common/Scanner.d.ts.map +1 -0
- package/dist/cjs/common/Scanner.js +7 -0
- package/dist/cjs/common/TryCatchHandler.d.ts +29 -0
- package/dist/cjs/common/TryCatchHandler.d.ts.map +1 -0
- package/dist/cjs/common/TryCatchHandler.js +66 -0
- package/dist/cjs/common/index.d.ts +11 -0
- package/dist/cjs/common/index.d.ts.map +1 -0
- package/dist/cjs/common/index.js +26 -0
- package/dist/cjs/crypto/Crypto.d.ts +69 -0
- package/dist/cjs/crypto/Crypto.d.ts.map +1 -0
- package/dist/cjs/crypto/Crypto.js +50 -0
- package/dist/cjs/crypto/CryptoConstants.d.ts +19 -0
- package/dist/cjs/crypto/CryptoConstants.d.ts.map +1 -0
- package/dist/cjs/crypto/CryptoConstants.js +21 -0
- package/dist/cjs/crypto/Spake2p.d.ts +42 -0
- package/dist/cjs/crypto/Spake2p.d.ts.map +1 -0
- package/dist/cjs/crypto/Spake2p.js +119 -0
- package/dist/cjs/crypto/index.d.ts +9 -0
- package/dist/cjs/crypto/index.d.ts.map +1 -0
- package/dist/cjs/crypto/index.js +24 -0
- package/dist/{dts/common → cjs/datatype}/AttributeId.d.ts +2 -1
- package/dist/cjs/datatype/AttributeId.d.ts.map +1 -0
- package/dist/cjs/{common → datatype}/AttributeId.js +1 -1
- package/dist/{dts/common → cjs/datatype}/ClusterId.d.ts +2 -1
- package/dist/cjs/datatype/ClusterId.d.ts.map +1 -0
- package/dist/cjs/{common → datatype}/ClusterId.js +1 -1
- package/dist/cjs/datatype/CommandId.d.ts +18 -0
- package/dist/cjs/datatype/CommandId.d.ts.map +1 -0
- package/dist/cjs/datatype/CommandId.js +23 -0
- package/dist/{dts/common → cjs/datatype}/DeviceTypeId.d.ts +2 -1
- package/dist/cjs/datatype/DeviceTypeId.d.ts.map +1 -0
- package/dist/cjs/{common → datatype}/DeviceTypeId.js +1 -1
- package/dist/{dts/common → cjs/datatype}/EndpointNumber.d.ts +2 -1
- package/dist/cjs/datatype/EndpointNumber.d.ts.map +1 -0
- package/dist/cjs/{common → datatype}/EndpointNumber.js +1 -1
- package/dist/cjs/datatype/EventId.d.ts +18 -0
- package/dist/cjs/datatype/EventId.d.ts.map +1 -0
- package/dist/cjs/datatype/EventId.js +23 -0
- package/dist/{dts/common → cjs/datatype}/FabricId.d.ts +2 -1
- package/dist/cjs/datatype/FabricId.d.ts.map +1 -0
- package/dist/cjs/{common → datatype}/FabricId.js +1 -1
- package/dist/{dts/common → cjs/datatype}/FabricIndex.d.ts +3 -1
- package/dist/cjs/datatype/FabricIndex.d.ts.map +1 -0
- package/dist/cjs/{common → datatype}/FabricIndex.js +3 -2
- package/dist/{dts/common → cjs/datatype}/GroupId.d.ts +2 -1
- package/dist/cjs/datatype/GroupId.d.ts.map +1 -0
- package/dist/cjs/{common → datatype}/GroupId.js +1 -1
- package/dist/{dts/common → cjs/datatype}/NodeId.d.ts +4 -1
- package/dist/cjs/datatype/NodeId.d.ts.map +1 -0
- package/dist/cjs/{common → datatype}/NodeId.js +19 -2
- package/dist/{dts/common → cjs/datatype}/SubjectId.d.ts +3 -2
- package/dist/cjs/datatype/SubjectId.d.ts.map +1 -0
- package/dist/cjs/{common → datatype}/SubjectId.js +1 -1
- package/dist/{dts/common → cjs/datatype}/VendorId.d.ts +2 -1
- package/dist/cjs/datatype/VendorId.d.ts.map +1 -0
- package/dist/cjs/{common → datatype}/VendorId.js +1 -1
- package/dist/cjs/datatype/index.d.ts +18 -0
- package/dist/cjs/datatype/index.d.ts.map +1 -0
- package/dist/cjs/datatype/index.js +34 -0
- package/dist/cjs/fabric/Fabric.d.ts +95 -0
- package/dist/cjs/fabric/Fabric.d.ts.map +1 -0
- package/dist/cjs/fabric/Fabric.js +210 -0
- package/dist/cjs/fabric/FabricManager.d.ts +30 -0
- package/dist/cjs/fabric/FabricManager.d.ts.map +1 -0
- package/dist/cjs/fabric/FabricManager.js +85 -0
- package/dist/cjs/fabric/index.d.ts +8 -0
- package/dist/cjs/fabric/index.d.ts.map +1 -0
- package/dist/cjs/fabric/index.js +23 -0
- package/dist/cjs/index.d.ts +9 -0
- package/dist/cjs/index.d.ts.map +1 -0
- package/dist/cjs/index.js +29 -0
- package/dist/cjs/log/Logger.d.ts +45 -0
- package/dist/cjs/log/Logger.d.ts.map +1 -0
- package/dist/cjs/log/Logger.js +115 -0
- package/dist/cjs/log/index.d.ts +7 -0
- package/dist/cjs/log/index.d.ts.map +1 -0
- package/dist/cjs/log/index.js +22 -0
- package/dist/cjs/math/ReedSolomon.d.ts +12 -0
- package/dist/cjs/math/ReedSolomon.d.ts.map +1 -0
- package/dist/cjs/math/ReedSolomon.js +96 -0
- package/dist/cjs/math/Verhoeff.d.ts +17 -0
- package/dist/cjs/math/Verhoeff.d.ts.map +1 -0
- package/dist/cjs/math/Verhoeff.js +51 -0
- package/dist/cjs/math/index.d.ts +8 -0
- package/dist/cjs/math/index.d.ts.map +1 -0
- package/dist/cjs/math/index.js +23 -0
- package/dist/cjs/mdns/MdnsBroadcaster.d.ts +21 -0
- package/dist/cjs/mdns/MdnsBroadcaster.d.ts.map +1 -0
- package/dist/cjs/mdns/MdnsBroadcaster.js +137 -0
- package/dist/cjs/mdns/MdnsConsts.d.ts +11 -0
- package/dist/cjs/mdns/MdnsConsts.d.ts.map +1 -0
- package/dist/cjs/mdns/MdnsConsts.js +15 -0
- package/dist/cjs/mdns/MdnsScanner.d.ts +22 -0
- package/dist/cjs/mdns/MdnsScanner.d.ts.map +1 -0
- package/dist/cjs/mdns/MdnsScanner.js +98 -0
- package/dist/cjs/mdns/MdnsServer.d.ts +26 -0
- package/dist/cjs/mdns/MdnsServer.d.ts.map +1 -0
- package/dist/cjs/mdns/MdnsServer.js +96 -0
- package/dist/cjs/mdns/index.d.ts +10 -0
- package/dist/cjs/mdns/index.d.ts.map +1 -0
- package/dist/cjs/mdns/index.js +25 -0
- package/dist/cjs/net/Channel.d.ts +10 -0
- package/dist/cjs/net/Channel.d.ts.map +1 -0
- package/dist/cjs/net/Channel.js +7 -0
- package/dist/cjs/net/NetInterface.d.ts +15 -0
- package/dist/cjs/net/NetInterface.d.ts.map +1 -0
- package/dist/cjs/net/NetInterface.js +7 -0
- package/dist/cjs/net/Network.d.ts +16 -0
- package/dist/cjs/net/Network.d.ts.map +1 -0
- package/dist/cjs/net/Network.js +12 -0
- package/dist/cjs/net/UdpChannel.d.ts +19 -0
- package/dist/cjs/net/UdpChannel.d.ts.map +1 -0
- package/dist/cjs/net/UdpChannel.js +7 -0
- package/dist/cjs/net/UdpInterface.d.ts +26 -0
- package/dist/cjs/net/UdpInterface.d.ts.map +1 -0
- package/dist/cjs/net/UdpInterface.js +50 -0
- package/dist/cjs/net/UdpMulticastServer.d.ts +29 -0
- package/dist/cjs/net/UdpMulticastServer.d.ts.map +1 -0
- package/dist/cjs/net/UdpMulticastServer.js +74 -0
- package/dist/cjs/net/fake/NetworkFake.d.ts +19 -0
- package/dist/cjs/net/fake/NetworkFake.d.ts.map +1 -0
- package/dist/cjs/net/fake/NetworkFake.js +28 -0
- package/dist/cjs/net/fake/SimulatedNetwork.d.ts +17 -0
- package/dist/cjs/net/fake/SimulatedNetwork.d.ts.map +1 -0
- package/dist/cjs/net/fake/SimulatedNetwork.js +56 -0
- package/dist/cjs/net/fake/UdpChannelFake.d.ts +22 -0
- package/dist/cjs/net/fake/UdpChannelFake.d.ts.map +1 -0
- package/dist/cjs/net/fake/UdpChannelFake.js +53 -0
- package/dist/cjs/net/index.d.ts +15 -0
- package/dist/cjs/net/index.d.ts.map +1 -0
- package/dist/cjs/net/index.js +30 -0
- package/dist/cjs/package.json +3 -0
- package/dist/cjs/protocol/ChannelManager.d.ts +23 -0
- package/dist/cjs/protocol/ChannelManager.d.ts.map +1 -0
- package/dist/cjs/protocol/ChannelManager.js +49 -0
- package/dist/cjs/protocol/ExchangeManager.d.ts +58 -0
- package/dist/cjs/protocol/ExchangeManager.d.ts.map +1 -0
- package/dist/cjs/protocol/ExchangeManager.js +150 -0
- package/dist/cjs/protocol/MessageExchange.d.ts +51 -0
- package/dist/cjs/protocol/MessageExchange.d.ts.map +1 -0
- package/dist/cjs/protocol/MessageExchange.js +240 -0
- package/dist/cjs/protocol/ProtocolHandler.d.ts +12 -0
- package/dist/cjs/protocol/ProtocolHandler.d.ts.map +1 -0
- package/dist/cjs/protocol/ProtocolHandler.js +7 -0
- package/dist/cjs/protocol/index.d.ts +10 -0
- package/dist/cjs/protocol/index.d.ts.map +1 -0
- package/dist/cjs/protocol/index.js +25 -0
- package/dist/cjs/protocol/interaction/AttributeDataDecoder.d.ts +39 -0
- package/dist/cjs/protocol/interaction/AttributeDataDecoder.d.ts.map +1 -0
- package/dist/cjs/protocol/interaction/AttributeDataDecoder.js +143 -0
- package/dist/cjs/protocol/interaction/InteractionClient.d.ts +63 -0
- package/dist/cjs/protocol/interaction/InteractionClient.d.ts.map +1 -0
- package/dist/cjs/protocol/interaction/InteractionClient.js +285 -0
- package/dist/cjs/protocol/interaction/InteractionMessenger.d.ts +250 -0
- package/dist/cjs/protocol/interaction/InteractionMessenger.d.ts.map +1 -0
- package/dist/cjs/protocol/interaction/InteractionMessenger.js +297 -0
- package/dist/cjs/protocol/interaction/InteractionProtocol.d.ts +484 -0
- package/dist/cjs/protocol/interaction/InteractionProtocol.d.ts.map +1 -0
- package/dist/cjs/protocol/interaction/InteractionProtocol.js +189 -0
- package/dist/cjs/protocol/interaction/InteractionServer.d.ts +71 -0
- package/dist/cjs/protocol/interaction/InteractionServer.d.ts.map +1 -0
- package/dist/cjs/protocol/interaction/InteractionServer.js +369 -0
- package/dist/cjs/protocol/interaction/SubscriptionHandler.d.ts +38 -0
- package/dist/cjs/protocol/interaction/SubscriptionHandler.d.ts.map +1 -0
- package/dist/cjs/protocol/interaction/SubscriptionHandler.js +174 -0
- package/dist/cjs/protocol/interaction/index.d.ts +12 -0
- package/dist/cjs/protocol/interaction/index.d.ts.map +1 -0
- package/dist/cjs/protocol/interaction/index.js +29 -0
- package/dist/cjs/protocol/securechannel/SecureChannelMessages.d.ts +63 -0
- package/dist/cjs/protocol/securechannel/SecureChannelMessages.d.ts.map +1 -0
- package/dist/cjs/protocol/securechannel/SecureChannelMessages.js +9 -0
- package/dist/cjs/protocol/securechannel/SecureChannelMessenger.d.ts +31 -0
- package/dist/cjs/protocol/securechannel/SecureChannelMessenger.d.ts.map +1 -0
- package/dist/cjs/protocol/securechannel/SecureChannelMessenger.js +96 -0
- package/dist/cjs/protocol/securechannel/SecureChannelProtocol.d.ts +21 -0
- package/dist/cjs/protocol/securechannel/SecureChannelProtocol.d.ts.map +1 -0
- package/dist/cjs/protocol/securechannel/SecureChannelProtocol.js +49 -0
- package/dist/cjs/protocol/securechannel/SecureChannelStatusMessageSchema.d.ts +23 -0
- package/dist/cjs/protocol/securechannel/SecureChannelStatusMessageSchema.d.ts.map +1 -0
- package/dist/cjs/protocol/securechannel/SecureChannelStatusMessageSchema.js +30 -0
- package/dist/cjs/protocol/securechannel/index.d.ts +10 -0
- package/dist/cjs/protocol/securechannel/index.d.ts.map +1 -0
- package/dist/cjs/protocol/securechannel/index.js +26 -0
- package/dist/cjs/schema/Base38Schema.d.ts +17 -0
- package/dist/cjs/schema/Base38Schema.d.ts.map +1 -0
- package/dist/cjs/schema/Base38Schema.js +96 -0
- package/dist/{dts → cjs}/schema/BitmapSchema.d.ts +8 -5
- package/dist/cjs/schema/BitmapSchema.d.ts.map +1 -0
- package/dist/cjs/schema/BitmapSchema.js +29 -19
- package/dist/cjs/schema/PairingCodeSchema.d.ts +55 -0
- package/dist/cjs/schema/PairingCodeSchema.d.ts.map +1 -0
- package/dist/cjs/schema/PairingCodeSchema.js +73 -0
- package/dist/cjs/schema/QrCodeSchema.d.ts +13 -0
- package/dist/cjs/schema/QrCodeSchema.d.ts.map +1 -0
- package/dist/cjs/schema/QrCodeSchema.js +203 -0
- package/dist/{dts → cjs}/schema/Schema.d.ts +2 -1
- package/dist/cjs/schema/Schema.d.ts.map +1 -0
- package/dist/cjs/schema/Schema.js +2 -1
- package/dist/cjs/schema/index.d.ts +11 -0
- package/dist/cjs/schema/index.d.ts.map +1 -0
- package/dist/cjs/schema/index.js +27 -0
- package/dist/cjs/session/SecureSession.d.ts +53 -0
- package/dist/cjs/session/SecureSession.d.ts.map +1 -0
- package/dist/cjs/session/SecureSession.js +135 -0
- package/dist/cjs/session/Session.d.ts +38 -0
- package/dist/cjs/session/Session.d.ts.map +1 -0
- package/dist/cjs/session/Session.js +17 -0
- package/dist/cjs/session/SessionManager.d.ts +41 -0
- package/dist/cjs/session/SessionManager.d.ts.map +1 -0
- package/dist/cjs/session/SessionManager.js +111 -0
- package/dist/cjs/session/UnsecureSession.d.ts +35 -0
- package/dist/cjs/session/UnsecureSession.d.ts.map +1 -0
- package/dist/cjs/session/UnsecureSession.js +68 -0
- package/dist/cjs/session/case/CaseClient.d.ts +13 -0
- package/dist/cjs/session/case/CaseClient.d.ts.map +1 -0
- package/dist/cjs/session/case/CaseClient.js +97 -0
- package/dist/cjs/session/case/CaseMessages.d.ts +63 -0
- package/dist/cjs/session/case/CaseMessages.d.ts.map +1 -0
- package/dist/cjs/session/case/CaseMessages.js +78 -0
- package/dist/cjs/session/case/CaseMessenger.d.ts +62 -0
- package/dist/cjs/session/case/CaseMessenger.d.ts.map +1 -0
- package/dist/cjs/session/case/CaseMessenger.js +62 -0
- package/dist/cjs/session/case/CaseServer.d.ts +14 -0
- package/dist/cjs/session/case/CaseServer.d.ts.map +1 -0
- package/dist/cjs/session/case/CaseServer.js +115 -0
- package/dist/cjs/session/index.d.ts +18 -0
- package/dist/cjs/session/index.d.ts.map +1 -0
- package/dist/cjs/session/index.js +36 -0
- package/dist/cjs/session/pase/PaseClient.d.ts +12 -0
- package/dist/cjs/session/pase/PaseClient.d.ts.map +1 -0
- package/dist/cjs/session/pase/PaseClient.js +56 -0
- package/dist/cjs/session/pase/PaseMessages.d.ts +44 -0
- package/dist/cjs/session/pase/PaseMessages.d.ts.map +1 -0
- package/dist/cjs/session/pase/PaseMessages.js +52 -0
- package/dist/cjs/session/pase/PaseMessenger.d.ts +67 -0
- package/dist/cjs/session/pase/PaseMessenger.d.ts.map +1 -0
- package/dist/cjs/session/pase/PaseMessenger.js +66 -0
- package/dist/cjs/session/pase/PaseServer.d.ts +23 -0
- package/dist/cjs/session/pase/PaseServer.d.ts.map +1 -0
- package/dist/cjs/session/pase/PaseServer.js +90 -0
- package/dist/{dts → cjs}/spec/Specifications.d.ts +2 -1
- package/dist/cjs/spec/Specifications.d.ts.map +1 -0
- package/dist/cjs/spec/Specifications.js +1 -1
- package/dist/cjs/spec/index.d.ts +7 -0
- package/dist/cjs/spec/index.d.ts.map +1 -0
- package/dist/cjs/spec/index.js +22 -0
- package/dist/cjs/storage/Storage.d.ts +13 -0
- package/dist/cjs/storage/Storage.d.ts.map +1 -0
- package/dist/cjs/storage/Storage.js +6 -0
- package/dist/cjs/storage/StorageBackendMemory.d.ts +16 -0
- package/dist/cjs/storage/StorageBackendMemory.d.ts.map +1 -0
- package/dist/cjs/storage/StorageBackendMemory.js +49 -0
- package/dist/cjs/storage/StorageContext.d.ts +16 -0
- package/dist/cjs/storage/StorageContext.d.ts.map +1 -0
- package/dist/cjs/storage/StorageContext.js +30 -0
- package/dist/cjs/storage/StorageManager.d.ts +16 -0
- package/dist/cjs/storage/StorageManager.d.ts.map +1 -0
- package/dist/cjs/storage/StorageManager.js +43 -0
- package/dist/cjs/storage/StringifyTools.d.ts +17 -0
- package/dist/cjs/storage/StringifyTools.d.ts.map +1 -0
- package/dist/cjs/storage/StringifyTools.js +48 -0
- package/dist/cjs/storage/index.d.ts +11 -0
- package/dist/cjs/storage/index.d.ts.map +1 -0
- package/dist/cjs/storage/index.js +26 -0
- package/dist/cjs/time/Time.d.ts +26 -0
- package/dist/cjs/time/Time.d.ts.map +1 -0
- package/dist/cjs/time/Time.js +16 -0
- package/dist/cjs/time/TimeFake.d.ts +20 -0
- package/dist/cjs/time/TimeFake.d.ts.map +1 -0
- package/dist/cjs/time/TimeFake.js +96 -0
- package/dist/cjs/time/index.d.ts +8 -0
- package/dist/cjs/time/index.d.ts.map +1 -0
- package/dist/cjs/time/index.js +23 -0
- package/dist/{dts → cjs}/tlv/TlvAny.d.ts +2 -1
- package/dist/cjs/tlv/TlvAny.d.ts.map +1 -0
- package/dist/cjs/tlv/TlvAny.js +1 -1
- package/dist/{dts → cjs}/tlv/TlvArray.d.ts +2 -1
- package/dist/cjs/tlv/TlvArray.d.ts.map +1 -0
- package/dist/cjs/tlv/TlvArray.js +1 -1
- package/dist/{dts → cjs}/tlv/TlvBoolean.d.ts +2 -1
- package/dist/cjs/tlv/TlvBoolean.d.ts.map +1 -0
- package/dist/cjs/tlv/TlvBoolean.js +1 -1
- package/dist/{dts → cjs}/tlv/TlvCodec.d.ts +2 -1
- package/dist/cjs/tlv/TlvCodec.d.ts.map +1 -0
- package/dist/cjs/tlv/TlvCodec.js +98 -45
- package/dist/cjs/tlv/TlvNoArguments.d.ts +17 -0
- package/dist/cjs/tlv/TlvNoArguments.d.ts.map +1 -0
- package/dist/cjs/tlv/TlvNoArguments.js +24 -0
- package/dist/{dts → cjs}/tlv/TlvNullable.d.ts +3 -2
- package/dist/cjs/tlv/TlvNullable.d.ts.map +1 -0
- package/dist/cjs/tlv/TlvNullable.js +2 -2
- package/dist/{dts → cjs}/tlv/TlvNumber.d.ts +8 -2
- package/dist/cjs/tlv/TlvNumber.d.ts.map +1 -0
- package/dist/cjs/tlv/TlvNumber.js +3 -4
- package/dist/{dts → cjs}/tlv/TlvObject.d.ts +3 -2
- package/dist/cjs/tlv/TlvObject.d.ts.map +1 -0
- package/dist/cjs/tlv/TlvObject.js +2 -3
- package/dist/{dts → cjs}/tlv/TlvSchema.d.ts +3 -2
- package/dist/cjs/tlv/TlvSchema.d.ts.map +1 -0
- package/dist/cjs/tlv/TlvSchema.js +2 -2
- package/dist/{dts → cjs}/tlv/TlvString.d.ts +3 -2
- package/dist/cjs/tlv/TlvString.d.ts.map +1 -0
- package/dist/cjs/tlv/TlvString.js +4 -4
- package/dist/{dts → cjs}/tlv/TlvVoid.d.ts +2 -1
- package/dist/cjs/tlv/TlvVoid.d.ts.map +1 -0
- package/dist/cjs/tlv/TlvVoid.js +1 -1
- package/dist/{dts → cjs}/tlv/TlvWrapper.d.ts +2 -1
- package/dist/cjs/tlv/TlvWrapper.d.ts.map +1 -0
- package/dist/cjs/tlv/TlvWrapper.js +1 -1
- package/dist/cjs/tlv/index.d.ts +18 -0
- package/dist/cjs/tlv/index.d.ts.map +1 -0
- package/dist/cjs/tlv/index.js +33 -0
- package/dist/{dts → cjs}/util/ByteArray.d.ts +2 -1
- package/dist/cjs/util/ByteArray.d.ts.map +1 -0
- package/dist/cjs/util/ByteArray.js +1 -1
- package/dist/cjs/util/Cache.d.ts +20 -0
- package/dist/cjs/util/Cache.d.ts.map +1 -0
- package/dist/cjs/util/Cache.js +48 -0
- package/dist/{dts → cjs}/util/DataReader.d.ts +2 -1
- package/dist/cjs/util/DataReader.d.ts.map +1 -0
- package/dist/cjs/util/DataReader.js +1 -1
- package/dist/{dts → cjs}/util/DataWriter.d.ts +2 -1
- package/dist/cjs/util/DataWriter.d.ts.map +1 -0
- package/dist/cjs/util/DataWriter.js +1 -1
- package/dist/cjs/util/Ip.d.ts +11 -0
- package/dist/cjs/util/Ip.d.ts.map +1 -0
- package/dist/cjs/util/Ip.js +69 -0
- package/dist/{dts → cjs}/util/Number.d.ts +2 -1
- package/dist/cjs/util/Number.d.ts.map +1 -0
- package/dist/cjs/util/Number.js +1 -1
- package/dist/cjs/util/Promises.d.ts +14 -0
- package/dist/cjs/util/Promises.d.ts.map +1 -0
- package/dist/cjs/util/Promises.js +30 -0
- package/dist/cjs/util/Queue.d.ts +17 -0
- package/dist/cjs/util/Queue.d.ts.map +1 -0
- package/dist/cjs/util/Queue.js +61 -0
- package/dist/cjs/util/Singleton.d.ts +7 -0
- package/dist/cjs/util/Singleton.d.ts.map +1 -0
- package/dist/cjs/util/Singleton.js +17 -0
- package/dist/cjs/util/Stream.d.ts +13 -0
- package/dist/cjs/util/Stream.d.ts.map +1 -0
- package/dist/cjs/util/Stream.js +12 -0
- package/dist/cjs/util/String.d.ts +7 -0
- package/dist/cjs/util/String.d.ts.map +1 -0
- package/dist/cjs/util/String.js +12 -0
- package/dist/{dts → cjs}/util/Type.d.ts +6 -1
- package/dist/cjs/util/Type.d.ts.map +1 -0
- package/dist/cjs/util/Type.js +1 -1
- package/dist/cjs/util/index.d.ts +18 -0
- package/dist/cjs/util/index.d.ts.map +1 -0
- package/dist/cjs/util/index.js +33 -0
- package/dist/es/MatterController.d.ts +46 -0
- package/dist/es/MatterController.d.ts.map +1 -0
- package/dist/es/MatterController.js +207 -0
- package/dist/es/MatterDevice.d.ts +64 -0
- package/dist/es/MatterDevice.d.ts.map +1 -0
- package/dist/es/MatterDevice.js +194 -0
- package/dist/es/certificate/AttestationCertificateManager.d.ts +28 -0
- package/dist/es/certificate/AttestationCertificateManager.d.ts.map +1 -0
- package/dist/es/certificate/AttestationCertificateManager.js +142 -0
- package/dist/es/certificate/CertificateManager.d.ts +202 -0
- package/dist/es/certificate/CertificateManager.d.ts.map +1 -0
- package/dist/es/certificate/CertificateManager.js +332 -0
- package/dist/es/certificate/CertificationDeclarationManager.d.ts +5 -0
- package/dist/es/certificate/CertificationDeclarationManager.d.ts.map +1 -0
- package/dist/es/certificate/CertificationDeclarationManager.js +26 -0
- package/dist/es/certificate/ChipPAAuthorities.d.ts +9 -0
- package/dist/es/certificate/ChipPAAuthorities.d.ts.map +1 -0
- package/dist/es/certificate/ChipPAAuthorities.js +17 -0
- package/dist/es/certificate/RootCertificateManager.d.ts +20 -0
- package/dist/es/certificate/RootCertificateManager.d.ts.map +1 -0
- package/dist/es/certificate/RootCertificateManager.js +94 -0
- package/dist/es/certificate/index.d.ts +11 -0
- package/dist/es/certificate/index.d.ts.map +1 -0
- package/dist/es/certificate/index.js +10 -0
- package/dist/es/cluster/AccessControlCluster.d.ts +113 -0
- package/dist/es/cluster/AccessControlCluster.d.ts.map +1 -0
- package/dist/es/cluster/AccessControlCluster.js +12 -12
- package/dist/es/cluster/ActionsCluster.d.ts +206 -0
- package/dist/es/cluster/ActionsCluster.d.ts.map +1 -0
- package/dist/es/cluster/ActionsCluster.js +222 -0
- package/dist/es/cluster/AdminCommissioningCluster.d.ts +63 -0
- package/dist/es/cluster/AdminCommissioningCluster.d.ts.map +1 -0
- package/dist/es/cluster/AdminCommissioningCluster.js +66 -0
- package/dist/es/cluster/BasicInformationCluster.d.ts +62 -0
- package/dist/es/cluster/BasicInformationCluster.d.ts.map +1 -0
- package/dist/es/cluster/BasicInformationCluster.js +10 -10
- package/dist/es/cluster/BindingCluster.d.ts +28 -0
- package/dist/es/cluster/BindingCluster.d.ts.map +1 -0
- package/dist/es/cluster/BindingCluster.js +6 -6
- package/dist/es/cluster/BooleanStateCluster.d.ts +26 -0
- package/dist/es/cluster/BooleanStateCluster.d.ts.map +1 -0
- package/dist/es/cluster/BooleanStateCluster.js +31 -0
- package/dist/es/cluster/BridgedDeviceBasicInformationCluster.d.ts +58 -0
- package/dist/es/cluster/BridgedDeviceBasicInformationCluster.d.ts.map +1 -0
- package/dist/es/cluster/BridgedDeviceBasicInformationCluster.js +8 -8
- package/dist/es/cluster/Cluster.d.ts +124 -0
- package/dist/es/cluster/Cluster.d.ts.map +1 -0
- package/dist/es/cluster/Cluster.js +16 -12
- package/dist/es/cluster/ClusterHelper.d.ts +1083 -0
- package/dist/es/cluster/ClusterHelper.d.ts.map +1 -0
- package/dist/es/cluster/ClusterHelper.js +81 -0
- package/dist/es/cluster/DescriptorCluster.d.ts +30 -0
- package/dist/es/cluster/DescriptorCluster.d.ts.map +1 -0
- package/dist/es/cluster/DescriptorCluster.js +5 -5
- package/dist/es/cluster/FlowMeasurementCluster.d.ts +24 -0
- package/dist/es/cluster/FlowMeasurementCluster.d.ts.map +1 -0
- package/dist/es/cluster/FlowMeasurementCluster.js +28 -0
- package/dist/es/cluster/GeneralCommissioningCluster.d.ts +99 -0
- package/dist/es/cluster/GeneralCommissioningCluster.d.ts.map +1 -0
- package/dist/es/cluster/GeneralCommissioningCluster.js +8 -7
- package/dist/es/cluster/GeneralDiagnosticsCluster.d.ts +116 -0
- package/dist/es/cluster/GeneralDiagnosticsCluster.d.ts.map +1 -0
- package/dist/es/cluster/GeneralDiagnosticsCluster.js +126 -0
- package/dist/es/cluster/GroupKeyManagementCluster.d.ts +91 -0
- package/dist/es/cluster/GroupKeyManagementCluster.d.ts.map +1 -0
- package/dist/es/cluster/GroupKeyManagementCluster.js +95 -0
- package/dist/es/cluster/GroupsCluster.d.ts +87 -0
- package/dist/es/cluster/GroupsCluster.d.ts.map +1 -0
- package/dist/es/cluster/GroupsCluster.js +6 -23
- package/dist/es/cluster/IdentifyCluster.d.ts +67 -0
- package/dist/es/cluster/IdentifyCluster.d.ts.map +1 -0
- package/dist/es/cluster/IdentifyCluster.js +11 -5
- package/dist/es/cluster/IlluminanceMeasurementCluster.d.ts +25 -0
- package/dist/es/cluster/IlluminanceMeasurementCluster.d.ts.map +1 -0
- package/dist/es/cluster/IlluminanceMeasurementCluster.js +30 -0
- package/dist/es/cluster/LabelCluster.d.ts +43 -0
- package/dist/es/cluster/LabelCluster.d.ts.map +1 -0
- package/dist/es/cluster/LabelCluster.js +5 -5
- package/dist/es/cluster/LevelControlCluster.d.ts +379 -0
- package/dist/es/cluster/LevelControlCluster.d.ts.map +1 -0
- package/dist/es/cluster/LevelControlCluster.js +135 -0
- package/dist/es/cluster/NetworkCommissioningCluster.d.ts +170 -0
- package/dist/es/cluster/NetworkCommissioningCluster.d.ts.map +1 -0
- package/dist/es/cluster/NetworkCommissioningCluster.js +175 -0
- package/dist/es/cluster/OccupancySensingCluster.d.ts +56 -0
- package/dist/es/cluster/OccupancySensingCluster.d.ts.map +1 -0
- package/dist/es/cluster/OccupancySensingCluster.js +59 -0
- package/dist/es/cluster/OnOffCluster.d.ts +90 -0
- package/dist/es/cluster/OnOffCluster.d.ts.map +1 -0
- package/dist/es/cluster/OnOffCluster.js +42 -20
- package/dist/es/cluster/OperationalCredentialsCluster.d.ts +163 -0
- package/dist/es/cluster/OperationalCredentialsCluster.d.ts.map +1 -0
- package/dist/es/cluster/OperationalCredentialsCluster.js +70 -56
- package/dist/es/cluster/PowerSourceCluster.d.ts +301 -0
- package/dist/es/cluster/PowerSourceCluster.d.ts.map +1 -0
- package/dist/es/cluster/PowerSourceCluster.js +129 -0
- package/dist/es/cluster/PowerSourceConfigurationCluster.d.ts +26 -0
- package/dist/es/cluster/PowerSourceConfigurationCluster.d.ts.map +1 -0
- package/dist/es/cluster/PowerSourceConfigurationCluster.js +28 -0
- package/dist/es/cluster/PressureMeasurementCluster.d.ts +36 -0
- package/dist/es/cluster/PressureMeasurementCluster.d.ts.map +1 -0
- package/dist/es/cluster/PressureMeasurementCluster.js +61 -0
- package/dist/es/cluster/ScenesCluster.d.ts +205 -0
- package/dist/es/cluster/ScenesCluster.d.ts.map +1 -0
- package/dist/es/cluster/ScenesCluster.js +10 -10
- package/dist/es/cluster/TemperatureMeasurementCluster.d.ts +24 -0
- package/dist/es/cluster/TemperatureMeasurementCluster.d.ts.map +1 -0
- package/dist/es/cluster/TemperatureMeasurementCluster.js +28 -0
- package/dist/es/cluster/WaterContentMeasurementCluster.d.ts +58 -0
- package/dist/es/cluster/WaterContentMeasurementCluster.d.ts.map +1 -0
- package/dist/es/cluster/WaterContentMeasurementCluster.js +55 -0
- package/dist/es/cluster/client/ClusterClient.d.ts +28 -0
- package/dist/es/cluster/client/ClusterClient.d.ts.map +1 -0
- package/dist/es/cluster/client/ClusterClient.js +1 -0
- package/dist/es/cluster/index.d.ts +46 -0
- package/dist/es/cluster/index.d.ts.map +1 -0
- package/dist/es/cluster/index.js +50 -0
- package/dist/es/cluster/server/AdminCommissioningServer.d.ts +10 -0
- package/dist/es/cluster/server/AdminCommissioningServer.d.ts.map +1 -0
- package/dist/es/cluster/server/AdminCommissioningServer.js +35 -0
- package/dist/es/cluster/server/AttributeServer.d.ts +43 -0
- package/dist/es/cluster/server/AttributeServer.d.ts.map +1 -0
- package/dist/es/cluster/server/AttributeServer.js +76 -0
- package/dist/es/cluster/server/ClusterServer.d.ts +62 -0
- package/dist/es/cluster/server/ClusterServer.d.ts.map +1 -0
- package/dist/es/cluster/server/ClusterServer.js +15 -0
- package/dist/es/cluster/server/CommandServer.d.ts +25 -0
- package/dist/es/cluster/server/CommandServer.d.ts.map +1 -0
- package/dist/es/cluster/server/CommandServer.js +35 -0
- package/dist/es/cluster/server/GeneralCommissioningServer.d.ts +9 -0
- package/dist/es/cluster/server/GeneralCommissioningServer.d.ts.map +1 -0
- package/dist/es/cluster/server/GeneralCommissioningServer.js +66 -0
- package/dist/es/cluster/server/GroupsServer.d.ts +9 -0
- package/dist/es/cluster/server/GroupsServer.d.ts.map +1 -0
- package/dist/es/cluster/server/GroupsServer.js +145 -0
- package/dist/es/cluster/server/LevelControlServer.d.ts +9 -0
- package/dist/es/cluster/server/LevelControlServer.d.ts.map +1 -0
- package/dist/es/cluster/server/LevelControlServer.js +54 -0
- package/dist/es/cluster/server/NetworkCommissioningServer.d.ts +9 -0
- package/dist/es/cluster/server/NetworkCommissioningServer.d.ts.map +1 -0
- package/dist/es/cluster/server/NetworkCommissioningServer.js +36 -0
- package/dist/es/cluster/server/OnOffServer.d.ts +9 -0
- package/dist/es/cluster/server/OnOffServer.d.ts.map +1 -0
- package/dist/es/cluster/server/OnOffServer.js +43 -0
- package/dist/es/cluster/server/OperationalCredentialsServer.d.ts +16 -0
- package/dist/es/cluster/server/OperationalCredentialsServer.d.ts.map +1 -0
- package/dist/es/cluster/server/OperationalCredentialsServer.js +103 -0
- package/dist/es/codec/DerCodec.d.ts +82 -0
- package/dist/es/codec/DerCodec.d.ts.map +1 -0
- package/dist/es/codec/DerCodec.js +159 -0
- package/dist/es/codec/DnsCodec.d.ts +71 -0
- package/dist/es/codec/DnsCodec.d.ts.map +1 -0
- package/dist/es/codec/DnsCodec.js +240 -0
- package/dist/es/codec/MessageCodec.d.ts +48 -0
- package/dist/es/codec/MessageCodec.d.ts.map +1 -0
- package/dist/es/codec/MessageCodec.js +113 -0
- package/dist/es/codec/index.d.ts +9 -0
- package/dist/es/codec/index.d.ts.map +1 -0
- package/dist/es/codec/index.js +8 -0
- package/dist/es/common/Broadcaster.d.ts +14 -0
- package/dist/es/common/Broadcaster.d.ts.map +1 -0
- package/dist/es/common/Broadcaster.js +6 -0
- package/dist/es/common/DeviceTypes.d.ts +73 -0
- package/dist/es/common/DeviceTypes.d.ts.map +1 -0
- package/dist/es/common/DeviceTypes.js +971 -0
- package/dist/es/common/MatterError.d.ts +9 -0
- package/dist/es/common/MatterError.d.ts.map +1 -0
- package/dist/es/common/MatterError.js +8 -0
- package/dist/es/common/Scanner.d.ts +16 -0
- package/dist/es/common/Scanner.d.ts.map +1 -0
- package/dist/es/common/Scanner.js +6 -0
- package/dist/es/common/TryCatchHandler.d.ts +29 -0
- package/dist/es/common/TryCatchHandler.d.ts.map +1 -0
- package/dist/es/common/TryCatchHandler.js +61 -0
- package/dist/es/common/index.d.ts +11 -0
- package/dist/es/common/index.d.ts.map +1 -0
- package/dist/es/common/index.js +10 -0
- package/dist/es/crypto/Crypto.d.ts +69 -0
- package/dist/es/crypto/Crypto.d.ts.map +1 -0
- package/dist/es/crypto/Crypto.js +43 -0
- package/dist/es/crypto/CryptoConstants.d.ts +19 -0
- package/dist/es/crypto/CryptoConstants.d.ts.map +1 -0
- package/dist/es/crypto/CryptoConstants.js +18 -0
- package/dist/es/crypto/Spake2p.d.ts +42 -0
- package/dist/es/crypto/Spake2p.d.ts.map +1 -0
- package/dist/es/crypto/Spake2p.js +112 -0
- package/dist/es/crypto/index.d.ts +9 -0
- package/dist/es/crypto/index.d.ts.map +1 -0
- package/dist/es/crypto/index.js +8 -0
- package/dist/es/datatype/AttributeId.d.ts +18 -0
- package/dist/es/datatype/AttributeId.d.ts.map +1 -0
- package/dist/es/{common → datatype}/AttributeId.js +1 -1
- package/dist/es/datatype/ClusterId.d.ts +19 -0
- package/dist/es/datatype/ClusterId.d.ts.map +1 -0
- package/dist/es/{common → datatype}/ClusterId.js +1 -1
- package/dist/es/datatype/CommandId.d.ts +18 -0
- package/dist/es/datatype/CommandId.d.ts.map +1 -0
- package/dist/es/datatype/CommandId.js +19 -0
- package/dist/es/datatype/DeviceTypeId.d.ts +18 -0
- package/dist/es/datatype/DeviceTypeId.d.ts.map +1 -0
- package/dist/es/{common → datatype}/DeviceTypeId.js +1 -1
- package/dist/es/datatype/EndpointNumber.d.ts +18 -0
- package/dist/es/datatype/EndpointNumber.d.ts.map +1 -0
- package/dist/es/{common → datatype}/EndpointNumber.js +1 -1
- package/dist/es/datatype/EventId.d.ts +18 -0
- package/dist/es/datatype/EventId.d.ts.map +1 -0
- package/dist/es/datatype/EventId.js +19 -0
- package/dist/es/datatype/FabricId.d.ts +19 -0
- package/dist/es/datatype/FabricId.d.ts.map +1 -0
- package/dist/es/{common → datatype}/FabricId.js +1 -1
- package/dist/es/datatype/FabricIndex.d.ts +24 -0
- package/dist/es/datatype/FabricIndex.d.ts.map +1 -0
- package/dist/es/{common → datatype}/FabricIndex.js +3 -2
- package/dist/es/datatype/GroupId.d.ts +25 -0
- package/dist/es/datatype/GroupId.d.ts.map +1 -0
- package/dist/es/{common → datatype}/GroupId.js +1 -1
- package/dist/es/datatype/NodeId.d.ts +22 -0
- package/dist/es/datatype/NodeId.d.ts.map +1 -0
- package/dist/es/{common → datatype}/NodeId.js +19 -2
- package/dist/es/datatype/SubjectId.d.ts +16 -0
- package/dist/es/datatype/SubjectId.d.ts.map +1 -0
- package/dist/es/{common → datatype}/SubjectId.js +1 -1
- package/dist/es/datatype/VendorId.d.ts +20 -0
- package/dist/es/datatype/VendorId.d.ts.map +1 -0
- package/dist/es/{common → datatype}/VendorId.js +1 -1
- package/dist/es/datatype/index.d.ts +18 -0
- package/dist/es/datatype/index.d.ts.map +1 -0
- package/dist/es/datatype/index.js +18 -0
- package/dist/es/fabric/Fabric.d.ts +95 -0
- package/dist/es/fabric/Fabric.d.ts.map +1 -0
- package/dist/es/fabric/Fabric.js +205 -0
- package/dist/es/fabric/FabricManager.d.ts +30 -0
- package/dist/es/fabric/FabricManager.d.ts.map +1 -0
- package/dist/es/fabric/FabricManager.js +80 -0
- package/dist/es/fabric/index.d.ts +8 -0
- package/dist/es/fabric/index.d.ts.map +1 -0
- package/dist/es/fabric/index.js +7 -0
- package/dist/es/index.d.ts +9 -0
- package/dist/es/index.d.ts.map +1 -0
- package/dist/es/index.js +10 -0
- package/dist/es/log/Logger.d.ts +45 -0
- package/dist/es/log/Logger.d.ts.map +1 -0
- package/dist/es/log/Logger.js +88 -0
- package/dist/es/log/index.d.ts +7 -0
- package/dist/es/log/index.d.ts.map +1 -0
- package/dist/es/log/index.js +6 -0
- package/dist/es/math/ReedSolomon.d.ts +12 -0
- package/dist/es/math/ReedSolomon.d.ts.map +1 -0
- package/dist/es/math/ReedSolomon.js +92 -0
- package/dist/es/math/Verhoeff.d.ts +17 -0
- package/dist/es/math/Verhoeff.d.ts.map +1 -0
- package/dist/es/math/Verhoeff.js +47 -0
- package/dist/es/math/index.d.ts +8 -0
- package/dist/es/math/index.d.ts.map +1 -0
- package/dist/es/math/index.js +7 -0
- package/dist/es/mdns/MdnsBroadcaster.d.ts +21 -0
- package/dist/es/mdns/MdnsBroadcaster.d.ts.map +1 -0
- package/dist/es/mdns/MdnsBroadcaster.js +133 -0
- package/dist/es/mdns/MdnsConsts.d.ts +11 -0
- package/dist/es/mdns/MdnsConsts.d.ts.map +1 -0
- package/dist/es/mdns/MdnsConsts.js +10 -0
- package/dist/es/mdns/MdnsScanner.d.ts +22 -0
- package/dist/es/mdns/MdnsScanner.d.ts.map +1 -0
- package/dist/es/mdns/MdnsScanner.js +94 -0
- package/dist/es/mdns/MdnsServer.d.ts +26 -0
- package/dist/es/mdns/MdnsServer.d.ts.map +1 -0
- package/dist/es/mdns/MdnsServer.js +92 -0
- package/dist/es/mdns/index.d.ts +10 -0
- package/dist/es/mdns/index.d.ts.map +1 -0
- package/dist/es/mdns/index.js +9 -0
- package/dist/es/net/Channel.d.ts +10 -0
- package/dist/es/net/Channel.d.ts.map +1 -0
- package/dist/es/net/Channel.js +6 -0
- package/dist/es/net/NetInterface.d.ts +15 -0
- package/dist/es/net/NetInterface.d.ts.map +1 -0
- package/dist/es/net/NetInterface.js +6 -0
- package/dist/es/net/Network.d.ts +16 -0
- package/dist/es/net/Network.d.ts.map +1 -0
- package/dist/es/net/Network.js +8 -0
- package/dist/es/net/UdpChannel.d.ts +19 -0
- package/dist/es/net/UdpChannel.d.ts.map +1 -0
- package/dist/es/net/UdpChannel.js +6 -0
- package/dist/es/net/UdpInterface.d.ts +26 -0
- package/dist/es/net/UdpInterface.d.ts.map +1 -0
- package/dist/es/net/UdpInterface.js +46 -0
- package/dist/es/net/UdpMulticastServer.d.ts +29 -0
- package/dist/es/net/UdpMulticastServer.d.ts.map +1 -0
- package/dist/es/net/UdpMulticastServer.js +70 -0
- package/dist/es/net/fake/NetworkFake.d.ts +19 -0
- package/dist/es/net/fake/NetworkFake.d.ts.map +1 -0
- package/dist/es/net/fake/NetworkFake.js +24 -0
- package/dist/es/net/fake/SimulatedNetwork.d.ts +17 -0
- package/dist/es/net/fake/SimulatedNetwork.d.ts.map +1 -0
- package/dist/es/net/fake/SimulatedNetwork.js +52 -0
- package/dist/es/net/fake/UdpChannelFake.d.ts +22 -0
- package/dist/es/net/fake/UdpChannelFake.d.ts.map +1 -0
- package/dist/es/net/fake/UdpChannelFake.js +49 -0
- package/dist/es/net/index.d.ts +15 -0
- package/dist/es/net/index.d.ts.map +1 -0
- package/dist/es/net/index.js +14 -0
- package/dist/es/protocol/ChannelManager.d.ts +23 -0
- package/dist/es/protocol/ChannelManager.d.ts.map +1 -0
- package/dist/es/protocol/ChannelManager.js +44 -0
- package/dist/es/protocol/ExchangeManager.d.ts +58 -0
- package/dist/es/protocol/ExchangeManager.d.ts.map +1 -0
- package/dist/es/protocol/ExchangeManager.js +142 -0
- package/dist/es/protocol/MessageExchange.d.ts +51 -0
- package/dist/es/protocol/MessageExchange.d.ts.map +1 -0
- package/dist/es/protocol/MessageExchange.js +234 -0
- package/dist/es/protocol/ProtocolHandler.d.ts +12 -0
- package/dist/es/protocol/ProtocolHandler.d.ts.map +1 -0
- package/dist/es/protocol/ProtocolHandler.js +6 -0
- package/dist/es/protocol/index.d.ts +10 -0
- package/dist/es/protocol/index.d.ts.map +1 -0
- package/dist/es/protocol/index.js +9 -0
- package/dist/es/protocol/interaction/AttributeDataDecoder.d.ts +39 -0
- package/dist/es/protocol/interaction/AttributeDataDecoder.d.ts.map +1 -0
- package/dist/es/protocol/interaction/AttributeDataDecoder.js +134 -0
- package/dist/es/protocol/interaction/InteractionClient.d.ts +63 -0
- package/dist/es/protocol/interaction/InteractionClient.d.ts.map +1 -0
- package/dist/es/protocol/interaction/InteractionClient.js +279 -0
- package/dist/es/protocol/interaction/InteractionMessenger.d.ts +250 -0
- package/dist/es/protocol/interaction/InteractionMessenger.d.ts.map +1 -0
- package/dist/es/protocol/interaction/InteractionMessenger.js +290 -0
- package/dist/es/protocol/interaction/InteractionProtocol.d.ts +484 -0
- package/dist/es/protocol/interaction/InteractionProtocol.d.ts.map +1 -0
- package/dist/es/protocol/interaction/InteractionProtocol.js +186 -0
- package/dist/es/protocol/interaction/InteractionServer.d.ts +71 -0
- package/dist/es/protocol/interaction/InteractionServer.d.ts.map +1 -0
- package/dist/es/protocol/interaction/InteractionServer.js +362 -0
- package/dist/es/protocol/interaction/SubscriptionHandler.d.ts +38 -0
- package/dist/es/protocol/interaction/SubscriptionHandler.d.ts.map +1 -0
- package/dist/es/protocol/interaction/SubscriptionHandler.js +170 -0
- package/dist/es/protocol/interaction/index.d.ts +12 -0
- package/dist/es/protocol/interaction/index.d.ts.map +1 -0
- package/dist/es/protocol/interaction/index.js +13 -0
- package/dist/es/protocol/securechannel/SecureChannelMessages.d.ts +63 -0
- package/dist/es/protocol/securechannel/SecureChannelMessages.d.ts.map +1 -0
- package/dist/es/protocol/securechannel/SecureChannelMessages.js +6 -0
- package/dist/es/protocol/securechannel/SecureChannelMessenger.d.ts +31 -0
- package/dist/es/protocol/securechannel/SecureChannelMessenger.d.ts.map +1 -0
- package/dist/es/protocol/securechannel/SecureChannelMessenger.js +91 -0
- package/dist/es/protocol/securechannel/SecureChannelProtocol.d.ts +21 -0
- package/dist/es/protocol/securechannel/SecureChannelProtocol.d.ts.map +1 -0
- package/dist/es/protocol/securechannel/SecureChannelProtocol.js +45 -0
- package/dist/es/protocol/securechannel/SecureChannelStatusMessageSchema.d.ts +23 -0
- package/dist/es/protocol/securechannel/SecureChannelStatusMessageSchema.d.ts.map +1 -0
- package/dist/es/protocol/securechannel/SecureChannelStatusMessageSchema.js +26 -0
- package/dist/es/protocol/securechannel/index.d.ts +10 -0
- package/dist/es/protocol/securechannel/index.d.ts.map +1 -0
- package/dist/es/protocol/securechannel/index.js +10 -0
- package/dist/es/schema/Base38Schema.d.ts +17 -0
- package/dist/es/schema/Base38Schema.d.ts.map +1 -0
- package/dist/es/schema/Base38Schema.js +93 -0
- package/dist/es/schema/BitmapSchema.d.ts +62 -0
- package/dist/es/schema/BitmapSchema.d.ts.map +1 -0
- package/dist/es/schema/BitmapSchema.js +26 -18
- package/dist/es/schema/PairingCodeSchema.d.ts +55 -0
- package/dist/es/schema/PairingCodeSchema.d.ts.map +1 -0
- package/dist/es/schema/PairingCodeSchema.js +70 -0
- package/dist/es/schema/QrCodeSchema.d.ts +13 -0
- package/dist/es/schema/QrCodeSchema.d.ts.map +1 -0
- package/dist/es/schema/QrCodeSchema.js +199 -0
- package/dist/es/schema/Schema.d.ts +17 -0
- package/dist/es/schema/Schema.d.ts.map +1 -0
- package/dist/es/schema/Schema.js +2 -1
- package/dist/es/schema/index.d.ts +11 -0
- package/dist/es/schema/index.d.ts.map +1 -0
- package/dist/es/schema/index.js +11 -0
- package/dist/es/session/SecureSession.d.ts +53 -0
- package/dist/es/session/SecureSession.d.ts.map +1 -0
- package/dist/es/session/SecureSession.js +131 -0
- package/dist/es/session/Session.d.ts +38 -0
- package/dist/es/session/Session.d.ts.map +1 -0
- package/dist/es/session/Session.js +14 -0
- package/dist/es/session/SessionManager.d.ts +41 -0
- package/dist/es/session/SessionManager.d.ts.map +1 -0
- package/dist/es/session/SessionManager.js +107 -0
- package/dist/es/session/UnsecureSession.d.ts +35 -0
- package/dist/es/session/UnsecureSession.d.ts.map +1 -0
- package/dist/es/session/UnsecureSession.js +64 -0
- package/dist/es/session/case/CaseClient.d.ts +13 -0
- package/dist/es/session/case/CaseClient.d.ts.map +1 -0
- package/dist/es/session/case/CaseClient.js +93 -0
- package/dist/es/session/case/CaseMessages.d.ts +63 -0
- package/dist/es/session/case/CaseMessages.d.ts.map +1 -0
- package/dist/es/session/case/CaseMessages.js +75 -0
- package/dist/es/session/case/CaseMessenger.d.ts +62 -0
- package/dist/es/session/case/CaseMessenger.d.ts.map +1 -0
- package/dist/es/session/case/CaseMessenger.js +57 -0
- package/dist/es/session/case/CaseServer.d.ts +14 -0
- package/dist/es/session/case/CaseServer.d.ts.map +1 -0
- package/dist/es/session/case/CaseServer.js +111 -0
- package/dist/es/session/index.d.ts +18 -0
- package/dist/es/session/index.d.ts.map +1 -0
- package/dist/es/session/index.js +20 -0
- package/dist/es/session/pase/PaseClient.d.ts +12 -0
- package/dist/es/session/pase/PaseClient.d.ts.map +1 -0
- package/dist/es/session/pase/PaseClient.js +52 -0
- package/dist/es/session/pase/PaseMessages.d.ts +44 -0
- package/dist/es/session/pase/PaseMessages.d.ts.map +1 -0
- package/dist/es/session/pase/PaseMessages.js +49 -0
- package/dist/es/session/pase/PaseMessenger.d.ts +67 -0
- package/dist/es/session/pase/PaseMessenger.d.ts.map +1 -0
- package/dist/es/session/pase/PaseMessenger.js +61 -0
- package/dist/es/session/pase/PaseServer.d.ts +23 -0
- package/dist/es/session/pase/PaseServer.d.ts.map +1 -0
- package/dist/es/session/pase/PaseServer.js +83 -0
- package/dist/es/spec/Specifications.d.ts +15 -0
- package/dist/es/spec/Specifications.d.ts.map +1 -0
- package/dist/es/spec/Specifications.js +1 -1
- package/dist/es/spec/index.d.ts +7 -0
- package/dist/es/spec/index.d.ts.map +1 -0
- package/dist/es/spec/index.js +6 -0
- package/dist/es/storage/Storage.d.ts +13 -0
- package/dist/es/storage/Storage.d.ts.map +1 -0
- package/dist/es/storage/Storage.js +2 -0
- package/dist/es/storage/StorageBackendMemory.d.ts +16 -0
- package/dist/es/storage/StorageBackendMemory.d.ts.map +1 -0
- package/dist/es/storage/StorageBackendMemory.js +45 -0
- package/dist/es/storage/StorageContext.d.ts +16 -0
- package/dist/es/storage/StorageContext.d.ts.map +1 -0
- package/dist/es/storage/StorageContext.js +26 -0
- package/dist/es/storage/StorageManager.d.ts +16 -0
- package/dist/es/storage/StorageManager.d.ts.map +1 -0
- package/dist/es/storage/StorageManager.js +39 -0
- package/dist/es/storage/StringifyTools.d.ts +17 -0
- package/dist/es/storage/StringifyTools.d.ts.map +1 -0
- package/dist/es/storage/StringifyTools.js +43 -0
- package/dist/es/storage/index.d.ts +11 -0
- package/dist/es/storage/index.d.ts.map +1 -0
- package/dist/es/storage/index.js +10 -0
- package/dist/es/time/Time.d.ts +26 -0
- package/dist/es/time/Time.d.ts.map +1 -0
- package/dist/es/time/Time.js +12 -0
- package/dist/es/time/TimeFake.d.ts +20 -0
- package/dist/es/time/TimeFake.d.ts.map +1 -0
- package/dist/es/time/TimeFake.js +92 -0
- package/dist/es/time/index.d.ts +8 -0
- package/dist/es/time/index.d.ts.map +1 -0
- package/dist/es/time/index.js +7 -0
- package/dist/es/tlv/TlvAny.d.ts +15 -0
- package/dist/es/tlv/TlvAny.d.ts.map +1 -0
- package/dist/es/tlv/TlvAny.js +1 -1
- package/dist/es/tlv/TlvArray.d.ts +30 -0
- package/dist/es/tlv/TlvArray.d.ts.map +1 -0
- package/dist/es/tlv/TlvArray.js +1 -1
- package/dist/es/tlv/TlvBoolean.d.ts +20 -0
- package/dist/es/tlv/TlvBoolean.d.ts.map +1 -0
- package/dist/es/tlv/TlvBoolean.js +1 -1
- package/dist/es/tlv/TlvCodec.d.ts +99 -0
- package/dist/es/tlv/TlvCodec.d.ts.map +1 -0
- package/dist/es/tlv/TlvCodec.js +98 -45
- package/dist/es/tlv/TlvNoArguments.d.ts +17 -0
- package/dist/es/tlv/TlvNoArguments.d.ts.map +1 -0
- package/dist/es/tlv/TlvNoArguments.js +20 -0
- package/dist/es/tlv/TlvNullable.d.ts +22 -0
- package/dist/es/tlv/TlvNullable.d.ts.map +1 -0
- package/dist/es/tlv/TlvNullable.js +2 -2
- package/dist/es/tlv/TlvNumber.d.ts +54 -0
- package/dist/es/tlv/TlvNumber.d.ts.map +1 -0
- package/dist/es/tlv/TlvNumber.js +3 -4
- package/dist/es/tlv/TlvObject.d.ts +62 -0
- package/dist/es/tlv/TlvObject.d.ts.map +1 -0
- package/dist/es/tlv/TlvObject.js +2 -3
- package/dist/es/tlv/TlvSchema.d.ts +68 -0
- package/dist/es/tlv/TlvSchema.d.ts.map +1 -0
- package/dist/es/tlv/TlvSchema.js +2 -2
- package/dist/es/tlv/TlvString.d.ts +39 -0
- package/dist/es/tlv/TlvString.d.ts.map +1 -0
- package/dist/es/tlv/TlvString.js +3 -3
- package/dist/es/tlv/TlvVoid.d.ts +19 -0
- package/dist/es/tlv/TlvVoid.d.ts.map +1 -0
- package/dist/es/tlv/TlvVoid.js +1 -1
- package/dist/es/tlv/TlvWrapper.d.ts +17 -0
- package/dist/es/tlv/TlvWrapper.d.ts.map +1 -0
- package/dist/es/tlv/TlvWrapper.js +1 -1
- package/dist/es/tlv/index.d.ts +18 -0
- package/dist/es/tlv/index.d.ts.map +1 -0
- package/dist/es/tlv/index.js +17 -0
- package/dist/es/util/ByteArray.d.ts +31 -0
- package/dist/es/util/ByteArray.d.ts.map +1 -0
- package/dist/es/util/ByteArray.js +2 -2
- package/dist/es/util/Cache.d.ts +20 -0
- package/dist/es/util/Cache.d.ts.map +1 -0
- package/dist/es/util/Cache.js +44 -0
- package/dist/es/util/DataReader.d.ts +30 -0
- package/dist/es/util/DataReader.d.ts.map +1 -0
- package/dist/es/util/DataReader.js +1 -1
- package/dist/es/util/DataWriter.d.ts +27 -0
- package/dist/es/util/DataWriter.d.ts.map +1 -0
- package/dist/es/util/DataWriter.js +1 -1
- package/dist/es/util/Ip.d.ts +11 -0
- package/dist/es/util/Ip.d.ts.map +1 -0
- package/dist/es/util/Ip.js +61 -0
- package/dist/es/util/Number.d.ts +24 -0
- package/dist/es/util/Number.d.ts.map +1 -0
- package/dist/es/util/Number.js +1 -1
- package/dist/es/util/Promises.d.ts +14 -0
- package/dist/es/util/Promises.d.ts.map +1 -0
- package/dist/es/util/Promises.js +26 -0
- package/dist/es/util/Queue.d.ts +17 -0
- package/dist/es/util/Queue.d.ts.map +1 -0
- package/dist/es/util/Queue.js +57 -0
- package/dist/es/util/Singleton.d.ts +7 -0
- package/dist/es/util/Singleton.d.ts.map +1 -0
- package/dist/es/util/Singleton.js +13 -0
- package/dist/es/util/Stream.d.ts +13 -0
- package/dist/es/util/Stream.d.ts.map +1 -0
- package/dist/es/util/Stream.js +8 -0
- package/dist/es/util/String.d.ts +7 -0
- package/dist/es/util/String.d.ts.map +1 -0
- package/dist/es/util/String.js +8 -0
- package/dist/es/util/Type.d.ts +15 -0
- package/dist/es/util/Type.d.ts.map +1 -0
- package/dist/es/util/Type.js +1 -1
- package/dist/es/util/index.d.ts +18 -0
- package/dist/es/util/index.d.ts.map +1 -0
- package/dist/es/util/index.js +17 -0
- package/package.json +74 -14
- package/dist/cjs/matter.js +0 -50
- package/dist/cjs/protocol/InteractionProtocol.js +0 -136
- package/dist/dts/cluster/BindingCluster.d.ts +0 -23
- package/dist/dts/cluster/DescriptorCluster.d.ts +0 -25
- package/dist/dts/cluster/LabelCluster.d.ts +0 -34
- package/dist/dts/matter.d.ts +0 -34
- package/dist/dts/protocol/InteractionProtocol.d.ts +0 -159
- package/dist/es/matter.js +0 -34
- package/dist/es/protocol/InteractionProtocol.js +0 -133
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2022-2023 Project CHIP Authors
|
|
4
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
+
*/
|
|
6
|
+
import { MatterDevice } from "../../MatterDevice.js";
|
|
7
|
+
import { ProtocolHandler } from "../../protocol/ProtocolHandler.js";
|
|
8
|
+
import { MessageExchange } from "../../protocol/MessageExchange.js";
|
|
9
|
+
import { DataReport, InteractionServerMessenger, InvokeRequest, InvokeResponse, ReadRequest, SubscribeRequest, TimedRequest, WriteRequest, WriteResponse } from "./InteractionMessenger.js";
|
|
10
|
+
import { Attributes, Cluster, Commands, Events } from "../../cluster/Cluster.js";
|
|
11
|
+
import { TlvAttributePath } from "./InteractionProtocol.js";
|
|
12
|
+
import { BitSchema, TypeFromBitSchema } from "../../schema/BitmapSchema.js";
|
|
13
|
+
import { TypeFromSchema } from "../../tlv/TlvSchema.js";
|
|
14
|
+
import { Message } from "../../codec/MessageCodec.js";
|
|
15
|
+
import { AttributeInitialValues, AttributeServers, ClusterServerHandlers } from "../../cluster/server/ClusterServer.js";
|
|
16
|
+
import { CommandServer } from "../../cluster/server/CommandServer.js";
|
|
17
|
+
import { AttributeServer } from "../../cluster/server/AttributeServer.js";
|
|
18
|
+
import { StorageContext } from "../../storage/StorageContext.js";
|
|
19
|
+
import { StorageManager } from "../../storage/StorageManager.js";
|
|
20
|
+
export declare const INTERACTION_PROTOCOL_ID = 1;
|
|
21
|
+
export declare class ClusterServer<F extends BitSchema, A extends Attributes, C extends Commands, E extends Events> {
|
|
22
|
+
readonly id: number;
|
|
23
|
+
readonly name: string;
|
|
24
|
+
readonly attributes: AttributeServers<A>;
|
|
25
|
+
readonly commands: CommandServer<any, any>[];
|
|
26
|
+
private clusterStorage;
|
|
27
|
+
private attributeStorageListeners;
|
|
28
|
+
constructor(clusterDef: Cluster<F, A, C, E>, features: TypeFromBitSchema<F>, attributesInitialValues: AttributeInitialValues<A>, handlers: ClusterServerHandlers<Cluster<F, A, C, E>>);
|
|
29
|
+
setStorage(storageContext: StorageContext): void;
|
|
30
|
+
attributeStorageListener(attributeName: string, version: number, value: any): void;
|
|
31
|
+
}
|
|
32
|
+
export interface CommandPath {
|
|
33
|
+
endpointId: number;
|
|
34
|
+
clusterId: number;
|
|
35
|
+
commandId: number;
|
|
36
|
+
}
|
|
37
|
+
export interface AttributePath {
|
|
38
|
+
endpointId: number;
|
|
39
|
+
clusterId: number;
|
|
40
|
+
attributeId: number;
|
|
41
|
+
}
|
|
42
|
+
export interface AttributeWithPath {
|
|
43
|
+
path: TypeFromSchema<typeof TlvAttributePath>;
|
|
44
|
+
attribute: AttributeServer<any>;
|
|
45
|
+
}
|
|
46
|
+
export declare function commandPathToId({ endpointId, clusterId, commandId }: CommandPath): string;
|
|
47
|
+
export declare function attributePathToId({ endpointId, clusterId, attributeId }: TypeFromSchema<typeof TlvAttributePath>): string;
|
|
48
|
+
export declare class InteractionServer implements ProtocolHandler<MatterDevice> {
|
|
49
|
+
private readonly storageManager;
|
|
50
|
+
private readonly endpoints;
|
|
51
|
+
private readonly attributes;
|
|
52
|
+
private readonly attributePaths;
|
|
53
|
+
private readonly commands;
|
|
54
|
+
private readonly commandPaths;
|
|
55
|
+
private nextSubscriptionId;
|
|
56
|
+
constructor(storageManager: StorageManager);
|
|
57
|
+
getId(): number;
|
|
58
|
+
addEndpoint(endpointId: number, device: {
|
|
59
|
+
name: string;
|
|
60
|
+
code: number;
|
|
61
|
+
}, clusters: ClusterServer<any, any, any, any>[]): this;
|
|
62
|
+
onNewExchange(exchange: MessageExchange<MatterDevice>): Promise<void>;
|
|
63
|
+
handleReadRequest(exchange: MessageExchange<MatterDevice>, { attributeRequests: attributePaths, isFabricFiltered }: ReadRequest): DataReport;
|
|
64
|
+
handleWriteRequest(exchange: MessageExchange<MatterDevice>, { suppressResponse, writeRequests }: WriteRequest): WriteResponse;
|
|
65
|
+
handleSubscribeRequest(exchange: MessageExchange<MatterDevice>, { minIntervalFloorSeconds, maxIntervalCeilingSeconds, attributeRequests, eventRequests, keepSubscriptions }: SubscribeRequest, messenger: InteractionServerMessenger): Promise<void>;
|
|
66
|
+
handleInvokeRequest(exchange: MessageExchange<MatterDevice>, { invokeRequests }: InvokeRequest, message: Message): Promise<InvokeResponse>;
|
|
67
|
+
handleTimedRequest(exchange: MessageExchange<MatterDevice>, { timeout }: TimedRequest): void;
|
|
68
|
+
private resolveAttributeName;
|
|
69
|
+
private getAttributes;
|
|
70
|
+
}
|
|
71
|
+
//# sourceMappingURL=InteractionServer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"InteractionServer.d.ts","sourceRoot":"","sources":["../../../../src/protocol/interaction/InteractionServer.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AACrD,OAAO,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AACpE,OAAO,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AACpE,OAAO,EACH,UAAU,EACV,0BAA0B,EAC1B,aAAa,EACb,cAAc,EAEd,WAAW,EAEX,gBAAgB,EAChB,YAAY,EACZ,YAAY,EACZ,aAAa,EAChB,MAAM,2BAA2B,CAAC;AACnC,OAAO,EAAE,UAAU,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,0BAA0B,CAAC;AACjF,OAAO,EAEH,gBAAgB,EAGnB,MAAM,0BAA0B,CAAA;AACjC,OAAO,EAAE,SAAS,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAC;AAC5E,OAAO,EAAa,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAOnE,OAAO,EAAE,OAAO,EAAE,MAAM,6BAA6B,CAAC;AAGtD,OAAO,EAAE,sBAAsB,EAAE,gBAAgB,EAAE,qBAAqB,EAAE,MAAM,uCAAuC,CAAC;AACxH,OAAO,EAAE,aAAa,EAAE,MAAM,uCAAuC,CAAC;AACtE,OAAO,EAAyB,eAAe,EAAE,MAAM,yCAAyC,CAAC;AAGjG,OAAO,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AACjE,OAAO,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AAIjE,eAAO,MAAM,uBAAuB,IAAS,CAAC;AAI9C,qBAAa,aAAa,CAAC,CAAC,SAAS,SAAS,EAAE,CAAC,SAAS,UAAU,EAAE,CAAC,SAAS,QAAQ,EAAE,CAAC,SAAS,MAAM;IACtG,QAAQ,CAAC,EAAE,EAAE,MAAM,CAAC;IACpB,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,UAAU,sBAA2B;IAC9C,QAAQ,CAAC,QAAQ,4BAAwC;IACzD,OAAO,CAAC,cAAc,CAA+B;IACrD,OAAO,CAAC,yBAAyB,CAA4D;gBAEjF,UAAU,EAAE,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,QAAQ,EAAE,iBAAiB,CAAC,CAAC,CAAC,EAAE,uBAAuB,EAAE,sBAAsB,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,qBAAqB,CAAC,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;IAoCrL,UAAU,CAAC,cAAc,EAAE,cAAc;IAiBzC,wBAAwB,CAAC,aAAa,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG;CAK9E;AAED,MAAM,WAAW,WAAW;IACxB,UAAU,EAAE,MAAM,CAAC;IACnB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;CACrB;AAED,MAAM,WAAW,aAAa;IAC1B,UAAU,EAAE,MAAM,CAAC;IACnB,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,EAAE,MAAM,CAAC;CACvB;AAED,MAAM,WAAW,iBAAiB;IAC9B,IAAI,EAAE,cAAc,CAAC,OAAO,gBAAgB,CAAC,CAAC;IAC9C,SAAS,EAAE,eAAe,CAAC,GAAG,CAAC,CAAC;CACnC;AAED,wBAAgB,eAAe,CAAC,EAAE,UAAU,EAAE,SAAS,EAAE,SAAS,EAAE,EAAE,WAAW,UAEhF;AAED,wBAAgB,iBAAiB,CAAC,EAAE,UAAU,EAAE,SAAS,EAAE,WAAW,EAAE,EAAE,cAAc,CAAC,OAAO,gBAAgB,CAAC,UAEhH;AAMD,qBAAa,iBAAkB,YAAW,eAAe,CAAC,YAAY,CAAC;IAS/D,OAAO,CAAC,QAAQ,CAAC,cAAc;IARnC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAA+G;IACzI,OAAO,CAAC,QAAQ,CAAC,UAAU,CAA2C;IACtE,OAAO,CAAC,QAAQ,CAAC,cAAc,CAA8B;IAC7D,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAA8C;IACvE,OAAO,CAAC,QAAQ,CAAC,YAAY,CAA4B;IACzD,OAAO,CAAC,kBAAkB,CAA4B;gBAGjC,cAAc,EAAE,cAAc;IAGnD,KAAK;IAIL,WAAW,CAAC,UAAU,EAAE,MAAM,EAAE,MAAM,EAAE;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,EAAE,QAAQ,EAAE,aAAa,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE;IAgD/G,aAAa,CAAC,QAAQ,EAAE,eAAe,CAAC,YAAY,CAAC;IAU3D,iBAAiB,CAAC,QAAQ,EAAE,eAAe,CAAC,YAAY,CAAC,EAAE,EAAE,iBAAiB,EAAE,cAAc,EAAE,gBAAgB,EAAE,EAAE,WAAW,GAAG,UAAU;IA6B5I,kBAAkB,CAAC,QAAQ,EAAE,eAAe,CAAC,YAAY,CAAC,EAAE,EAAE,gBAAgB,EAAE,aAAa,EAAE,EAAE,YAAY,GAAG,aAAa;IA8CvH,sBAAsB,CAAC,QAAQ,EAAE,eAAe,CAAC,YAAY,CAAC,EAAE,EAAE,uBAAuB,EAAE,yBAAyB,EAAE,iBAAiB,EAAE,aAAa,EAAE,iBAAiB,EAAE,EAAE,gBAAgB,EAAE,SAAS,EAAE,0BAA0B,GAAG,OAAO,CAAC,IAAI,CAAC;IAkDpP,mBAAmB,CAAC,QAAQ,EAAE,eAAe,CAAC,YAAY,CAAC,EAAE,EAAE,cAAc,EAAE,EAAE,aAAa,EAAE,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,cAAc,CAAC;IAoChJ,kBAAkB,CAAC,QAAQ,EAAE,eAAe,CAAC,YAAY,CAAC,EAAE,EAAE,OAAO,EAAE,EAAE,YAAY;IAKrF,OAAO,CAAC,oBAAoB;IA2B5B,OAAO,CAAC,aAAa;CA0BxB"}
|
|
@@ -0,0 +1,362 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2022-2023 Project CHIP Authors
|
|
4
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
+
*/
|
|
6
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
7
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
8
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
9
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
10
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
11
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
12
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
13
|
+
});
|
|
14
|
+
};
|
|
15
|
+
import { InteractionServerMessenger, StatusResponseError } from "./InteractionMessenger.js";
|
|
16
|
+
import { TlvSubscribeResponse } from "./InteractionProtocol.js";
|
|
17
|
+
import { TlvNoArguments } from "../../tlv/TlvNoArguments.js";
|
|
18
|
+
import { DeviceTypeId } from "../../datatype/DeviceTypeId.js";
|
|
19
|
+
import { ClusterId } from "../../datatype/ClusterId.js";
|
|
20
|
+
import { EndpointNumber } from "../../datatype/EndpointNumber.js";
|
|
21
|
+
import { SubscriptionHandler } from "./SubscriptionHandler.js";
|
|
22
|
+
import { Crypto } from "../../crypto/Crypto.js";
|
|
23
|
+
import { decodeValueForSchema, normalizeAttributeData } from "./AttributeDataDecoder.js";
|
|
24
|
+
import { CommandServer } from "../../cluster/server/CommandServer.js";
|
|
25
|
+
import { AttributeGetterServer, AttributeServer } from "../../cluster/server/AttributeServer.js";
|
|
26
|
+
import { DescriptorCluster } from "../../cluster/DescriptorCluster.js";
|
|
27
|
+
import { Logger } from "../../log/Logger.js";
|
|
28
|
+
import { capitalize } from "../../util/String.js";
|
|
29
|
+
import { TlvVoid } from "../../tlv/TlvVoid.js";
|
|
30
|
+
export const INTERACTION_PROTOCOL_ID = 0x0001;
|
|
31
|
+
const logger = Logger.get("InteractionProtocol");
|
|
32
|
+
export class ClusterServer {
|
|
33
|
+
constructor(clusterDef, features, attributesInitialValues, handlers) {
|
|
34
|
+
this.attributes = {};
|
|
35
|
+
this.commands = new Array();
|
|
36
|
+
this.clusterStorage = null;
|
|
37
|
+
this.attributeStorageListeners = new Map();
|
|
38
|
+
const { id, name, attributes: attributeDefs, commands: commandDefs } = clusterDef;
|
|
39
|
+
this.id = id;
|
|
40
|
+
this.name = name;
|
|
41
|
+
// Create attributes
|
|
42
|
+
attributesInitialValues = Object.assign(Object.assign({}, attributesInitialValues), { clusterRevision: clusterDef.revision, featureMap: features });
|
|
43
|
+
for (const name in attributesInitialValues) {
|
|
44
|
+
const { id, schema, writable, persistent } = attributeDefs[name];
|
|
45
|
+
const validator = typeof schema.validate === 'function' ? schema.validate.bind(schema) : undefined;
|
|
46
|
+
const getter = handlers[`get${capitalize(name)}`];
|
|
47
|
+
if (getter === undefined) {
|
|
48
|
+
this.attributes[name] = new AttributeServer(id, name, schema, validator !== null && validator !== void 0 ? validator : (() => { }), writable, attributesInitialValues[name]);
|
|
49
|
+
}
|
|
50
|
+
else {
|
|
51
|
+
this.attributes[name] = new AttributeGetterServer(id, name, schema, validator !== null && validator !== void 0 ? validator : (() => { }), writable, attributesInitialValues[name], getter);
|
|
52
|
+
}
|
|
53
|
+
if (persistent) {
|
|
54
|
+
const listener = (value, version) => this.attributeStorageListener(name, version, value);
|
|
55
|
+
this.attributeStorageListeners.set(id, listener);
|
|
56
|
+
this.attributes[name].addMatterListener(listener);
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
// Create commands
|
|
60
|
+
for (const name in commandDefs) {
|
|
61
|
+
const handler = handlers[name];
|
|
62
|
+
if (handler === undefined)
|
|
63
|
+
continue;
|
|
64
|
+
const { requestId, requestSchema, responseId, responseSchema } = commandDefs[name];
|
|
65
|
+
this.commands.push(new CommandServer(requestId, responseId, name, requestSchema, responseSchema, (request, session, message) => handler({ request, attributes: this.attributes, session, message })));
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
setStorage(storageContext) {
|
|
69
|
+
this.clusterStorage = storageContext;
|
|
70
|
+
for (const name in this.attributes) {
|
|
71
|
+
const attribute = this.attributes[name];
|
|
72
|
+
if (!this.attributeStorageListeners.has(attribute.id))
|
|
73
|
+
return;
|
|
74
|
+
if (!storageContext.has(attribute.name))
|
|
75
|
+
return;
|
|
76
|
+
try {
|
|
77
|
+
const data = storageContext.get(attribute.name);
|
|
78
|
+
logger.debug(`Restoring attribute ${attribute.name} (${attribute.id}) in cluster ${this.name} (${this.id})`);
|
|
79
|
+
attribute.init(data.value, data.version);
|
|
80
|
+
}
|
|
81
|
+
catch (error) {
|
|
82
|
+
logger.warn(`Failed to restore attribute ${attribute.name} (${attribute.id}) in cluster ${this.name} (${this.id})`, error);
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
attributeStorageListener(attributeName, version, value) {
|
|
87
|
+
if (!this.clusterStorage)
|
|
88
|
+
return;
|
|
89
|
+
logger.debug(`Storing attribute ${attributeName} in cluster ${this.name} (${this.id})`);
|
|
90
|
+
this.clusterStorage.set(attributeName, { version, value });
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
export function commandPathToId({ endpointId, clusterId, commandId }) {
|
|
94
|
+
return `${endpointId}/${clusterId}/${commandId}`;
|
|
95
|
+
}
|
|
96
|
+
export function attributePathToId({ endpointId, clusterId, attributeId }) {
|
|
97
|
+
return `${endpointId}/${clusterId}/${attributeId}`;
|
|
98
|
+
}
|
|
99
|
+
function toHex(value) {
|
|
100
|
+
return value === undefined ? "*" : `0x${value.toString(16)}`;
|
|
101
|
+
}
|
|
102
|
+
export class InteractionServer {
|
|
103
|
+
constructor(storageManager) {
|
|
104
|
+
this.storageManager = storageManager;
|
|
105
|
+
this.endpoints = new Map();
|
|
106
|
+
this.attributes = new Map();
|
|
107
|
+
this.attributePaths = new Array();
|
|
108
|
+
this.commands = new Map();
|
|
109
|
+
this.commandPaths = new Array();
|
|
110
|
+
this.nextSubscriptionId = Crypto.getRandomUInt32();
|
|
111
|
+
}
|
|
112
|
+
getId() {
|
|
113
|
+
return INTERACTION_PROTOCOL_ID;
|
|
114
|
+
}
|
|
115
|
+
addEndpoint(endpointId, device, clusters) {
|
|
116
|
+
// Add the descriptor cluster
|
|
117
|
+
const descriptorCluster = new ClusterServer(DescriptorCluster, {}, {
|
|
118
|
+
deviceTypeList: [{ revision: 1, deviceType: new DeviceTypeId(device.code) }],
|
|
119
|
+
serverList: [],
|
|
120
|
+
clientList: [],
|
|
121
|
+
partsList: [],
|
|
122
|
+
}, {});
|
|
123
|
+
clusters.push(descriptorCluster);
|
|
124
|
+
descriptorCluster.attributes.serverList.setLocal(clusters.map(({ id }) => new ClusterId(id)));
|
|
125
|
+
const clusterEndpointNumber = new EndpointNumber(endpointId);
|
|
126
|
+
const clusterMap = new Map();
|
|
127
|
+
clusters.forEach(cluster => {
|
|
128
|
+
const { id: clusterId, attributes, commands } = cluster;
|
|
129
|
+
cluster.setStorage(this.storageManager.createContext(`Cluster-${clusterEndpointNumber.number}-${clusterId}`));
|
|
130
|
+
clusterMap.set(clusterId, cluster);
|
|
131
|
+
// Add attributes
|
|
132
|
+
for (const name in attributes) {
|
|
133
|
+
const attribute = attributes[name];
|
|
134
|
+
const path = { endpointId, clusterId, attributeId: attribute.id };
|
|
135
|
+
this.attributes.set(attributePathToId(path), attribute);
|
|
136
|
+
this.attributePaths.push(path);
|
|
137
|
+
}
|
|
138
|
+
// Add commands
|
|
139
|
+
commands.forEach(command => {
|
|
140
|
+
const path = { endpointId, clusterId, commandId: command.invokeId };
|
|
141
|
+
this.commands.set(commandPathToId(path), command);
|
|
142
|
+
this.commandPaths.push(path);
|
|
143
|
+
});
|
|
144
|
+
});
|
|
145
|
+
// Add part list if the endpoint is not root
|
|
146
|
+
if (endpointId !== 0) {
|
|
147
|
+
const rootPartsListAttribute = this.attributes.get(attributePathToId({ endpointId: 0, clusterId: DescriptorCluster.id, attributeId: DescriptorCluster.attributes.partsList.id }));
|
|
148
|
+
if (rootPartsListAttribute === undefined)
|
|
149
|
+
throw new Error("The root endpoint should be added first!");
|
|
150
|
+
rootPartsListAttribute.setLocal([...rootPartsListAttribute.getLocal(), clusterEndpointNumber]);
|
|
151
|
+
}
|
|
152
|
+
this.endpoints.set(endpointId, Object.assign(Object.assign({}, device), { clusters: clusterMap }));
|
|
153
|
+
return this;
|
|
154
|
+
}
|
|
155
|
+
onNewExchange(exchange) {
|
|
156
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
157
|
+
yield new InteractionServerMessenger(exchange).handleRequest(readRequest => this.handleReadRequest(exchange, readRequest), writeRequest => this.handleWriteRequest(exchange, writeRequest), (subscribeRequest, messenger) => this.handleSubscribeRequest(exchange, subscribeRequest, messenger), (invokeRequest, message) => this.handleInvokeRequest(exchange, invokeRequest, message), timedRequest => this.handleTimedRequest(exchange, timedRequest));
|
|
158
|
+
});
|
|
159
|
+
}
|
|
160
|
+
handleReadRequest(exchange, { attributeRequests: attributePaths, isFabricFiltered }) {
|
|
161
|
+
if (attributePaths === undefined) {
|
|
162
|
+
throw new StatusResponseError("Only Read requests with attributeRequests are supported right now", 143 /* StatusCode.UnsupportedRead */);
|
|
163
|
+
}
|
|
164
|
+
logger.debug(`Received read request from ${exchange.channel.getName()}: ${attributePaths.map(path => this.resolveAttributeName(path)).join(", ")}, isFabricFiltered=${isFabricFiltered}`);
|
|
165
|
+
// UnsupportedNode/UnsupportedEndpoint/UnsupportedCluster/UnsupportedAttribute/UnsupportedRead
|
|
166
|
+
const attributeReports = attributePaths.flatMap((path) => {
|
|
167
|
+
const attributes = this.getAttributes([path]);
|
|
168
|
+
if (attributes.length === 0) {
|
|
169
|
+
logger.debug(`Read from ${exchange.channel.getName()}: ${this.resolveAttributeName(path)} unsupported path`);
|
|
170
|
+
return [{ attributeStatus: { path, status: { status: 134 /* StatusCode.UnsupportedAttribute */ } } }]; // TODO: Find correct status code
|
|
171
|
+
}
|
|
172
|
+
return attributes.map(({ path, attribute }) => {
|
|
173
|
+
const { value, version } = attribute.getWithVersion(exchange.session); // TODO check ACL
|
|
174
|
+
logger.debug(`Read from ${exchange.channel.getName()}: ${this.resolveAttributeName(path)}=${Logger.toJSON(value)} (version=${version})`);
|
|
175
|
+
return { attributeData: { path, data: attribute.schema.encodeTlv(value), dataVersion: version } };
|
|
176
|
+
});
|
|
177
|
+
});
|
|
178
|
+
return {
|
|
179
|
+
interactionModelRevision: 1,
|
|
180
|
+
suppressResponse: false,
|
|
181
|
+
attributeReports
|
|
182
|
+
};
|
|
183
|
+
}
|
|
184
|
+
handleWriteRequest(exchange, { suppressResponse, writeRequests }) {
|
|
185
|
+
logger.debug(`Received write request from ${exchange.channel.getName()}: ${writeRequests.map(req => this.resolveAttributeName(req.path)).join(", ")}, suppressResponse=${suppressResponse}`);
|
|
186
|
+
// TODO consider TimedRequest constraints
|
|
187
|
+
const writeData = normalizeAttributeData(writeRequests, true);
|
|
188
|
+
const writeResults = writeData.flatMap((values) => {
|
|
189
|
+
const { path, dataVersion } = values[0];
|
|
190
|
+
const attributes = this.getAttributes([path], true);
|
|
191
|
+
if (attributes.length === 0) {
|
|
192
|
+
return [{ path, statusCode: 136 /* StatusCode.UnsupportedWrite */ }]; // TODO: Find correct status code
|
|
193
|
+
}
|
|
194
|
+
return attributes.map(({ path, attribute }) => {
|
|
195
|
+
// TODO add checks or dataVersion
|
|
196
|
+
// TODO add ACL checks
|
|
197
|
+
const { schema, defaultValue } = attribute;
|
|
198
|
+
try {
|
|
199
|
+
const value = decodeValueForSchema(schema, values, defaultValue);
|
|
200
|
+
logger.debug(`Handle write request from ${exchange.channel.getName()} resolved to: ${this.resolveAttributeName(path)}=${Logger.toJSON(value)} (Version=${dataVersion})`);
|
|
201
|
+
attribute.set(value, exchange.session);
|
|
202
|
+
}
|
|
203
|
+
catch (error) {
|
|
204
|
+
if (attributes.length === 1) { // For Multi-Attribute-Writes we ignore errors
|
|
205
|
+
logger.error(`Error while handling write request from ${exchange.channel.getName()} to ${this.resolveAttributeName(path)}: ${error.message}`);
|
|
206
|
+
return { path, statusCode: 135 /* StatusCode.ConstraintError */ };
|
|
207
|
+
}
|
|
208
|
+
else {
|
|
209
|
+
logger.debug(`While handling write request from ${exchange.channel.getName()} to ${this.resolveAttributeName(path)} ignored: ${error.message}`);
|
|
210
|
+
}
|
|
211
|
+
}
|
|
212
|
+
return { path, statusCode: 0 /* StatusCode.Success */ };
|
|
213
|
+
});
|
|
214
|
+
//.filter(({ statusCode }) => statusCode !== StatusCode.Success); // see https://github.com/project-chip/connectedhomeip/issues/26198
|
|
215
|
+
});
|
|
216
|
+
// TODO respect suppressResponse, potentially also needs adjustment in InteractionMessenger class!
|
|
217
|
+
const errorResults = writeResults.filter(({ statusCode }) => statusCode !== 0 /* StatusCode.Success */);
|
|
218
|
+
logger.debug(`Write request from ${exchange.channel.getName()} done ${errorResults.length ? `with following errors: ${errorResults.map(({ path, statusCode }) => `${this.resolveAttributeName(path)}=${Logger.toJSON(statusCode)}`).join(", ")}` : "without errors"}`);
|
|
219
|
+
return {
|
|
220
|
+
interactionModelRevision: 1,
|
|
221
|
+
writeResponses: writeResults.map(({ path, statusCode }) => ({ path, status: { status: statusCode } })),
|
|
222
|
+
};
|
|
223
|
+
}
|
|
224
|
+
handleSubscribeRequest(exchange, { minIntervalFloorSeconds, maxIntervalCeilingSeconds, attributeRequests, eventRequests, keepSubscriptions }, messenger) {
|
|
225
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
226
|
+
logger.debug(`Received subscribe request from ${exchange.channel.getName()}`);
|
|
227
|
+
if (!exchange.session.isSecure())
|
|
228
|
+
throw new Error("Subscriptions are only implemented on secure sessions");
|
|
229
|
+
const session = exchange.session;
|
|
230
|
+
const fabric = session.getFabric();
|
|
231
|
+
if (fabric === undefined)
|
|
232
|
+
throw new Error("Subscriptions are only implemented after a fabric has been assigned");
|
|
233
|
+
if ((!Array.isArray(attributeRequests) || attributeRequests.length === 0) && (!Array.isArray(eventRequests) || eventRequests.length === 0)) {
|
|
234
|
+
throw new StatusResponseError("No attributes or events requested", 128 /* StatusCode.InvalidAction */);
|
|
235
|
+
}
|
|
236
|
+
if (!keepSubscriptions) {
|
|
237
|
+
session.clearSubscriptions();
|
|
238
|
+
}
|
|
239
|
+
// TODO add eventsRequest and other missing supports
|
|
240
|
+
if (attributeRequests !== undefined) {
|
|
241
|
+
logger.debug(`Subscribe to ${attributeRequests.map(path => this.resolveAttributeName(path)).join(", ")}`);
|
|
242
|
+
if (attributeRequests.length === 0)
|
|
243
|
+
throw new Error("Unsupported subscription request with empty attribute list");
|
|
244
|
+
if (minIntervalFloorSeconds < 0)
|
|
245
|
+
throw new Error("minIntervalFloorSeconds should be greater or equal to 0");
|
|
246
|
+
if (maxIntervalCeilingSeconds < 0)
|
|
247
|
+
throw new Error("maxIntervalCeilingSeconds should be greater or equal to 1");
|
|
248
|
+
if (maxIntervalCeilingSeconds < minIntervalFloorSeconds)
|
|
249
|
+
throw new Error("maxIntervalCeilingSeconds should be greater or equal to minIntervalFloorSeconds");
|
|
250
|
+
const attributes = this.getAttributes(attributeRequests);
|
|
251
|
+
if (!attributes.length) {
|
|
252
|
+
throw new StatusResponseError("Attributes not found", 134 /* StatusCode.UnsupportedAttribute */);
|
|
253
|
+
}
|
|
254
|
+
// TODO: Interpret specs:
|
|
255
|
+
// The publisher SHALL compute an appropriate value for the MaxInterval field in the action. This SHALL respect the following constraint: MinIntervalFloor ≤ MaxInterval ≤ MAX(SUBSCRIPTION_MAX_INTERVAL_PUBLISHER_LIMIT=60mn, MaxIntervalCeiling)
|
|
256
|
+
if (this.nextSubscriptionId === 0xFFFFFFFF)
|
|
257
|
+
this.nextSubscriptionId = 0;
|
|
258
|
+
const subscriptionId = this.nextSubscriptionId++;
|
|
259
|
+
const subscriptionHandler = new SubscriptionHandler(subscriptionId, session.getContext(), fabric, session.getPeerNodeId(), attributes, minIntervalFloorSeconds, maxIntervalCeilingSeconds);
|
|
260
|
+
session.addSubscription(subscriptionHandler);
|
|
261
|
+
// Send initial data report to prime the subscription with initial data
|
|
262
|
+
yield subscriptionHandler.sendInitialReport(messenger, session);
|
|
263
|
+
const maxInterval = subscriptionHandler.getMaxInterval();
|
|
264
|
+
logger.info(`Created subscription ${subscriptionId} for Session ${session.getId()} with ${attributes.length} attributes. Updates: ${minIntervalFloorSeconds} - ${maxIntervalCeilingSeconds} => ${maxInterval} seconds`);
|
|
265
|
+
// Then send the subscription response
|
|
266
|
+
yield messenger.send(4 /* MessageType.SubscribeResponse */, TlvSubscribeResponse.encode({ subscriptionId, maxInterval, interactionModelRevision: 1 }));
|
|
267
|
+
subscriptionHandler.activateSendingUpdates();
|
|
268
|
+
}
|
|
269
|
+
});
|
|
270
|
+
}
|
|
271
|
+
handleInvokeRequest(exchange, { invokeRequests }, message) {
|
|
272
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
273
|
+
logger.debug(`Received invoke request from ${exchange.channel.getName()}: ${invokeRequests.map(({ commandPath: { endpointId, clusterId, commandId } }) => `${toHex(endpointId)}/${toHex(clusterId)}/${toHex(commandId)}`).join(", ")}`);
|
|
274
|
+
const results = new Array();
|
|
275
|
+
yield Promise.all(invokeRequests.map(({ commandPath, commandFields }) => __awaiter(this, void 0, void 0, function* () {
|
|
276
|
+
if (commandPath.endpointId === undefined) {
|
|
277
|
+
logger.error("Wildcard command invokes not yet supported!");
|
|
278
|
+
results.push({ code: 129 /* StatusCode.UnsupportedCommand */, commandPath, response: TlvVoid.encodeTlv(), responseId: 0 });
|
|
279
|
+
return;
|
|
280
|
+
}
|
|
281
|
+
const command = this.commands.get(commandPathToId(commandPath));
|
|
282
|
+
if (command === undefined)
|
|
283
|
+
return;
|
|
284
|
+
// If no arguments are provided in the invoke data (because optional field), we use our type as replacement
|
|
285
|
+
if (commandFields === undefined) {
|
|
286
|
+
commandFields = TlvNoArguments.encodeTlv(commandFields);
|
|
287
|
+
}
|
|
288
|
+
const result = yield command.invoke(exchange.session, commandFields, message);
|
|
289
|
+
results.push(Object.assign(Object.assign({}, result), { commandPath }));
|
|
290
|
+
})));
|
|
291
|
+
return {
|
|
292
|
+
suppressResponse: false,
|
|
293
|
+
interactionModelRevision: 1,
|
|
294
|
+
invokeResponses: results.map(({ commandPath, responseId, code, response }) => {
|
|
295
|
+
if (response.length === 0) {
|
|
296
|
+
return { status: { commandPath, status: { status: code } } };
|
|
297
|
+
}
|
|
298
|
+
else {
|
|
299
|
+
return { command: { commandPath: Object.assign(Object.assign({}, commandPath), { commandId: responseId }), commandFields: response } };
|
|
300
|
+
}
|
|
301
|
+
}),
|
|
302
|
+
};
|
|
303
|
+
});
|
|
304
|
+
}
|
|
305
|
+
handleTimedRequest(exchange, { timeout }) {
|
|
306
|
+
logger.debug(`Received timed request (${timeout}) from ${exchange.channel.getName()}`);
|
|
307
|
+
// TODO: implement this
|
|
308
|
+
}
|
|
309
|
+
resolveAttributeName({ endpointId, clusterId, attributeId }) {
|
|
310
|
+
var _a;
|
|
311
|
+
if (endpointId === undefined) {
|
|
312
|
+
return `*/${toHex(clusterId)}/${toHex(attributeId)}`;
|
|
313
|
+
}
|
|
314
|
+
const endpoint = this.endpoints.get(endpointId);
|
|
315
|
+
if (endpoint === undefined) {
|
|
316
|
+
return `unknown(${toHex(endpointId)})/${toHex(clusterId)}/${toHex(attributeId)}`;
|
|
317
|
+
}
|
|
318
|
+
const endpointName = `${endpoint.name}(${toHex(endpointId)})`;
|
|
319
|
+
if (clusterId === undefined) {
|
|
320
|
+
return `${endpointName}/*/${toHex(attributeId)}`;
|
|
321
|
+
}
|
|
322
|
+
const cluster = endpoint.clusters.get(clusterId);
|
|
323
|
+
if (cluster === undefined) {
|
|
324
|
+
return `${endpointName}/unknown(${toHex(clusterId)})/${toHex(attributeId)}`;
|
|
325
|
+
}
|
|
326
|
+
const clusterName = `${cluster.name}(${toHex(clusterId)})`;
|
|
327
|
+
if (attributeId === undefined) {
|
|
328
|
+
return `${endpointName}/${clusterName}/*`;
|
|
329
|
+
}
|
|
330
|
+
const attribute = this.attributes.get(attributePathToId({ endpointId, clusterId, attributeId }));
|
|
331
|
+
const attributeName = `${(_a = attribute === null || attribute === void 0 ? void 0 : attribute.name) !== null && _a !== void 0 ? _a : "unknown"}(${toHex(attributeId)})`;
|
|
332
|
+
return `${endpointName}/${clusterName}/${attributeName}`;
|
|
333
|
+
}
|
|
334
|
+
getAttributes(filters, onlyWritable = false) {
|
|
335
|
+
const result = new Array();
|
|
336
|
+
filters.forEach(({ endpointId, clusterId, attributeId }) => {
|
|
337
|
+
if (endpointId !== undefined && clusterId !== undefined && attributeId !== undefined) {
|
|
338
|
+
const path = { endpointId, clusterId, attributeId };
|
|
339
|
+
const attribute = this.attributes.get(attributePathToId(path));
|
|
340
|
+
if (attribute === undefined)
|
|
341
|
+
return;
|
|
342
|
+
if (onlyWritable && !attribute.isWritable)
|
|
343
|
+
return;
|
|
344
|
+
result.push({ path, attribute });
|
|
345
|
+
}
|
|
346
|
+
else {
|
|
347
|
+
this.attributePaths.filter(path => (endpointId === undefined || endpointId === path.endpointId)
|
|
348
|
+
&& (clusterId === undefined || clusterId === path.clusterId)
|
|
349
|
+
&& (attributeId === undefined || attributeId === path.attributeId))
|
|
350
|
+
.forEach(path => {
|
|
351
|
+
const attribute = this.attributes.get(attributePathToId(path));
|
|
352
|
+
if (attribute === undefined)
|
|
353
|
+
return;
|
|
354
|
+
if (onlyWritable && !attribute.isWritable)
|
|
355
|
+
return;
|
|
356
|
+
result.push({ path, attribute });
|
|
357
|
+
});
|
|
358
|
+
}
|
|
359
|
+
});
|
|
360
|
+
return result;
|
|
361
|
+
}
|
|
362
|
+
}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2022-2023 Project CHIP Authors
|
|
4
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
+
*/
|
|
6
|
+
import { MatterDevice } from "../../MatterDevice.js";
|
|
7
|
+
import { InteractionServerMessenger } from "./InteractionMessenger.js";
|
|
8
|
+
import { Fabric } from "../../fabric/Fabric.js";
|
|
9
|
+
import { AttributeWithPath } from "./InteractionServer.js";
|
|
10
|
+
import { NodeId } from "../../datatype/NodeId.js";
|
|
11
|
+
import { TlvAttributePath } from "./InteractionProtocol.js";
|
|
12
|
+
import { SecureSession } from "../../session/SecureSession.js";
|
|
13
|
+
import { TlvSchema, TypeFromSchema } from "../../tlv/TlvSchema.js";
|
|
14
|
+
export declare class SubscriptionHandler {
|
|
15
|
+
readonly subscriptionId: number;
|
|
16
|
+
private readonly server;
|
|
17
|
+
private readonly fabric;
|
|
18
|
+
private readonly peerNodeId;
|
|
19
|
+
private readonly attributes;
|
|
20
|
+
private lastUpdateTimeMs;
|
|
21
|
+
private updateTimer;
|
|
22
|
+
private outstandingAttributeUpdates;
|
|
23
|
+
private attributeListeners;
|
|
24
|
+
private sendUpdatesActivated;
|
|
25
|
+
private readonly maxInterval;
|
|
26
|
+
private readonly sendInterval;
|
|
27
|
+
private readonly minIntervalFloorMs;
|
|
28
|
+
private readonly maxIntervalCeilingMs;
|
|
29
|
+
constructor(subscriptionId: number, server: MatterDevice, fabric: Fabric, peerNodeId: NodeId, attributes: AttributeWithPath[], minIntervalFloor: number, maxIntervalCeiling: number);
|
|
30
|
+
getMaxInterval(): number;
|
|
31
|
+
activateSendingUpdates(): void;
|
|
32
|
+
sendUpdate(): Promise<void>;
|
|
33
|
+
sendInitialReport(messenger: InteractionServerMessenger, session: SecureSession<MatterDevice>): Promise<void>;
|
|
34
|
+
attributeChangeListener(path: TypeFromSchema<typeof TlvAttributePath>, schema: TlvSchema<any>, version: number, value: any): void;
|
|
35
|
+
cancel(): void;
|
|
36
|
+
private sendUpdateMessage;
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=SubscriptionHandler.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SubscriptionHandler.d.ts","sourceRoot":"","sources":["../../../../src/protocol/interaction/SubscriptionHandler.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AACrD,OAAO,EAAE,0BAA0B,EAAuB,MAAM,2BAA2B,CAAC;AAC5F,OAAO,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;AAChD,OAAO,EAAE,iBAAiB,EAA8C,MAAM,wBAAwB,CAAC;AAGvG,OAAO,EAAE,MAAM,EAAE,MAAM,0BAA0B,CAAC;AAClD,OAAO,EAAc,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AAExE,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAC;AAC/D,OAAO,EAAE,SAAS,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAmBnE,qBAAa,mBAAmB;IAYxB,QAAQ,CAAC,cAAc,EAAE,MAAM;IAC/B,OAAO,CAAC,QAAQ,CAAC,MAAM;IACvB,OAAO,CAAC,QAAQ,CAAC,MAAM;IACvB,OAAO,CAAC,QAAQ,CAAC,UAAU;IAC3B,OAAO,CAAC,QAAQ,CAAC,UAAU;IAf/B,OAAO,CAAC,gBAAgB,CAAK;IAC7B,OAAO,CAAC,WAAW,CAAQ;IAC3B,OAAO,CAAC,2BAA2B,CAA4C;IAC/E,OAAO,CAAC,kBAAkB,CAA4D;IACtF,OAAO,CAAC,oBAAoB,CAAS;IACrC,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAS;IACrC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAS;IACtC,OAAO,CAAC,QAAQ,CAAC,kBAAkB,CAAS;IAC5C,OAAO,CAAC,QAAQ,CAAC,oBAAoB,CAAS;gBAGjC,cAAc,EAAE,MAAM,EACd,MAAM,EAAE,YAAY,EACpB,MAAM,EAAE,MAAM,EACd,UAAU,EAAE,MAAM,EAClB,UAAU,EAAE,iBAAiB,EAAE,EAChD,gBAAgB,EAAE,MAAM,EACxB,kBAAkB,EAAE,MAAM;IAsB9B,cAAc,IAAI,MAAM;IAIxB,sBAAsB;IAShB,UAAU;IA0BV,iBAAiB,CAAC,SAAS,EAAE,0BAA0B,EAAE,OAAO,EAAE,aAAa,CAAC,YAAY,CAAC;IAuBnG,uBAAuB,CAAC,IAAI,EAAE,cAAc,CAAC,OAAO,gBAAgB,CAAC,EAAE,MAAM,EAAE,SAAS,CAAC,GAAG,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG;IAK1H,MAAM;YAaQ,iBAAiB;CAmClC"}
|
|
@@ -0,0 +1,170 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2022-2023 Project CHIP Authors
|
|
4
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
+
*/
|
|
6
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
7
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
8
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
9
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
10
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
11
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
12
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
13
|
+
});
|
|
14
|
+
};
|
|
15
|
+
import { InteractionServerMessenger, StatusResponseError } from "./InteractionMessenger.js";
|
|
16
|
+
import { INTERACTION_PROTOCOL_ID, attributePathToId } from "./InteractionServer.js";
|
|
17
|
+
import { Logger } from "../../log/Logger.js";
|
|
18
|
+
import { Time } from "../../time/Time.js";
|
|
19
|
+
import { tryCatchAsync } from "../../common/TryCatchHandler.js";
|
|
20
|
+
const logger = Logger.get("SubscriptionHandler");
|
|
21
|
+
// We use 3 minutes as global max interval because with 60mins as defined by spec the timeframe
|
|
22
|
+
// until the controller establishs a new subscription after e.g a reboot can be up to 60 mins
|
|
23
|
+
// and the controller would assume that the value is unchanged. this is too long.
|
|
24
|
+
// chip-tool is not respecting the 60mins at all and only respects the max sent by the controller
|
|
25
|
+
// which can lead to spamming the network with unneeded packages. So I decided for 3 minutes for now
|
|
26
|
+
// as a compromise until we have something better.
|
|
27
|
+
const SUBSCRIPTION_MAX_INTERVAL_PUBLISHER_LIMIT_MS = 3 * 60 * 1000; /** 3 mins */ // Officially: 1000 * 60 * 60; /** 1 hour */
|
|
28
|
+
export class SubscriptionHandler {
|
|
29
|
+
constructor(subscriptionId, server, fabric, peerNodeId, attributes, minIntervalFloor, maxIntervalCeiling) {
|
|
30
|
+
this.subscriptionId = subscriptionId;
|
|
31
|
+
this.server = server;
|
|
32
|
+
this.fabric = fabric;
|
|
33
|
+
this.peerNodeId = peerNodeId;
|
|
34
|
+
this.attributes = attributes;
|
|
35
|
+
this.lastUpdateTimeMs = 0;
|
|
36
|
+
this.outstandingAttributeUpdates = new Map();
|
|
37
|
+
this.attributeListeners = new Map();
|
|
38
|
+
this.sendUpdatesActivated = false;
|
|
39
|
+
this.minIntervalFloorMs = minIntervalFloor * 1000;
|
|
40
|
+
this.maxIntervalCeilingMs = maxIntervalCeiling * 1000;
|
|
41
|
+
// The final Max interval needs to be between min-floor and the MAX of max-ceiling and the defined publisher
|
|
42
|
+
// maximum of 60 minutes - this is to ensure that the publisher is not flooded with updates. But spec also
|
|
43
|
+
// says that it should be more frequent than the max interval.
|
|
44
|
+
// So let's calculate a maximum in the second half of the range between the two, but then already send at
|
|
45
|
+
// half of that time (so ideally we have 2 updates per max interval, so one could fail, and we still are good).
|
|
46
|
+
const halfMaxIntervalCeilingMs = (Math.max(SUBSCRIPTION_MAX_INTERVAL_PUBLISHER_LIMIT_MS, this.maxIntervalCeilingMs) - this.minIntervalFloorMs) / 2;
|
|
47
|
+
this.maxInterval = Math.floor(this.minIntervalFloorMs + halfMaxIntervalCeilingMs + halfMaxIntervalCeilingMs * Math.random());
|
|
48
|
+
this.sendInterval = Math.floor(this.maxInterval / 2);
|
|
49
|
+
this.updateTimer = Time.getTimer(this.sendInterval, () => this.sendUpdate()); // will be started later
|
|
50
|
+
attributes.forEach(({ path, attribute }) => {
|
|
51
|
+
// TODO: handle attributes with "getter" methods
|
|
52
|
+
const listener = (value, version) => this.attributeChangeListener(path, attribute.schema, version, value);
|
|
53
|
+
this.attributeListeners.set(attributePathToId(path), listener);
|
|
54
|
+
attribute.addMatterListener(listener);
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
getMaxInterval() {
|
|
58
|
+
return Math.ceil(this.maxInterval / 1000);
|
|
59
|
+
}
|
|
60
|
+
activateSendingUpdates() {
|
|
61
|
+
this.sendUpdatesActivated = true;
|
|
62
|
+
if (this.outstandingAttributeUpdates.size > 0) {
|
|
63
|
+
void this.sendUpdate();
|
|
64
|
+
}
|
|
65
|
+
else {
|
|
66
|
+
this.updateTimer = Time.getTimer(this.sendInterval, () => this.sendUpdate()).start();
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
sendUpdate() {
|
|
70
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
71
|
+
this.updateTimer.stop();
|
|
72
|
+
const now = Time.nowMs();
|
|
73
|
+
const timeSinceLastUpdateMs = now - this.lastUpdateTimeMs;
|
|
74
|
+
if (timeSinceLastUpdateMs < this.minIntervalFloorMs) {
|
|
75
|
+
this.updateTimer = Time.getTimer(this.minIntervalFloorMs - timeSinceLastUpdateMs, () => this.sendUpdate()).start();
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
78
|
+
if (!this.sendUpdatesActivated) {
|
|
79
|
+
return;
|
|
80
|
+
}
|
|
81
|
+
const updatesToSend = Array.from(this.outstandingAttributeUpdates.values());
|
|
82
|
+
this.outstandingAttributeUpdates.clear();
|
|
83
|
+
this.lastUpdateTimeMs = now;
|
|
84
|
+
try {
|
|
85
|
+
yield this.sendUpdateMessage(updatesToSend);
|
|
86
|
+
}
|
|
87
|
+
catch (error) {
|
|
88
|
+
// TODO: Add maybe a counter and cancel subscription update sending after a certain number of errors?
|
|
89
|
+
logger.error("Error sending subscription update message", error);
|
|
90
|
+
}
|
|
91
|
+
this.updateTimer = Time.getTimer(this.sendInterval, () => this.sendUpdate()).start();
|
|
92
|
+
});
|
|
93
|
+
}
|
|
94
|
+
sendInitialReport(messenger, session) {
|
|
95
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
96
|
+
this.updateTimer.stop();
|
|
97
|
+
const values = this.attributes.map(({ path, attribute }) => {
|
|
98
|
+
const { value, version } = attribute.getWithVersion(session);
|
|
99
|
+
return { path, value, version, schema: attribute.schema };
|
|
100
|
+
}).filter(({ value }) => value !== undefined);
|
|
101
|
+
this.lastUpdateTimeMs = Time.nowMs();
|
|
102
|
+
yield messenger.sendDataReport({
|
|
103
|
+
suppressResponse: false,
|
|
104
|
+
subscriptionId: this.subscriptionId,
|
|
105
|
+
interactionModelRevision: 1,
|
|
106
|
+
attributeReports: values.map(({ path, schema, value, version }) => ({
|
|
107
|
+
attributeData: {
|
|
108
|
+
path,
|
|
109
|
+
dataVersion: version,
|
|
110
|
+
data: schema.encodeTlv(value),
|
|
111
|
+
},
|
|
112
|
+
})),
|
|
113
|
+
});
|
|
114
|
+
});
|
|
115
|
+
}
|
|
116
|
+
attributeChangeListener(path, schema, version, value) {
|
|
117
|
+
this.outstandingAttributeUpdates.set(attributePathToId(path), { path, schema, version, value });
|
|
118
|
+
void this.sendUpdate();
|
|
119
|
+
}
|
|
120
|
+
cancel() {
|
|
121
|
+
this.sendUpdatesActivated = false;
|
|
122
|
+
this.attributes.forEach(({ path, attribute }) => {
|
|
123
|
+
const pathId = attributePathToId(path);
|
|
124
|
+
const listener = this.attributeListeners.get(pathId);
|
|
125
|
+
if (listener !== undefined) {
|
|
126
|
+
attribute.removeMatterListener(listener);
|
|
127
|
+
}
|
|
128
|
+
this.attributeListeners.delete(pathId);
|
|
129
|
+
});
|
|
130
|
+
this.updateTimer.stop();
|
|
131
|
+
}
|
|
132
|
+
sendUpdateMessage(values) {
|
|
133
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
134
|
+
logger.debug(`Sending subscription update message for ID ${this.subscriptionId} with ${values.length} values`);
|
|
135
|
+
const exchange = this.server.initiateExchange(this.fabric, this.peerNodeId, INTERACTION_PROTOCOL_ID);
|
|
136
|
+
if (exchange === undefined)
|
|
137
|
+
return;
|
|
138
|
+
logger.debug(`Sending subscription changes for ID ${this.subscriptionId}: ${Logger.toJSON(values)}`);
|
|
139
|
+
const messenger = new InteractionServerMessenger(exchange);
|
|
140
|
+
try {
|
|
141
|
+
yield tryCatchAsync(() => __awaiter(this, void 0, void 0, function* () {
|
|
142
|
+
yield messenger.sendDataReport({
|
|
143
|
+
suppressResponse: !values.length,
|
|
144
|
+
subscriptionId: this.subscriptionId,
|
|
145
|
+
interactionModelRevision: 1,
|
|
146
|
+
attributeReports: values.map(({ path, schema, value, version }) => ({
|
|
147
|
+
attributeData: {
|
|
148
|
+
path,
|
|
149
|
+
dataVersion: version,
|
|
150
|
+
data: schema.encodeTlv(value),
|
|
151
|
+
},
|
|
152
|
+
})),
|
|
153
|
+
});
|
|
154
|
+
}), StatusResponseError, (error) => {
|
|
155
|
+
if (error.code === 125 /* StatusCode.InvalidSubscription */ ||
|
|
156
|
+
error.code === 1 /* StatusCode.Failure */) {
|
|
157
|
+
logger.info(`Subscription ${this.subscriptionId} cancelled by peer.`);
|
|
158
|
+
this.cancel();
|
|
159
|
+
}
|
|
160
|
+
else {
|
|
161
|
+
throw error;
|
|
162
|
+
}
|
|
163
|
+
});
|
|
164
|
+
}
|
|
165
|
+
finally {
|
|
166
|
+
messenger.close();
|
|
167
|
+
}
|
|
168
|
+
});
|
|
169
|
+
}
|
|
170
|
+
}
|