@project-chip/matter.js 0.2.0 → 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 +20 -15
- 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 +12 -7
- 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 +12 -7
- 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 +7 -7
- 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 +26 -19
- package/dist/cjs/cluster/OperationalCredentialsCluster.d.ts.map +1 -0
- package/dist/cjs/cluster/OperationalCredentialsCluster.js +23 -20
- 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 +3 -2
- package/dist/cjs/schema/Schema.d.ts.map +1 -0
- package/dist/cjs/schema/Schema.js +6 -3
- 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 +3 -1
- package/dist/cjs/tlv/TlvAny.d.ts.map +1 -0
- package/dist/cjs/tlv/TlvAny.js +11 -1
- package/dist/{dts → cjs}/tlv/TlvArray.d.ts +4 -3
- package/dist/cjs/tlv/TlvArray.d.ts.map +1 -0
- package/dist/cjs/tlv/TlvArray.js +9 -7
- package/dist/{dts → cjs}/tlv/TlvBoolean.d.ts +3 -1
- package/dist/cjs/tlv/TlvBoolean.d.ts.map +1 -0
- package/dist/cjs/tlv/TlvBoolean.js +5 -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 +4 -2
- package/dist/cjs/tlv/TlvNullable.d.ts.map +1 -0
- package/dist/cjs/tlv/TlvNullable.js +6 -2
- package/dist/{dts → cjs}/tlv/TlvNumber.d.ts +10 -2
- package/dist/cjs/tlv/TlvNumber.d.ts.map +1 -0
- package/dist/cjs/tlv/TlvNumber.js +13 -6
- package/dist/{dts → cjs}/tlv/TlvObject.d.ts +10 -4
- package/dist/cjs/tlv/TlvObject.d.ts.map +1 -0
- package/dist/cjs/tlv/TlvObject.js +25 -7
- 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 +4 -3
- package/dist/cjs/tlv/TlvString.d.ts.map +1 -0
- package/dist/cjs/tlv/TlvString.js +12 -7
- package/dist/{dts → cjs}/tlv/TlvVoid.d.ts +3 -1
- package/dist/cjs/tlv/TlvVoid.d.ts.map +1 -0
- package/dist/cjs/tlv/TlvVoid.js +5 -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 +7 -7
- 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 +23 -20
- 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 +6 -3
- 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 +11 -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 +9 -7
- 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 +5 -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 +6 -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 +13 -6
- 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 +25 -7
- 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 +12 -7
- 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 +5 -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,189 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* @license
|
|
4
|
+
* Copyright 2022-2023 Project CHIP Authors
|
|
5
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
6
|
+
*/
|
|
7
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
8
|
+
exports.TlvWriteResponse = exports.TlvWriteRequest = exports.TlvTimedRequest = exports.TlvInvokeResponse = exports.TlvInvokeRequest = exports.TlvSubscribeResponse = exports.TlvSubscribeRequest = exports.TlvDataReport = exports.TlvReadRequest = exports.TlvStatusResponse = exports.TlvInvokeResponseData = exports.TlvCommandStatus = exports.TlvCommandData = exports.TlvCommandPath = exports.TlvEventReport = exports.TlvEventStatus = exports.TlvAttributeReport = exports.TlvAttributeReportData = exports.TlvAttributeData = exports.TlvAttributeStatus = exports.TlvStatus = exports.TlvDataVersionFilter = exports.TlvClusterPath = exports.TlvEventFilter = exports.TlvEventData = exports.TlvEventPath = exports.TlvAttributePath = void 0;
|
|
9
|
+
const NodeId_js_1 = require("../../datatype/NodeId.js");
|
|
10
|
+
const TlvAny_js_1 = require("../../tlv/TlvAny.js");
|
|
11
|
+
const TlvArray_js_1 = require("../../tlv/TlvArray.js");
|
|
12
|
+
const TlvBoolean_js_1 = require("../../tlv/TlvBoolean.js");
|
|
13
|
+
const TlvNullable_js_1 = require("../../tlv/TlvNullable.js");
|
|
14
|
+
const TlvNumber_js_1 = require("../../tlv/TlvNumber.js");
|
|
15
|
+
const TlvObject_js_1 = require("../../tlv/TlvObject.js");
|
|
16
|
+
// Data structures
|
|
17
|
+
/** @see {@link MatterCoreSpecificationV1_0}, section 10.5.2 */
|
|
18
|
+
exports.TlvAttributePath = (0, TlvObject_js_1.TlvList)({
|
|
19
|
+
enableTagCompression: (0, TlvObject_js_1.TlvOptionalField)(0, TlvBoolean_js_1.TlvBoolean),
|
|
20
|
+
nodeId: (0, TlvObject_js_1.TlvOptionalField)(1, NodeId_js_1.TlvNodeId),
|
|
21
|
+
endpointId: (0, TlvObject_js_1.TlvOptionalField)(2, TlvNumber_js_1.TlvUInt16),
|
|
22
|
+
clusterId: (0, TlvObject_js_1.TlvOptionalField)(3, TlvNumber_js_1.TlvUInt32),
|
|
23
|
+
attributeId: (0, TlvObject_js_1.TlvOptionalField)(4, TlvNumber_js_1.TlvUInt32),
|
|
24
|
+
listIndex: (0, TlvObject_js_1.TlvOptionalField)(5, (0, TlvNullable_js_1.TlvNullable)(TlvNumber_js_1.TlvUInt16)),
|
|
25
|
+
});
|
|
26
|
+
/** @see {@link MatterCoreSpecificationV1_0}, section 10.5.8 */
|
|
27
|
+
exports.TlvEventPath = (0, TlvObject_js_1.TlvList)({
|
|
28
|
+
node: (0, TlvObject_js_1.TlvOptionalField)(0, NodeId_js_1.TlvNodeId),
|
|
29
|
+
endpoint: (0, TlvObject_js_1.TlvOptionalField)(1, TlvNumber_js_1.TlvUInt16),
|
|
30
|
+
cluster: (0, TlvObject_js_1.TlvOptionalField)(2, TlvNumber_js_1.TlvUInt32),
|
|
31
|
+
event: (0, TlvObject_js_1.TlvOptionalField)(3, TlvNumber_js_1.TlvUInt32),
|
|
32
|
+
isUrgent: (0, TlvObject_js_1.TlvOptionalField)(4, TlvBoolean_js_1.TlvBoolean),
|
|
33
|
+
});
|
|
34
|
+
/** @see {@link MatterCoreSpecificationV1_0}, section 10.5.9 */
|
|
35
|
+
exports.TlvEventData = (0, TlvObject_js_1.TlvObject)({
|
|
36
|
+
path: (0, TlvObject_js_1.TlvField)(0, exports.TlvEventPath),
|
|
37
|
+
eventNumber: (0, TlvObject_js_1.TlvField)(1, TlvNumber_js_1.TlvUInt64),
|
|
38
|
+
priority: (0, TlvObject_js_1.TlvField)(2, TlvNumber_js_1.TlvUInt8),
|
|
39
|
+
epochTimestamp: (0, TlvObject_js_1.TlvOptionalField)(3, TlvNumber_js_1.TlvInt64),
|
|
40
|
+
systemTimestamp: (0, TlvObject_js_1.TlvOptionalField)(4, TlvNumber_js_1.TlvUInt64),
|
|
41
|
+
deltaEpochTimestamp: (0, TlvObject_js_1.TlvOptionalField)(5, TlvNumber_js_1.TlvUInt64),
|
|
42
|
+
deltaSystemTimestamp: (0, TlvObject_js_1.TlvOptionalField)(6, TlvNumber_js_1.TlvUInt64),
|
|
43
|
+
data: (0, TlvObject_js_1.TlvOptionalField)(7, TlvAny_js_1.TlvAny),
|
|
44
|
+
});
|
|
45
|
+
/** @see {@link MatterCoreSpecificationV1_0}, section 10.5.6 */
|
|
46
|
+
exports.TlvEventFilter = (0, TlvObject_js_1.TlvList)({
|
|
47
|
+
node: (0, TlvObject_js_1.TlvOptionalField)(0, NodeId_js_1.TlvNodeId),
|
|
48
|
+
eventMin: (0, TlvObject_js_1.TlvField)(1, TlvNumber_js_1.TlvUInt64),
|
|
49
|
+
});
|
|
50
|
+
/** @see {@link MatterCoreSpecificationV1_0}, section 10.5.7 */
|
|
51
|
+
exports.TlvClusterPath = (0, TlvObject_js_1.TlvList)({
|
|
52
|
+
node: (0, TlvObject_js_1.TlvOptionalField)(0, NodeId_js_1.TlvNodeId),
|
|
53
|
+
endpoint: (0, TlvObject_js_1.TlvField)(1, TlvNumber_js_1.TlvUInt16),
|
|
54
|
+
cluster: (0, TlvObject_js_1.TlvField)(2, TlvNumber_js_1.TlvUInt32),
|
|
55
|
+
});
|
|
56
|
+
/** @see {@link MatterCoreSpecificationV1_0}, section 10.5.3 */
|
|
57
|
+
exports.TlvDataVersionFilter = (0, TlvObject_js_1.TlvObject)({
|
|
58
|
+
path: (0, TlvObject_js_1.TlvField)(0, exports.TlvClusterPath),
|
|
59
|
+
dataVersion: (0, TlvObject_js_1.TlvField)(1, TlvNumber_js_1.TlvUInt32),
|
|
60
|
+
});
|
|
61
|
+
/** @see {@link MatterCoreSpecificationV1_0}, section 10.5.17 */
|
|
62
|
+
exports.TlvStatus = (0, TlvObject_js_1.TlvObject)({
|
|
63
|
+
status: (0, TlvObject_js_1.TlvOptionalField)(0, (0, TlvNumber_js_1.TlvEnum)()),
|
|
64
|
+
clusterStatus: (0, TlvObject_js_1.TlvOptionalField)(1, (0, TlvNumber_js_1.TlvEnum)()),
|
|
65
|
+
});
|
|
66
|
+
/** @see {@link MatterCoreSpecificationV1_0}, section 10.5.16 */
|
|
67
|
+
exports.TlvAttributeStatus = (0, TlvObject_js_1.TlvObject)({
|
|
68
|
+
path: (0, TlvObject_js_1.TlvField)(0, exports.TlvAttributePath),
|
|
69
|
+
status: (0, TlvObject_js_1.TlvField)(1, exports.TlvStatus),
|
|
70
|
+
});
|
|
71
|
+
/** @see {@link MatterCoreSpecificationV1_0}, section 10.5.4 */
|
|
72
|
+
exports.TlvAttributeData = (0, TlvObject_js_1.TlvObject)({
|
|
73
|
+
dataVersion: (0, TlvObject_js_1.TlvOptionalField)(0, TlvNumber_js_1.TlvUInt32),
|
|
74
|
+
path: (0, TlvObject_js_1.TlvField)(1, exports.TlvAttributePath),
|
|
75
|
+
data: (0, TlvObject_js_1.TlvField)(2, TlvAny_js_1.TlvAny),
|
|
76
|
+
});
|
|
77
|
+
exports.TlvAttributeReportData = (0, TlvObject_js_1.TlvObject)({
|
|
78
|
+
dataVersion: (0, TlvObject_js_1.TlvField)(0, TlvNumber_js_1.TlvUInt32),
|
|
79
|
+
path: (0, TlvObject_js_1.TlvField)(1, exports.TlvAttributePath),
|
|
80
|
+
data: (0, TlvObject_js_1.TlvField)(2, TlvAny_js_1.TlvAny),
|
|
81
|
+
});
|
|
82
|
+
/** @see {@link MatterCoreSpecificationV1_0}, section 10.5.5 */
|
|
83
|
+
exports.TlvAttributeReport = (0, TlvObject_js_1.TlvObject)({
|
|
84
|
+
attributeStatus: (0, TlvObject_js_1.TlvOptionalField)(0, exports.TlvAttributeStatus),
|
|
85
|
+
attributeData: (0, TlvObject_js_1.TlvOptionalField)(1, exports.TlvAttributeReportData),
|
|
86
|
+
});
|
|
87
|
+
/** @see {@link MatterCoreSpecificationV1_0}, section 10.5.15 */
|
|
88
|
+
exports.TlvEventStatus = (0, TlvObject_js_1.TlvObject)({
|
|
89
|
+
path: (0, TlvObject_js_1.TlvField)(0, exports.TlvEventPath),
|
|
90
|
+
status: (0, TlvObject_js_1.TlvField)(1, exports.TlvStatus),
|
|
91
|
+
});
|
|
92
|
+
/** @see {@link MatterCoreSpecificationV1_0}, section 10.5.10 */
|
|
93
|
+
exports.TlvEventReport = (0, TlvObject_js_1.TlvObject)({
|
|
94
|
+
eventStatus: (0, TlvObject_js_1.TlvField)(0, exports.TlvEventStatus),
|
|
95
|
+
eventData: (0, TlvObject_js_1.TlvField)(1, exports.TlvEventData),
|
|
96
|
+
});
|
|
97
|
+
/** @see {@link MatterCoreSpecificationV1_0}, section 10.5.11 */
|
|
98
|
+
exports.TlvCommandPath = (0, TlvObject_js_1.TlvList)({
|
|
99
|
+
endpointId: (0, TlvObject_js_1.TlvOptionalField)(0, TlvNumber_js_1.TlvUInt16),
|
|
100
|
+
clusterId: (0, TlvObject_js_1.TlvField)(1, TlvNumber_js_1.TlvUInt32),
|
|
101
|
+
commandId: (0, TlvObject_js_1.TlvField)(2, TlvNumber_js_1.TlvUInt32),
|
|
102
|
+
});
|
|
103
|
+
/** @see {@link MatterCoreSpecificationV1_0}, section 10.5.12 */
|
|
104
|
+
exports.TlvCommandData = (0, TlvObject_js_1.TlvObject)({
|
|
105
|
+
commandPath: (0, TlvObject_js_1.TlvField)(0, exports.TlvCommandPath),
|
|
106
|
+
commandFields: (0, TlvObject_js_1.TlvOptionalField)(1, TlvAny_js_1.TlvAny),
|
|
107
|
+
});
|
|
108
|
+
/** @see {@link MatterCoreSpecificationV1_0}, section 10.5.14 */
|
|
109
|
+
exports.TlvCommandStatus = (0, TlvObject_js_1.TlvObject)({
|
|
110
|
+
commandPath: (0, TlvObject_js_1.TlvField)(0, exports.TlvCommandPath),
|
|
111
|
+
status: (0, TlvObject_js_1.TlvField)(1, exports.TlvStatus),
|
|
112
|
+
});
|
|
113
|
+
/** @see {@link MatterCoreSpecificationV1_0}, section 10.5.13 */
|
|
114
|
+
exports.TlvInvokeResponseData = (0, TlvObject_js_1.TlvObject)({
|
|
115
|
+
command: (0, TlvObject_js_1.TlvOptionalField)(0, exports.TlvCommandData),
|
|
116
|
+
status: (0, TlvObject_js_1.TlvOptionalField)(1, exports.TlvCommandStatus),
|
|
117
|
+
});
|
|
118
|
+
// Request/Response Messages
|
|
119
|
+
/** @see {@link MatterCoreSpecificationV1_0}, section 10.6.1 */
|
|
120
|
+
exports.TlvStatusResponse = (0, TlvObject_js_1.TlvObject)({
|
|
121
|
+
status: (0, TlvObject_js_1.TlvField)(0, (0, TlvNumber_js_1.TlvEnum)()),
|
|
122
|
+
interactionModelRevision: (0, TlvObject_js_1.TlvField)(0xFF, TlvNumber_js_1.TlvUInt8),
|
|
123
|
+
});
|
|
124
|
+
/** @see {@link MatterCoreSpecificationV1_0}, section 10.6.2 */
|
|
125
|
+
exports.TlvReadRequest = (0, TlvObject_js_1.TlvObject)({
|
|
126
|
+
attributeRequests: (0, TlvObject_js_1.TlvOptionalField)(0, (0, TlvArray_js_1.TlvArray)(exports.TlvAttributePath)),
|
|
127
|
+
eventRequests: (0, TlvObject_js_1.TlvOptionalField)(1, (0, TlvArray_js_1.TlvArray)(exports.TlvEventPath)),
|
|
128
|
+
eventFilters: (0, TlvObject_js_1.TlvOptionalField)(2, (0, TlvArray_js_1.TlvArray)(exports.TlvEventFilter)),
|
|
129
|
+
isFabricFiltered: (0, TlvObject_js_1.TlvField)(3, TlvBoolean_js_1.TlvBoolean),
|
|
130
|
+
dataVersionFilters: (0, TlvObject_js_1.TlvOptionalField)(4, (0, TlvArray_js_1.TlvArray)(exports.TlvDataVersionFilter)),
|
|
131
|
+
interactionModelRevision: (0, TlvObject_js_1.TlvField)(0xFF, TlvNumber_js_1.TlvUInt8),
|
|
132
|
+
});
|
|
133
|
+
/** @see {@link MatterCoreSpecificationV1_0}, section 10.6.3 */
|
|
134
|
+
exports.TlvDataReport = (0, TlvObject_js_1.TlvObject)({
|
|
135
|
+
subscriptionId: (0, TlvObject_js_1.TlvOptionalField)(0, TlvNumber_js_1.TlvUInt32),
|
|
136
|
+
attributeReports: (0, TlvObject_js_1.TlvOptionalField)(1, (0, TlvArray_js_1.TlvArray)(exports.TlvAttributeReport)),
|
|
137
|
+
eventReports: (0, TlvObject_js_1.TlvOptionalField)(2, (0, TlvArray_js_1.TlvArray)(exports.TlvEventReport)),
|
|
138
|
+
moreChunkedMessages: (0, TlvObject_js_1.TlvOptionalField)(3, TlvBoolean_js_1.TlvBoolean),
|
|
139
|
+
suppressResponse: (0, TlvObject_js_1.TlvOptionalField)(4, TlvBoolean_js_1.TlvBoolean),
|
|
140
|
+
interactionModelRevision: (0, TlvObject_js_1.TlvField)(0xFF, TlvNumber_js_1.TlvUInt8),
|
|
141
|
+
});
|
|
142
|
+
/** @see {@link MatterCoreSpecificationV1_0}, section 10.6.4 */
|
|
143
|
+
exports.TlvSubscribeRequest = (0, TlvObject_js_1.TlvObject)({
|
|
144
|
+
keepSubscriptions: (0, TlvObject_js_1.TlvField)(0, TlvBoolean_js_1.TlvBoolean),
|
|
145
|
+
minIntervalFloorSeconds: (0, TlvObject_js_1.TlvField)(1, TlvNumber_js_1.TlvUInt16),
|
|
146
|
+
maxIntervalCeilingSeconds: (0, TlvObject_js_1.TlvField)(2, TlvNumber_js_1.TlvUInt16),
|
|
147
|
+
attributeRequests: (0, TlvObject_js_1.TlvOptionalField)(3, (0, TlvArray_js_1.TlvArray)(exports.TlvAttributePath)),
|
|
148
|
+
eventRequests: (0, TlvObject_js_1.TlvOptionalField)(4, (0, TlvArray_js_1.TlvArray)(exports.TlvEventPath)),
|
|
149
|
+
eventFilters: (0, TlvObject_js_1.TlvOptionalField)(5, (0, TlvArray_js_1.TlvArray)(exports.TlvEventFilter)),
|
|
150
|
+
isFabricFiltered: (0, TlvObject_js_1.TlvField)(7, TlvBoolean_js_1.TlvBoolean),
|
|
151
|
+
dataVersionFilters: (0, TlvObject_js_1.TlvOptionalField)(8, (0, TlvArray_js_1.TlvArray)(exports.TlvDataVersionFilter)),
|
|
152
|
+
});
|
|
153
|
+
/** @see {@link MatterCoreSpecificationV1_0}, section 10.6.5 */
|
|
154
|
+
exports.TlvSubscribeResponse = (0, TlvObject_js_1.TlvObject)({
|
|
155
|
+
subscriptionId: (0, TlvObject_js_1.TlvField)(0, TlvNumber_js_1.TlvUInt32),
|
|
156
|
+
maxInterval: (0, TlvObject_js_1.TlvField)(2, TlvNumber_js_1.TlvUInt16),
|
|
157
|
+
interactionModelRevision: (0, TlvObject_js_1.TlvField)(0xFF, TlvNumber_js_1.TlvUInt8),
|
|
158
|
+
});
|
|
159
|
+
/** @see {@link MatterCoreSpecificationV1_0}, section 10.6.9 */
|
|
160
|
+
exports.TlvInvokeRequest = (0, TlvObject_js_1.TlvObject)({
|
|
161
|
+
suppressResponse: (0, TlvObject_js_1.TlvField)(0, TlvBoolean_js_1.TlvBoolean),
|
|
162
|
+
timedRequest: (0, TlvObject_js_1.TlvField)(1, TlvBoolean_js_1.TlvBoolean),
|
|
163
|
+
invokeRequests: (0, TlvObject_js_1.TlvField)(2, (0, TlvArray_js_1.TlvArray)(exports.TlvCommandData)),
|
|
164
|
+
interactionModelRevision: (0, TlvObject_js_1.TlvField)(0xFF, TlvNumber_js_1.TlvUInt8),
|
|
165
|
+
});
|
|
166
|
+
/** @see {@link MatterCoreSpecificationV1_0}, section 10.6.10 */
|
|
167
|
+
exports.TlvInvokeResponse = (0, TlvObject_js_1.TlvObject)({
|
|
168
|
+
suppressResponse: (0, TlvObject_js_1.TlvField)(0, TlvBoolean_js_1.TlvBoolean),
|
|
169
|
+
invokeResponses: (0, TlvObject_js_1.TlvField)(1, (0, TlvArray_js_1.TlvArray)(exports.TlvInvokeResponseData)),
|
|
170
|
+
interactionModelRevision: (0, TlvObject_js_1.TlvField)(0xFF, TlvNumber_js_1.TlvUInt8),
|
|
171
|
+
});
|
|
172
|
+
/** @see {@link MatterCoreSpecificationV1_0}, section 10.6.8 */
|
|
173
|
+
exports.TlvTimedRequest = (0, TlvObject_js_1.TlvObject)({
|
|
174
|
+
timeout: (0, TlvObject_js_1.TlvField)(0, TlvNumber_js_1.TlvUInt16),
|
|
175
|
+
interactionModelRevision: (0, TlvObject_js_1.TlvField)(0xFF, TlvNumber_js_1.TlvUInt8), //??
|
|
176
|
+
});
|
|
177
|
+
/** @see {@link MatterCoreSpecificationV1_0}, section 10.6.6 */
|
|
178
|
+
exports.TlvWriteRequest = (0, TlvObject_js_1.TlvObject)({
|
|
179
|
+
suppressResponse: (0, TlvObject_js_1.TlvOptionalField)(0, TlvBoolean_js_1.TlvBoolean),
|
|
180
|
+
timedRequest: (0, TlvObject_js_1.TlvField)(1, TlvBoolean_js_1.TlvBoolean),
|
|
181
|
+
writeRequests: (0, TlvObject_js_1.TlvField)(2, (0, TlvArray_js_1.TlvArray)(exports.TlvAttributeData)),
|
|
182
|
+
moreChunkedMessages: (0, TlvObject_js_1.TlvOptionalField)(3, TlvBoolean_js_1.TlvBoolean),
|
|
183
|
+
interactionModelRevision: (0, TlvObject_js_1.TlvField)(0xFF, TlvNumber_js_1.TlvUInt8),
|
|
184
|
+
});
|
|
185
|
+
/** @see {@link MatterCoreSpecificationV1_0}, section 10.6.7 */
|
|
186
|
+
exports.TlvWriteResponse = (0, TlvObject_js_1.TlvObject)({
|
|
187
|
+
writeResponses: (0, TlvObject_js_1.TlvField)(0, (0, TlvArray_js_1.TlvArray)(exports.TlvAttributeStatus)),
|
|
188
|
+
interactionModelRevision: (0, TlvObject_js_1.TlvField)(0xFF, TlvNumber_js_1.TlvUInt8),
|
|
189
|
+
});
|
|
@@ -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,369 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* @license
|
|
4
|
+
* Copyright 2022-2023 Project CHIP Authors
|
|
5
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
6
|
+
*/
|
|
7
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
8
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
9
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
10
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
11
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
12
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
13
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
14
|
+
});
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
exports.InteractionServer = exports.attributePathToId = exports.commandPathToId = exports.ClusterServer = exports.INTERACTION_PROTOCOL_ID = void 0;
|
|
18
|
+
const InteractionMessenger_js_1 = require("./InteractionMessenger.js");
|
|
19
|
+
const InteractionProtocol_js_1 = require("./InteractionProtocol.js");
|
|
20
|
+
const TlvNoArguments_js_1 = require("../../tlv/TlvNoArguments.js");
|
|
21
|
+
const DeviceTypeId_js_1 = require("../../datatype/DeviceTypeId.js");
|
|
22
|
+
const ClusterId_js_1 = require("../../datatype/ClusterId.js");
|
|
23
|
+
const EndpointNumber_js_1 = require("../../datatype/EndpointNumber.js");
|
|
24
|
+
const SubscriptionHandler_js_1 = require("./SubscriptionHandler.js");
|
|
25
|
+
const Crypto_js_1 = require("../../crypto/Crypto.js");
|
|
26
|
+
const AttributeDataDecoder_js_1 = require("./AttributeDataDecoder.js");
|
|
27
|
+
const CommandServer_js_1 = require("../../cluster/server/CommandServer.js");
|
|
28
|
+
const AttributeServer_js_1 = require("../../cluster/server/AttributeServer.js");
|
|
29
|
+
const DescriptorCluster_js_1 = require("../../cluster/DescriptorCluster.js");
|
|
30
|
+
const Logger_js_1 = require("../../log/Logger.js");
|
|
31
|
+
const String_js_1 = require("../../util/String.js");
|
|
32
|
+
const TlvVoid_js_1 = require("../../tlv/TlvVoid.js");
|
|
33
|
+
exports.INTERACTION_PROTOCOL_ID = 0x0001;
|
|
34
|
+
const logger = Logger_js_1.Logger.get("InteractionProtocol");
|
|
35
|
+
class ClusterServer {
|
|
36
|
+
constructor(clusterDef, features, attributesInitialValues, handlers) {
|
|
37
|
+
this.attributes = {};
|
|
38
|
+
this.commands = new Array();
|
|
39
|
+
this.clusterStorage = null;
|
|
40
|
+
this.attributeStorageListeners = new Map();
|
|
41
|
+
const { id, name, attributes: attributeDefs, commands: commandDefs } = clusterDef;
|
|
42
|
+
this.id = id;
|
|
43
|
+
this.name = name;
|
|
44
|
+
// Create attributes
|
|
45
|
+
attributesInitialValues = Object.assign(Object.assign({}, attributesInitialValues), { clusterRevision: clusterDef.revision, featureMap: features });
|
|
46
|
+
for (const name in attributesInitialValues) {
|
|
47
|
+
const { id, schema, writable, persistent } = attributeDefs[name];
|
|
48
|
+
const validator = typeof schema.validate === 'function' ? schema.validate.bind(schema) : undefined;
|
|
49
|
+
const getter = handlers[`get${(0, String_js_1.capitalize)(name)}`];
|
|
50
|
+
if (getter === undefined) {
|
|
51
|
+
this.attributes[name] = new AttributeServer_js_1.AttributeServer(id, name, schema, validator !== null && validator !== void 0 ? validator : (() => { }), writable, attributesInitialValues[name]);
|
|
52
|
+
}
|
|
53
|
+
else {
|
|
54
|
+
this.attributes[name] = new AttributeServer_js_1.AttributeGetterServer(id, name, schema, validator !== null && validator !== void 0 ? validator : (() => { }), writable, attributesInitialValues[name], getter);
|
|
55
|
+
}
|
|
56
|
+
if (persistent) {
|
|
57
|
+
const listener = (value, version) => this.attributeStorageListener(name, version, value);
|
|
58
|
+
this.attributeStorageListeners.set(id, listener);
|
|
59
|
+
this.attributes[name].addMatterListener(listener);
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
// Create commands
|
|
63
|
+
for (const name in commandDefs) {
|
|
64
|
+
const handler = handlers[name];
|
|
65
|
+
if (handler === undefined)
|
|
66
|
+
continue;
|
|
67
|
+
const { requestId, requestSchema, responseId, responseSchema } = commandDefs[name];
|
|
68
|
+
this.commands.push(new CommandServer_js_1.CommandServer(requestId, responseId, name, requestSchema, responseSchema, (request, session, message) => handler({ request, attributes: this.attributes, session, message })));
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
setStorage(storageContext) {
|
|
72
|
+
this.clusterStorage = storageContext;
|
|
73
|
+
for (const name in this.attributes) {
|
|
74
|
+
const attribute = this.attributes[name];
|
|
75
|
+
if (!this.attributeStorageListeners.has(attribute.id))
|
|
76
|
+
return;
|
|
77
|
+
if (!storageContext.has(attribute.name))
|
|
78
|
+
return;
|
|
79
|
+
try {
|
|
80
|
+
const data = storageContext.get(attribute.name);
|
|
81
|
+
logger.debug(`Restoring attribute ${attribute.name} (${attribute.id}) in cluster ${this.name} (${this.id})`);
|
|
82
|
+
attribute.init(data.value, data.version);
|
|
83
|
+
}
|
|
84
|
+
catch (error) {
|
|
85
|
+
logger.warn(`Failed to restore attribute ${attribute.name} (${attribute.id}) in cluster ${this.name} (${this.id})`, error);
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
attributeStorageListener(attributeName, version, value) {
|
|
90
|
+
if (!this.clusterStorage)
|
|
91
|
+
return;
|
|
92
|
+
logger.debug(`Storing attribute ${attributeName} in cluster ${this.name} (${this.id})`);
|
|
93
|
+
this.clusterStorage.set(attributeName, { version, value });
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
exports.ClusterServer = ClusterServer;
|
|
97
|
+
function commandPathToId({ endpointId, clusterId, commandId }) {
|
|
98
|
+
return `${endpointId}/${clusterId}/${commandId}`;
|
|
99
|
+
}
|
|
100
|
+
exports.commandPathToId = commandPathToId;
|
|
101
|
+
function attributePathToId({ endpointId, clusterId, attributeId }) {
|
|
102
|
+
return `${endpointId}/${clusterId}/${attributeId}`;
|
|
103
|
+
}
|
|
104
|
+
exports.attributePathToId = attributePathToId;
|
|
105
|
+
function toHex(value) {
|
|
106
|
+
return value === undefined ? "*" : `0x${value.toString(16)}`;
|
|
107
|
+
}
|
|
108
|
+
class InteractionServer {
|
|
109
|
+
constructor(storageManager) {
|
|
110
|
+
this.storageManager = storageManager;
|
|
111
|
+
this.endpoints = new Map();
|
|
112
|
+
this.attributes = new Map();
|
|
113
|
+
this.attributePaths = new Array();
|
|
114
|
+
this.commands = new Map();
|
|
115
|
+
this.commandPaths = new Array();
|
|
116
|
+
this.nextSubscriptionId = Crypto_js_1.Crypto.getRandomUInt32();
|
|
117
|
+
}
|
|
118
|
+
getId() {
|
|
119
|
+
return exports.INTERACTION_PROTOCOL_ID;
|
|
120
|
+
}
|
|
121
|
+
addEndpoint(endpointId, device, clusters) {
|
|
122
|
+
// Add the descriptor cluster
|
|
123
|
+
const descriptorCluster = new ClusterServer(DescriptorCluster_js_1.DescriptorCluster, {}, {
|
|
124
|
+
deviceTypeList: [{ revision: 1, deviceType: new DeviceTypeId_js_1.DeviceTypeId(device.code) }],
|
|
125
|
+
serverList: [],
|
|
126
|
+
clientList: [],
|
|
127
|
+
partsList: [],
|
|
128
|
+
}, {});
|
|
129
|
+
clusters.push(descriptorCluster);
|
|
130
|
+
descriptorCluster.attributes.serverList.setLocal(clusters.map(({ id }) => new ClusterId_js_1.ClusterId(id)));
|
|
131
|
+
const clusterEndpointNumber = new EndpointNumber_js_1.EndpointNumber(endpointId);
|
|
132
|
+
const clusterMap = new Map();
|
|
133
|
+
clusters.forEach(cluster => {
|
|
134
|
+
const { id: clusterId, attributes, commands } = cluster;
|
|
135
|
+
cluster.setStorage(this.storageManager.createContext(`Cluster-${clusterEndpointNumber.number}-${clusterId}`));
|
|
136
|
+
clusterMap.set(clusterId, cluster);
|
|
137
|
+
// Add attributes
|
|
138
|
+
for (const name in attributes) {
|
|
139
|
+
const attribute = attributes[name];
|
|
140
|
+
const path = { endpointId, clusterId, attributeId: attribute.id };
|
|
141
|
+
this.attributes.set(attributePathToId(path), attribute);
|
|
142
|
+
this.attributePaths.push(path);
|
|
143
|
+
}
|
|
144
|
+
// Add commands
|
|
145
|
+
commands.forEach(command => {
|
|
146
|
+
const path = { endpointId, clusterId, commandId: command.invokeId };
|
|
147
|
+
this.commands.set(commandPathToId(path), command);
|
|
148
|
+
this.commandPaths.push(path);
|
|
149
|
+
});
|
|
150
|
+
});
|
|
151
|
+
// Add part list if the endpoint is not root
|
|
152
|
+
if (endpointId !== 0) {
|
|
153
|
+
const rootPartsListAttribute = this.attributes.get(attributePathToId({ endpointId: 0, clusterId: DescriptorCluster_js_1.DescriptorCluster.id, attributeId: DescriptorCluster_js_1.DescriptorCluster.attributes.partsList.id }));
|
|
154
|
+
if (rootPartsListAttribute === undefined)
|
|
155
|
+
throw new Error("The root endpoint should be added first!");
|
|
156
|
+
rootPartsListAttribute.setLocal([...rootPartsListAttribute.getLocal(), clusterEndpointNumber]);
|
|
157
|
+
}
|
|
158
|
+
this.endpoints.set(endpointId, Object.assign(Object.assign({}, device), { clusters: clusterMap }));
|
|
159
|
+
return this;
|
|
160
|
+
}
|
|
161
|
+
onNewExchange(exchange) {
|
|
162
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
163
|
+
yield new InteractionMessenger_js_1.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));
|
|
164
|
+
});
|
|
165
|
+
}
|
|
166
|
+
handleReadRequest(exchange, { attributeRequests: attributePaths, isFabricFiltered }) {
|
|
167
|
+
if (attributePaths === undefined) {
|
|
168
|
+
throw new InteractionMessenger_js_1.StatusResponseError("Only Read requests with attributeRequests are supported right now", 143 /* StatusCode.UnsupportedRead */);
|
|
169
|
+
}
|
|
170
|
+
logger.debug(`Received read request from ${exchange.channel.getName()}: ${attributePaths.map(path => this.resolveAttributeName(path)).join(", ")}, isFabricFiltered=${isFabricFiltered}`);
|
|
171
|
+
// UnsupportedNode/UnsupportedEndpoint/UnsupportedCluster/UnsupportedAttribute/UnsupportedRead
|
|
172
|
+
const attributeReports = attributePaths.flatMap((path) => {
|
|
173
|
+
const attributes = this.getAttributes([path]);
|
|
174
|
+
if (attributes.length === 0) {
|
|
175
|
+
logger.debug(`Read from ${exchange.channel.getName()}: ${this.resolveAttributeName(path)} unsupported path`);
|
|
176
|
+
return [{ attributeStatus: { path, status: { status: 134 /* StatusCode.UnsupportedAttribute */ } } }]; // TODO: Find correct status code
|
|
177
|
+
}
|
|
178
|
+
return attributes.map(({ path, attribute }) => {
|
|
179
|
+
const { value, version } = attribute.getWithVersion(exchange.session); // TODO check ACL
|
|
180
|
+
logger.debug(`Read from ${exchange.channel.getName()}: ${this.resolveAttributeName(path)}=${Logger_js_1.Logger.toJSON(value)} (version=${version})`);
|
|
181
|
+
return { attributeData: { path, data: attribute.schema.encodeTlv(value), dataVersion: version } };
|
|
182
|
+
});
|
|
183
|
+
});
|
|
184
|
+
return {
|
|
185
|
+
interactionModelRevision: 1,
|
|
186
|
+
suppressResponse: false,
|
|
187
|
+
attributeReports
|
|
188
|
+
};
|
|
189
|
+
}
|
|
190
|
+
handleWriteRequest(exchange, { suppressResponse, writeRequests }) {
|
|
191
|
+
logger.debug(`Received write request from ${exchange.channel.getName()}: ${writeRequests.map(req => this.resolveAttributeName(req.path)).join(", ")}, suppressResponse=${suppressResponse}`);
|
|
192
|
+
// TODO consider TimedRequest constraints
|
|
193
|
+
const writeData = (0, AttributeDataDecoder_js_1.normalizeAttributeData)(writeRequests, true);
|
|
194
|
+
const writeResults = writeData.flatMap((values) => {
|
|
195
|
+
const { path, dataVersion } = values[0];
|
|
196
|
+
const attributes = this.getAttributes([path], true);
|
|
197
|
+
if (attributes.length === 0) {
|
|
198
|
+
return [{ path, statusCode: 136 /* StatusCode.UnsupportedWrite */ }]; // TODO: Find correct status code
|
|
199
|
+
}
|
|
200
|
+
return attributes.map(({ path, attribute }) => {
|
|
201
|
+
// TODO add checks or dataVersion
|
|
202
|
+
// TODO add ACL checks
|
|
203
|
+
const { schema, defaultValue } = attribute;
|
|
204
|
+
try {
|
|
205
|
+
const value = (0, AttributeDataDecoder_js_1.decodeValueForSchema)(schema, values, defaultValue);
|
|
206
|
+
logger.debug(`Handle write request from ${exchange.channel.getName()} resolved to: ${this.resolveAttributeName(path)}=${Logger_js_1.Logger.toJSON(value)} (Version=${dataVersion})`);
|
|
207
|
+
attribute.set(value, exchange.session);
|
|
208
|
+
}
|
|
209
|
+
catch (error) {
|
|
210
|
+
if (attributes.length === 1) { // For Multi-Attribute-Writes we ignore errors
|
|
211
|
+
logger.error(`Error while handling write request from ${exchange.channel.getName()} to ${this.resolveAttributeName(path)}: ${error.message}`);
|
|
212
|
+
return { path, statusCode: 135 /* StatusCode.ConstraintError */ };
|
|
213
|
+
}
|
|
214
|
+
else {
|
|
215
|
+
logger.debug(`While handling write request from ${exchange.channel.getName()} to ${this.resolveAttributeName(path)} ignored: ${error.message}`);
|
|
216
|
+
}
|
|
217
|
+
}
|
|
218
|
+
return { path, statusCode: 0 /* StatusCode.Success */ };
|
|
219
|
+
});
|
|
220
|
+
//.filter(({ statusCode }) => statusCode !== StatusCode.Success); // see https://github.com/project-chip/connectedhomeip/issues/26198
|
|
221
|
+
});
|
|
222
|
+
// TODO respect suppressResponse, potentially also needs adjustment in InteractionMessenger class!
|
|
223
|
+
const errorResults = writeResults.filter(({ statusCode }) => statusCode !== 0 /* StatusCode.Success */);
|
|
224
|
+
logger.debug(`Write request from ${exchange.channel.getName()} done ${errorResults.length ? `with following errors: ${errorResults.map(({ path, statusCode }) => `${this.resolveAttributeName(path)}=${Logger_js_1.Logger.toJSON(statusCode)}`).join(", ")}` : "without errors"}`);
|
|
225
|
+
return {
|
|
226
|
+
interactionModelRevision: 1,
|
|
227
|
+
writeResponses: writeResults.map(({ path, statusCode }) => ({ path, status: { status: statusCode } })),
|
|
228
|
+
};
|
|
229
|
+
}
|
|
230
|
+
handleSubscribeRequest(exchange, { minIntervalFloorSeconds, maxIntervalCeilingSeconds, attributeRequests, eventRequests, keepSubscriptions }, messenger) {
|
|
231
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
232
|
+
logger.debug(`Received subscribe request from ${exchange.channel.getName()}`);
|
|
233
|
+
if (!exchange.session.isSecure())
|
|
234
|
+
throw new Error("Subscriptions are only implemented on secure sessions");
|
|
235
|
+
const session = exchange.session;
|
|
236
|
+
const fabric = session.getFabric();
|
|
237
|
+
if (fabric === undefined)
|
|
238
|
+
throw new Error("Subscriptions are only implemented after a fabric has been assigned");
|
|
239
|
+
if ((!Array.isArray(attributeRequests) || attributeRequests.length === 0) && (!Array.isArray(eventRequests) || eventRequests.length === 0)) {
|
|
240
|
+
throw new InteractionMessenger_js_1.StatusResponseError("No attributes or events requested", 128 /* StatusCode.InvalidAction */);
|
|
241
|
+
}
|
|
242
|
+
if (!keepSubscriptions) {
|
|
243
|
+
session.clearSubscriptions();
|
|
244
|
+
}
|
|
245
|
+
// TODO add eventsRequest and other missing supports
|
|
246
|
+
if (attributeRequests !== undefined) {
|
|
247
|
+
logger.debug(`Subscribe to ${attributeRequests.map(path => this.resolveAttributeName(path)).join(", ")}`);
|
|
248
|
+
if (attributeRequests.length === 0)
|
|
249
|
+
throw new Error("Unsupported subscription request with empty attribute list");
|
|
250
|
+
if (minIntervalFloorSeconds < 0)
|
|
251
|
+
throw new Error("minIntervalFloorSeconds should be greater or equal to 0");
|
|
252
|
+
if (maxIntervalCeilingSeconds < 0)
|
|
253
|
+
throw new Error("maxIntervalCeilingSeconds should be greater or equal to 1");
|
|
254
|
+
if (maxIntervalCeilingSeconds < minIntervalFloorSeconds)
|
|
255
|
+
throw new Error("maxIntervalCeilingSeconds should be greater or equal to minIntervalFloorSeconds");
|
|
256
|
+
const attributes = this.getAttributes(attributeRequests);
|
|
257
|
+
if (!attributes.length) {
|
|
258
|
+
throw new InteractionMessenger_js_1.StatusResponseError("Attributes not found", 134 /* StatusCode.UnsupportedAttribute */);
|
|
259
|
+
}
|
|
260
|
+
// TODO: Interpret specs:
|
|
261
|
+
// 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)
|
|
262
|
+
if (this.nextSubscriptionId === 0xFFFFFFFF)
|
|
263
|
+
this.nextSubscriptionId = 0;
|
|
264
|
+
const subscriptionId = this.nextSubscriptionId++;
|
|
265
|
+
const subscriptionHandler = new SubscriptionHandler_js_1.SubscriptionHandler(subscriptionId, session.getContext(), fabric, session.getPeerNodeId(), attributes, minIntervalFloorSeconds, maxIntervalCeilingSeconds);
|
|
266
|
+
session.addSubscription(subscriptionHandler);
|
|
267
|
+
// Send initial data report to prime the subscription with initial data
|
|
268
|
+
yield subscriptionHandler.sendInitialReport(messenger, session);
|
|
269
|
+
const maxInterval = subscriptionHandler.getMaxInterval();
|
|
270
|
+
logger.info(`Created subscription ${subscriptionId} for Session ${session.getId()} with ${attributes.length} attributes. Updates: ${minIntervalFloorSeconds} - ${maxIntervalCeilingSeconds} => ${maxInterval} seconds`);
|
|
271
|
+
// Then send the subscription response
|
|
272
|
+
yield messenger.send(4 /* MessageType.SubscribeResponse */, InteractionProtocol_js_1.TlvSubscribeResponse.encode({ subscriptionId, maxInterval, interactionModelRevision: 1 }));
|
|
273
|
+
subscriptionHandler.activateSendingUpdates();
|
|
274
|
+
}
|
|
275
|
+
});
|
|
276
|
+
}
|
|
277
|
+
handleInvokeRequest(exchange, { invokeRequests }, message) {
|
|
278
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
279
|
+
logger.debug(`Received invoke request from ${exchange.channel.getName()}: ${invokeRequests.map(({ commandPath: { endpointId, clusterId, commandId } }) => `${toHex(endpointId)}/${toHex(clusterId)}/${toHex(commandId)}`).join(", ")}`);
|
|
280
|
+
const results = new Array();
|
|
281
|
+
yield Promise.all(invokeRequests.map(({ commandPath, commandFields }) => __awaiter(this, void 0, void 0, function* () {
|
|
282
|
+
if (commandPath.endpointId === undefined) {
|
|
283
|
+
logger.error("Wildcard command invokes not yet supported!");
|
|
284
|
+
results.push({ code: 129 /* StatusCode.UnsupportedCommand */, commandPath, response: TlvVoid_js_1.TlvVoid.encodeTlv(), responseId: 0 });
|
|
285
|
+
return;
|
|
286
|
+
}
|
|
287
|
+
const command = this.commands.get(commandPathToId(commandPath));
|
|
288
|
+
if (command === undefined)
|
|
289
|
+
return;
|
|
290
|
+
// If no arguments are provided in the invoke data (because optional field), we use our type as replacement
|
|
291
|
+
if (commandFields === undefined) {
|
|
292
|
+
commandFields = TlvNoArguments_js_1.TlvNoArguments.encodeTlv(commandFields);
|
|
293
|
+
}
|
|
294
|
+
const result = yield command.invoke(exchange.session, commandFields, message);
|
|
295
|
+
results.push(Object.assign(Object.assign({}, result), { commandPath }));
|
|
296
|
+
})));
|
|
297
|
+
return {
|
|
298
|
+
suppressResponse: false,
|
|
299
|
+
interactionModelRevision: 1,
|
|
300
|
+
invokeResponses: results.map(({ commandPath, responseId, code, response }) => {
|
|
301
|
+
if (response.length === 0) {
|
|
302
|
+
return { status: { commandPath, status: { status: code } } };
|
|
303
|
+
}
|
|
304
|
+
else {
|
|
305
|
+
return { command: { commandPath: Object.assign(Object.assign({}, commandPath), { commandId: responseId }), commandFields: response } };
|
|
306
|
+
}
|
|
307
|
+
}),
|
|
308
|
+
};
|
|
309
|
+
});
|
|
310
|
+
}
|
|
311
|
+
handleTimedRequest(exchange, { timeout }) {
|
|
312
|
+
logger.debug(`Received timed request (${timeout}) from ${exchange.channel.getName()}`);
|
|
313
|
+
// TODO: implement this
|
|
314
|
+
}
|
|
315
|
+
resolveAttributeName({ endpointId, clusterId, attributeId }) {
|
|
316
|
+
var _a;
|
|
317
|
+
if (endpointId === undefined) {
|
|
318
|
+
return `*/${toHex(clusterId)}/${toHex(attributeId)}`;
|
|
319
|
+
}
|
|
320
|
+
const endpoint = this.endpoints.get(endpointId);
|
|
321
|
+
if (endpoint === undefined) {
|
|
322
|
+
return `unknown(${toHex(endpointId)})/${toHex(clusterId)}/${toHex(attributeId)}`;
|
|
323
|
+
}
|
|
324
|
+
const endpointName = `${endpoint.name}(${toHex(endpointId)})`;
|
|
325
|
+
if (clusterId === undefined) {
|
|
326
|
+
return `${endpointName}/*/${toHex(attributeId)}`;
|
|
327
|
+
}
|
|
328
|
+
const cluster = endpoint.clusters.get(clusterId);
|
|
329
|
+
if (cluster === undefined) {
|
|
330
|
+
return `${endpointName}/unknown(${toHex(clusterId)})/${toHex(attributeId)}`;
|
|
331
|
+
}
|
|
332
|
+
const clusterName = `${cluster.name}(${toHex(clusterId)})`;
|
|
333
|
+
if (attributeId === undefined) {
|
|
334
|
+
return `${endpointName}/${clusterName}/*`;
|
|
335
|
+
}
|
|
336
|
+
const attribute = this.attributes.get(attributePathToId({ endpointId, clusterId, attributeId }));
|
|
337
|
+
const attributeName = `${(_a = attribute === null || attribute === void 0 ? void 0 : attribute.name) !== null && _a !== void 0 ? _a : "unknown"}(${toHex(attributeId)})`;
|
|
338
|
+
return `${endpointName}/${clusterName}/${attributeName}`;
|
|
339
|
+
}
|
|
340
|
+
getAttributes(filters, onlyWritable = false) {
|
|
341
|
+
const result = new Array();
|
|
342
|
+
filters.forEach(({ endpointId, clusterId, attributeId }) => {
|
|
343
|
+
if (endpointId !== undefined && clusterId !== undefined && attributeId !== undefined) {
|
|
344
|
+
const path = { endpointId, clusterId, attributeId };
|
|
345
|
+
const attribute = this.attributes.get(attributePathToId(path));
|
|
346
|
+
if (attribute === undefined)
|
|
347
|
+
return;
|
|
348
|
+
if (onlyWritable && !attribute.isWritable)
|
|
349
|
+
return;
|
|
350
|
+
result.push({ path, attribute });
|
|
351
|
+
}
|
|
352
|
+
else {
|
|
353
|
+
this.attributePaths.filter(path => (endpointId === undefined || endpointId === path.endpointId)
|
|
354
|
+
&& (clusterId === undefined || clusterId === path.clusterId)
|
|
355
|
+
&& (attributeId === undefined || attributeId === path.attributeId))
|
|
356
|
+
.forEach(path => {
|
|
357
|
+
const attribute = this.attributes.get(attributePathToId(path));
|
|
358
|
+
if (attribute === undefined)
|
|
359
|
+
return;
|
|
360
|
+
if (onlyWritable && !attribute.isWritable)
|
|
361
|
+
return;
|
|
362
|
+
result.push({ path, attribute });
|
|
363
|
+
});
|
|
364
|
+
}
|
|
365
|
+
});
|
|
366
|
+
return result;
|
|
367
|
+
}
|
|
368
|
+
}
|
|
369
|
+
exports.InteractionServer = InteractionServer;
|