@matter/protocol 0.11.0-alpha.0-20241005-e3e4e4a7a
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/LICENSE +201 -0
- package/dist/cjs/MatterDevice.d.ts +79 -0
- package/dist/cjs/MatterDevice.d.ts.map +1 -0
- package/dist/cjs/MatterDevice.js +253 -0
- package/dist/cjs/MatterDevice.js.map +6 -0
- package/dist/cjs/ble/Ble.d.ts +29 -0
- package/dist/cjs/ble/Ble.d.ts.map +1 -0
- package/dist/cjs/ble/Ble.js +50 -0
- package/dist/cjs/ble/Ble.js.map +6 -0
- package/dist/cjs/ble/BleConsts.d.ts +32 -0
- package/dist/cjs/ble/BleConsts.d.ts.map +1 -0
- package/dist/cjs/ble/BleConsts.js +53 -0
- package/dist/cjs/ble/BleConsts.js.map +6 -0
- package/dist/cjs/ble/BtpSessionHandler.d.ts +87 -0
- package/dist/cjs/ble/BtpSessionHandler.d.ts.map +1 -0
- package/dist/cjs/ble/BtpSessionHandler.js +432 -0
- package/dist/cjs/ble/BtpSessionHandler.js.map +6 -0
- package/dist/cjs/ble/index.d.ts +9 -0
- package/dist/cjs/ble/index.d.ts.map +1 -0
- package/dist/cjs/ble/index.js +26 -0
- package/dist/cjs/ble/index.js.map +6 -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 +171 -0
- package/dist/cjs/certificate/AttestationCertificateManager.js.map +6 -0
- package/dist/cjs/certificate/CertificateManager.d.ts +575 -0
- package/dist/cjs/certificate/CertificateManager.d.ts.map +1 -0
- package/dist/cjs/certificate/CertificateManager.js +810 -0
- package/dist/cjs/certificate/CertificateManager.js.map +6 -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 +54 -0
- package/dist/cjs/certificate/CertificationDeclarationManager.js.map +6 -0
- package/dist/cjs/certificate/ChipPAAuthorities.d.ts +14 -0
- package/dist/cjs/certificate/ChipPAAuthorities.d.ts.map +1 -0
- package/dist/cjs/certificate/ChipPAAuthorities.js +57 -0
- package/dist/cjs/certificate/ChipPAAuthorities.js.map +6 -0
- package/dist/cjs/certificate/DeviceCertification.d.ts +30 -0
- package/dist/cjs/certificate/DeviceCertification.d.ts.map +1 -0
- package/dist/cjs/certificate/DeviceCertification.js +103 -0
- package/dist/cjs/certificate/DeviceCertification.js.map +6 -0
- package/dist/cjs/certificate/RootCertificateManager.d.ts +33 -0
- package/dist/cjs/certificate/RootCertificateManager.d.ts.map +1 -0
- package/dist/cjs/certificate/RootCertificateManager.js +142 -0
- package/dist/cjs/certificate/RootCertificateManager.js.map +6 -0
- package/dist/cjs/certificate/index.d.ts +12 -0
- package/dist/cjs/certificate/index.d.ts.map +1 -0
- package/dist/cjs/certificate/index.js +29 -0
- package/dist/cjs/certificate/index.js.map +6 -0
- package/dist/cjs/cluster/client/AttributeClient.d.ts +61 -0
- package/dist/cjs/cluster/client/AttributeClient.d.ts.map +1 -0
- package/dist/cjs/cluster/client/AttributeClient.js +177 -0
- package/dist/cjs/cluster/client/AttributeClient.js.map +6 -0
- package/dist/cjs/cluster/client/ClusterClient.d.ts +10 -0
- package/dist/cjs/cluster/client/ClusterClient.d.ts.map +1 -0
- package/dist/cjs/cluster/client/ClusterClient.js +281 -0
- package/dist/cjs/cluster/client/ClusterClient.js.map +6 -0
- package/dist/cjs/cluster/client/ClusterClientTypes.d.ts +171 -0
- package/dist/cjs/cluster/client/ClusterClientTypes.d.ts.map +1 -0
- package/dist/cjs/cluster/client/ClusterClientTypes.js +22 -0
- package/dist/cjs/cluster/client/ClusterClientTypes.js.map +6 -0
- package/dist/cjs/cluster/client/EventClient.d.ts +41 -0
- package/dist/cjs/cluster/client/EventClient.d.ts.map +1 -0
- package/dist/cjs/cluster/client/EventClient.js +94 -0
- package/dist/cjs/cluster/client/EventClient.js.map +6 -0
- package/dist/cjs/cluster/client/index.d.ts +10 -0
- package/dist/cjs/cluster/client/index.d.ts.map +1 -0
- package/dist/cjs/cluster/client/index.js +27 -0
- package/dist/cjs/cluster/client/index.js.map +6 -0
- package/dist/cjs/cluster/index.d.ts +8 -0
- package/dist/cjs/cluster/index.d.ts.map +1 -0
- package/dist/cjs/cluster/index.js +25 -0
- package/dist/cjs/cluster/index.js.map +6 -0
- package/dist/cjs/cluster/server/AttributeServer.d.ts +307 -0
- package/dist/cjs/cluster/server/AttributeServer.d.ts.map +1 -0
- package/dist/cjs/cluster/server/AttributeServer.js +734 -0
- package/dist/cjs/cluster/server/AttributeServer.js.map +6 -0
- package/dist/cjs/cluster/server/ClusterDatasource.d.ts +16 -0
- package/dist/cjs/cluster/server/ClusterDatasource.d.ts.map +1 -0
- package/dist/cjs/cluster/server/ClusterDatasource.js +22 -0
- package/dist/cjs/cluster/server/ClusterDatasource.js.map +6 -0
- package/dist/cjs/cluster/server/ClusterServer.d.ts +40 -0
- package/dist/cjs/cluster/server/ClusterServer.d.ts.map +1 -0
- package/dist/cjs/cluster/server/ClusterServer.js +22 -0
- package/dist/cjs/cluster/server/ClusterServer.js.map +6 -0
- package/dist/cjs/cluster/server/CommandServer.d.ts +34 -0
- package/dist/cjs/cluster/server/CommandServer.d.ts.map +1 -0
- package/dist/cjs/cluster/server/CommandServer.js +76 -0
- package/dist/cjs/cluster/server/CommandServer.js.map +6 -0
- package/dist/cjs/cluster/server/EventServer.d.ts +41 -0
- package/dist/cjs/cluster/server/EventServer.d.ts.map +1 -0
- package/dist/cjs/cluster/server/EventServer.js +149 -0
- package/dist/cjs/cluster/server/EventServer.js.map +6 -0
- package/dist/cjs/cluster/server/index.d.ts +11 -0
- package/dist/cjs/cluster/server/index.d.ts.map +1 -0
- package/dist/cjs/cluster/server/index.js +28 -0
- package/dist/cjs/cluster/server/index.js.map +6 -0
- package/dist/cjs/codec/BtpCodec.d.ts +78 -0
- package/dist/cjs/codec/BtpCodec.d.ts.map +1 -0
- package/dist/cjs/codec/BtpCodec.js +254 -0
- package/dist/cjs/codec/BtpCodec.js.map +6 -0
- package/dist/cjs/codec/MessageCodec.d.ts +63 -0
- package/dist/cjs/codec/MessageCodec.d.ts.map +1 -0
- package/dist/cjs/codec/MessageCodec.js +220 -0
- package/dist/cjs/codec/MessageCodec.js.map +6 -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 +36 -0
- package/dist/cjs/codec/index.js.map +6 -0
- package/dist/cjs/common/FailsafeContext.d.ts +79 -0
- package/dist/cjs/common/FailsafeContext.d.ts.map +1 -0
- package/dist/cjs/common/FailsafeContext.js +237 -0
- package/dist/cjs/common/FailsafeContext.js.map +6 -0
- package/dist/cjs/common/FailsafeTimer.d.ts +25 -0
- package/dist/cjs/common/FailsafeTimer.d.ts.map +1 -0
- package/dist/cjs/common/FailsafeTimer.js +91 -0
- package/dist/cjs/common/FailsafeTimer.js.map +6 -0
- package/dist/cjs/common/InstanceBroadcaster.d.ts +273 -0
- package/dist/cjs/common/InstanceBroadcaster.d.ts.map +1 -0
- package/dist/cjs/common/InstanceBroadcaster.js +139 -0
- package/dist/cjs/common/InstanceBroadcaster.js.map +6 -0
- package/dist/cjs/common/OperationalCredentialsTypes.d.ts +21 -0
- package/dist/cjs/common/OperationalCredentialsTypes.d.ts.map +1 -0
- package/dist/cjs/common/OperationalCredentialsTypes.js +45 -0
- package/dist/cjs/common/OperationalCredentialsTypes.js.map +6 -0
- package/dist/cjs/common/Scanner.d.ts +121 -0
- package/dist/cjs/common/Scanner.d.ts.map +1 -0
- package/dist/cjs/common/Scanner.js +51 -0
- package/dist/cjs/common/Scanner.js.map +6 -0
- package/dist/cjs/common/index.d.ts +12 -0
- package/dist/cjs/common/index.d.ts.map +1 -0
- package/dist/cjs/common/index.js +29 -0
- package/dist/cjs/common/index.js.map +6 -0
- package/dist/cjs/endpoint/EndpointInterface.d.ts +37 -0
- package/dist/cjs/endpoint/EndpointInterface.d.ts.map +1 -0
- package/dist/cjs/endpoint/EndpointInterface.js +22 -0
- package/dist/cjs/endpoint/EndpointInterface.js.map +6 -0
- package/dist/cjs/endpoint/EndpointStructureLogger.d.ts +31 -0
- package/dist/cjs/endpoint/EndpointStructureLogger.d.ts.map +1 -0
- package/dist/cjs/endpoint/EndpointStructureLogger.js +236 -0
- package/dist/cjs/endpoint/EndpointStructureLogger.js.map +6 -0
- package/dist/cjs/endpoint/index.d.ts +8 -0
- package/dist/cjs/endpoint/index.d.ts.map +1 -0
- package/dist/cjs/endpoint/index.js +25 -0
- package/dist/cjs/endpoint/index.js.map +6 -0
- package/dist/cjs/fabric/Fabric.d.ts +121 -0
- package/dist/cjs/fabric/Fabric.d.ts.map +1 -0
- package/dist/cjs/fabric/Fabric.js +427 -0
- package/dist/cjs/fabric/Fabric.js.map +6 -0
- package/dist/cjs/fabric/FabricManager.d.ts +44 -0
- package/dist/cjs/fabric/FabricManager.d.ts.map +1 -0
- package/dist/cjs/fabric/FabricManager.js +209 -0
- package/dist/cjs/fabric/FabricManager.js.map +6 -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 +25 -0
- package/dist/cjs/fabric/index.js.map +6 -0
- package/dist/cjs/index.d.ts +20 -0
- package/dist/cjs/index.d.ts.map +1 -0
- package/dist/cjs/index.js +37 -0
- package/dist/cjs/index.js.map +6 -0
- package/dist/cjs/interaction/AccessControlManager.d.ts +49 -0
- package/dist/cjs/interaction/AccessControlManager.d.ts.map +1 -0
- package/dist/cjs/interaction/AccessControlManager.js +248 -0
- package/dist/cjs/interaction/AccessControlManager.js.map +6 -0
- package/dist/cjs/interaction/AttributeDataDecoder.d.ts +52 -0
- package/dist/cjs/interaction/AttributeDataDecoder.d.ts.map +1 -0
- package/dist/cjs/interaction/AttributeDataDecoder.js +185 -0
- package/dist/cjs/interaction/AttributeDataDecoder.js.map +6 -0
- package/dist/cjs/interaction/AttributeDataEncoder.d.ts +71 -0
- package/dist/cjs/interaction/AttributeDataEncoder.d.ts.map +1 -0
- package/dist/cjs/interaction/AttributeDataEncoder.js +190 -0
- package/dist/cjs/interaction/AttributeDataEncoder.js.map +6 -0
- package/dist/cjs/interaction/EventDataDecoder.d.ts +30 -0
- package/dist/cjs/interaction/EventDataDecoder.d.ts.map +1 -0
- package/dist/cjs/interaction/EventDataDecoder.js +103 -0
- package/dist/cjs/interaction/EventDataDecoder.js.map +6 -0
- package/dist/cjs/interaction/EventHandler.d.ts +42 -0
- package/dist/cjs/interaction/EventHandler.d.ts.map +1 -0
- package/dist/cjs/interaction/EventHandler.js +112 -0
- package/dist/cjs/interaction/EventHandler.js.map +6 -0
- package/dist/cjs/interaction/InteractionClient.d.ts +294 -0
- package/dist/cjs/interaction/InteractionClient.d.ts.map +1 -0
- package/dist/cjs/interaction/InteractionClient.js +829 -0
- package/dist/cjs/interaction/InteractionClient.js.map +6 -0
- package/dist/cjs/interaction/InteractionEndpointStructure.d.ts +59 -0
- package/dist/cjs/interaction/InteractionEndpointStructure.d.ts.map +1 -0
- package/dist/cjs/interaction/InteractionEndpointStructure.js +341 -0
- package/dist/cjs/interaction/InteractionEndpointStructure.js.map +6 -0
- package/dist/cjs/interaction/InteractionMessenger.d.ts +315 -0
- package/dist/cjs/interaction/InteractionMessenger.d.ts.map +1 -0
- package/dist/cjs/interaction/InteractionMessenger.js +484 -0
- package/dist/cjs/interaction/InteractionMessenger.js.map +6 -0
- package/dist/cjs/interaction/InteractionServer.d.ts +97 -0
- package/dist/cjs/interaction/InteractionServer.d.ts.map +1 -0
- package/dist/cjs/interaction/InteractionServer.js +1026 -0
- package/dist/cjs/interaction/InteractionServer.js.map +6 -0
- package/dist/cjs/interaction/ServerSubscription.d.ts +121 -0
- package/dist/cjs/interaction/ServerSubscription.d.ts.map +1 -0
- package/dist/cjs/interaction/ServerSubscription.js +672 -0
- package/dist/cjs/interaction/ServerSubscription.js.map +6 -0
- package/dist/cjs/interaction/Subscription.d.ts +44 -0
- package/dist/cjs/interaction/Subscription.d.ts.map +1 -0
- package/dist/cjs/interaction/Subscription.js +85 -0
- package/dist/cjs/interaction/Subscription.js.map +6 -0
- package/dist/cjs/interaction/SubscriptionOptions.d.ts +43 -0
- package/dist/cjs/interaction/SubscriptionOptions.d.ts.map +1 -0
- package/dist/cjs/interaction/SubscriptionOptions.js +46 -0
- package/dist/cjs/interaction/SubscriptionOptions.js.map +6 -0
- package/dist/cjs/interaction/index.d.ts +17 -0
- package/dist/cjs/interaction/index.d.ts.map +1 -0
- package/dist/cjs/interaction/index.js +34 -0
- package/dist/cjs/interaction/index.js.map +6 -0
- package/dist/cjs/mdns/MdnsBroadcaster.d.ts +34 -0
- package/dist/cjs/mdns/MdnsBroadcaster.d.ts.map +1 -0
- package/dist/cjs/mdns/MdnsBroadcaster.js +338 -0
- package/dist/cjs/mdns/MdnsBroadcaster.js.map +6 -0
- package/dist/cjs/mdns/MdnsConsts.d.ts +19 -0
- package/dist/cjs/mdns/MdnsConsts.d.ts.map +1 -0
- package/dist/cjs/mdns/MdnsConsts.js +52 -0
- package/dist/cjs/mdns/MdnsConsts.js.map +6 -0
- package/dist/cjs/mdns/MdnsInstanceBroadcaster.d.ts +28 -0
- package/dist/cjs/mdns/MdnsInstanceBroadcaster.d.ts.map +1 -0
- package/dist/cjs/mdns/MdnsInstanceBroadcaster.js +87 -0
- package/dist/cjs/mdns/MdnsInstanceBroadcaster.js.map +6 -0
- package/dist/cjs/mdns/MdnsScanner.d.ts +79 -0
- package/dist/cjs/mdns/MdnsScanner.d.ts.map +1 -0
- package/dist/cjs/mdns/MdnsScanner.js +842 -0
- package/dist/cjs/mdns/MdnsScanner.js.map +6 -0
- package/dist/cjs/mdns/MdnsServer.d.ts +29 -0
- package/dist/cjs/mdns/MdnsServer.d.ts.map +1 -0
- package/dist/cjs/mdns/MdnsServer.js +275 -0
- package/dist/cjs/mdns/MdnsServer.js.map +6 -0
- package/dist/cjs/mdns/MdnsService.d.ts +28 -0
- package/dist/cjs/mdns/MdnsService.d.ts.map +1 -0
- package/dist/cjs/mdns/MdnsService.js +95 -0
- package/dist/cjs/mdns/MdnsService.js.map +6 -0
- package/dist/cjs/mdns/index.d.ts +12 -0
- package/dist/cjs/mdns/index.d.ts.map +1 -0
- package/dist/cjs/mdns/index.js +29 -0
- package/dist/cjs/mdns/index.js.map +6 -0
- package/dist/cjs/package.json +10 -0
- package/dist/cjs/peer/ControllerCommissioner.d.ts +82 -0
- package/dist/cjs/peer/ControllerCommissioner.d.ts.map +1 -0
- package/dist/cjs/peer/ControllerCommissioner.js +224 -0
- package/dist/cjs/peer/ControllerCommissioner.js.map +6 -0
- package/dist/cjs/peer/ControllerCommissioningFlow.d.ts +88 -0
- package/dist/cjs/peer/ControllerCommissioningFlow.d.ts.map +1 -0
- package/dist/cjs/peer/ControllerCommissioningFlow.js +849 -0
- package/dist/cjs/peer/ControllerCommissioningFlow.js.map +6 -0
- package/dist/cjs/peer/ControllerDiscovery.d.ts +43 -0
- package/dist/cjs/peer/ControllerDiscovery.d.ts.map +1 -0
- package/dist/cjs/peer/ControllerDiscovery.js +192 -0
- package/dist/cjs/peer/ControllerDiscovery.js.map +6 -0
- package/dist/cjs/peer/OperationalPeer.d.ts +28 -0
- package/dist/cjs/peer/OperationalPeer.d.ts.map +1 -0
- package/dist/cjs/peer/OperationalPeer.js +22 -0
- package/dist/cjs/peer/OperationalPeer.js.map +6 -0
- package/dist/cjs/peer/PeerAddress.d.ts +30 -0
- package/dist/cjs/peer/PeerAddress.d.ts.map +1 -0
- package/dist/cjs/peer/PeerAddress.js +71 -0
- package/dist/cjs/peer/PeerAddress.js.map +6 -0
- package/dist/cjs/peer/PeerSet.d.ts +98 -0
- package/dist/cjs/peer/PeerSet.d.ts.map +1 -0
- package/dist/cjs/peer/PeerSet.js +500 -0
- package/dist/cjs/peer/PeerSet.js.map +6 -0
- package/dist/cjs/peer/PeerStore.d.ts +17 -0
- package/dist/cjs/peer/PeerStore.d.ts.map +1 -0
- package/dist/cjs/peer/PeerStore.js +31 -0
- package/dist/cjs/peer/PeerStore.js.map +6 -0
- package/dist/cjs/peer/index.d.ts +13 -0
- package/dist/cjs/peer/index.d.ts.map +1 -0
- package/dist/cjs/peer/index.js +30 -0
- package/dist/cjs/peer/index.js.map +6 -0
- package/dist/cjs/protocol/ChannelManager.d.ts +30 -0
- package/dist/cjs/protocol/ChannelManager.d.ts.map +1 -0
- package/dist/cjs/protocol/ChannelManager.js +168 -0
- package/dist/cjs/protocol/ChannelManager.js.map +6 -0
- package/dist/cjs/protocol/DeviceAdvertiser.d.ts +43 -0
- package/dist/cjs/protocol/DeviceAdvertiser.d.ts.map +1 -0
- package/dist/cjs/protocol/DeviceAdvertiser.js +185 -0
- package/dist/cjs/protocol/DeviceAdvertiser.js.map +6 -0
- package/dist/cjs/protocol/DeviceCommissioner.d.ts +49 -0
- package/dist/cjs/protocol/DeviceCommissioner.d.ts.map +1 -0
- package/dist/cjs/protocol/DeviceCommissioner.js +198 -0
- package/dist/cjs/protocol/DeviceCommissioner.js.map +6 -0
- package/dist/cjs/protocol/ExchangeManager.d.ts +73 -0
- package/dist/cjs/protocol/ExchangeManager.d.ts.map +1 -0
- package/dist/cjs/protocol/ExchangeManager.js +407 -0
- package/dist/cjs/protocol/ExchangeManager.js.map +6 -0
- package/dist/cjs/protocol/MessageCounter.d.ts +57 -0
- package/dist/cjs/protocol/MessageCounter.d.ts.map +1 -0
- package/dist/cjs/protocol/MessageCounter.js +104 -0
- package/dist/cjs/protocol/MessageCounter.js.map +6 -0
- package/dist/cjs/protocol/MessageExchange.d.ts +84 -0
- package/dist/cjs/protocol/MessageExchange.d.ts.map +1 -0
- package/dist/cjs/protocol/MessageExchange.js +508 -0
- package/dist/cjs/protocol/MessageExchange.js.map +6 -0
- package/dist/cjs/protocol/MessageReceptionState.d.ts +65 -0
- package/dist/cjs/protocol/MessageReceptionState.d.ts.map +1 -0
- package/dist/cjs/protocol/MessageReceptionState.js +173 -0
- package/dist/cjs/protocol/MessageReceptionState.js.map +6 -0
- package/dist/cjs/protocol/ProtocolHandler.d.ts +13 -0
- package/dist/cjs/protocol/ProtocolHandler.d.ts.map +1 -0
- package/dist/cjs/protocol/ProtocolHandler.js +22 -0
- package/dist/cjs/protocol/ProtocolHandler.js.map +6 -0
- package/dist/cjs/protocol/index.d.ts +14 -0
- package/dist/cjs/protocol/index.d.ts.map +1 -0
- package/dist/cjs/protocol/index.js +31 -0
- package/dist/cjs/protocol/index.js.map +6 -0
- package/dist/cjs/securechannel/SecureChannelMessenger.d.ts +53 -0
- package/dist/cjs/securechannel/SecureChannelMessenger.d.ts.map +1 -0
- package/dist/cjs/securechannel/SecureChannelMessenger.js +143 -0
- package/dist/cjs/securechannel/SecureChannelMessenger.js.map +6 -0
- package/dist/cjs/securechannel/SecureChannelProtocol.d.ts +31 -0
- package/dist/cjs/securechannel/SecureChannelProtocol.d.ts.map +1 -0
- package/dist/cjs/securechannel/SecureChannelProtocol.js +140 -0
- package/dist/cjs/securechannel/SecureChannelProtocol.js.map +6 -0
- package/dist/cjs/securechannel/SecureChannelStatusMessageSchema.d.ts +23 -0
- package/dist/cjs/securechannel/SecureChannelStatusMessageSchema.d.ts.map +1 -0
- package/dist/cjs/securechannel/SecureChannelStatusMessageSchema.js +53 -0
- package/dist/cjs/securechannel/SecureChannelStatusMessageSchema.js.map +6 -0
- package/dist/cjs/securechannel/index.d.ts +9 -0
- package/dist/cjs/securechannel/index.d.ts.map +1 -0
- package/dist/cjs/securechannel/index.js +26 -0
- package/dist/cjs/securechannel/index.js.map +6 -0
- package/dist/cjs/session/InsecureSession.d.ts +38 -0
- package/dist/cjs/session/InsecureSession.d.ts.map +1 -0
- package/dist/cjs/session/InsecureSession.js +95 -0
- package/dist/cjs/session/InsecureSession.js.map +6 -0
- package/dist/cjs/session/SecureSession.d.ts +81 -0
- package/dist/cjs/session/SecureSession.d.ts.map +1 -0
- package/dist/cjs/session/SecureSession.js +291 -0
- package/dist/cjs/session/SecureSession.js.map +6 -0
- package/dist/cjs/session/Session.d.ts +102 -0
- package/dist/cjs/session/Session.d.ts.map +1 -0
- package/dist/cjs/session/Session.js +141 -0
- package/dist/cjs/session/Session.js.map +6 -0
- package/dist/cjs/session/SessionManager.d.ts +132 -0
- package/dist/cjs/session/SessionManager.d.ts.map +1 -0
- package/dist/cjs/session/SessionManager.js +410 -0
- package/dist/cjs/session/SessionManager.js.map +6 -0
- package/dist/cjs/session/case/CaseClient.d.ts +18 -0
- package/dist/cjs/session/case/CaseClient.d.ts.map +1 -0
- package/dist/cjs/session/case/CaseClient.js +216 -0
- package/dist/cjs/session/case/CaseClient.js.map +6 -0
- package/dist/cjs/session/case/CaseMessages.d.ts +82 -0
- package/dist/cjs/session/case/CaseMessages.d.ts.map +1 -0
- package/dist/cjs/session/case/CaseMessages.js +97 -0
- package/dist/cjs/session/case/CaseMessages.js.map +6 -0
- package/dist/cjs/session/case/CaseMessenger.d.ts +79 -0
- package/dist/cjs/session/case/CaseMessenger.d.ts.map +1 -0
- package/dist/cjs/session/case/CaseMessenger.js +74 -0
- package/dist/cjs/session/case/CaseMessenger.js.map +6 -0
- package/dist/cjs/session/case/CaseServer.d.ts +18 -0
- package/dist/cjs/session/case/CaseServer.d.ts.map +1 -0
- package/dist/cjs/session/case/CaseServer.js +232 -0
- package/dist/cjs/session/case/CaseServer.js.map +6 -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 +35 -0
- package/dist/cjs/session/index.js.map +6 -0
- package/dist/cjs/session/pase/PaseClient.d.ts +18 -0
- package/dist/cjs/session/pase/PaseClient.d.ts.map +1 -0
- package/dist/cjs/session/pase/PaseClient.js +101 -0
- package/dist/cjs/session/pase/PaseClient.js.map +6 -0
- package/dist/cjs/session/pase/PaseMessages.d.ts +85 -0
- package/dist/cjs/session/pase/PaseMessages.d.ts.map +1 -0
- package/dist/cjs/session/pase/PaseMessages.js +88 -0
- package/dist/cjs/session/pase/PaseMessages.js.map +6 -0
- package/dist/cjs/session/pase/PaseMessenger.d.ts +75 -0
- package/dist/cjs/session/pase/PaseMessenger.d.ts.map +1 -0
- package/dist/cjs/session/pase/PaseMessenger.js +86 -0
- package/dist/cjs/session/pase/PaseMessenger.js.map +6 -0
- package/dist/cjs/session/pase/PaseServer.d.ts +29 -0
- package/dist/cjs/session/pase/PaseServer.d.ts.map +1 -0
- package/dist/cjs/session/pase/PaseServer.js +159 -0
- package/dist/cjs/session/pase/PaseServer.js.map +6 -0
- package/dist/cjs/tsconfig.tsbuildinfo +1 -0
- package/dist/esm/MatterDevice.d.ts +79 -0
- package/dist/esm/MatterDevice.d.ts.map +1 -0
- package/dist/esm/MatterDevice.js +239 -0
- package/dist/esm/MatterDevice.js.map +6 -0
- package/dist/esm/ble/Ble.d.ts +29 -0
- package/dist/esm/ble/Ble.d.ts.map +1 -0
- package/dist/esm/ble/Ble.js +30 -0
- package/dist/esm/ble/Ble.js.map +6 -0
- package/dist/esm/ble/BleConsts.d.ts +32 -0
- package/dist/esm/ble/BleConsts.d.ts.map +1 -0
- package/dist/esm/ble/BleConsts.js +33 -0
- package/dist/esm/ble/BleConsts.js.map +6 -0
- package/dist/esm/ble/BtpSessionHandler.d.ts +87 -0
- package/dist/esm/ble/BtpSessionHandler.d.ts.map +1 -0
- package/dist/esm/ble/BtpSessionHandler.js +419 -0
- package/dist/esm/ble/BtpSessionHandler.js.map +6 -0
- package/dist/esm/ble/index.d.ts +9 -0
- package/dist/esm/ble/index.d.ts.map +1 -0
- package/dist/esm/ble/index.js +9 -0
- package/dist/esm/ble/index.js.map +6 -0
- package/dist/esm/certificate/AttestationCertificateManager.d.ts +28 -0
- package/dist/esm/certificate/AttestationCertificateManager.d.ts.map +1 -0
- package/dist/esm/certificate/AttestationCertificateManager.js +155 -0
- package/dist/esm/certificate/AttestationCertificateManager.js.map +6 -0
- package/dist/esm/certificate/CertificateManager.d.ts +575 -0
- package/dist/esm/certificate/CertificateManager.d.ts.map +1 -0
- package/dist/esm/certificate/CertificateManager.js +837 -0
- package/dist/esm/certificate/CertificateManager.js.map +6 -0
- package/dist/esm/certificate/CertificationDeclarationManager.d.ts +5 -0
- package/dist/esm/certificate/CertificationDeclarationManager.d.ts.map +1 -0
- package/dist/esm/certificate/CertificationDeclarationManager.js +34 -0
- package/dist/esm/certificate/CertificationDeclarationManager.js.map +6 -0
- package/dist/esm/certificate/ChipPAAuthorities.d.ts +14 -0
- package/dist/esm/certificate/ChipPAAuthorities.d.ts.map +1 -0
- package/dist/esm/certificate/ChipPAAuthorities.js +37 -0
- package/dist/esm/certificate/ChipPAAuthorities.js.map +6 -0
- package/dist/esm/certificate/DeviceCertification.d.ts +30 -0
- package/dist/esm/certificate/DeviceCertification.d.ts.map +1 -0
- package/dist/esm/certificate/DeviceCertification.js +83 -0
- package/dist/esm/certificate/DeviceCertification.js.map +6 -0
- package/dist/esm/certificate/RootCertificateManager.d.ts +33 -0
- package/dist/esm/certificate/RootCertificateManager.d.ts.map +1 -0
- package/dist/esm/certificate/RootCertificateManager.js +139 -0
- package/dist/esm/certificate/RootCertificateManager.js.map +6 -0
- package/dist/esm/certificate/index.d.ts +12 -0
- package/dist/esm/certificate/index.d.ts.map +1 -0
- package/dist/esm/certificate/index.js +12 -0
- package/dist/esm/certificate/index.js.map +6 -0
- package/dist/esm/cluster/client/AttributeClient.d.ts +61 -0
- package/dist/esm/cluster/client/AttributeClient.d.ts.map +1 -0
- package/dist/esm/cluster/client/AttributeClient.js +157 -0
- package/dist/esm/cluster/client/AttributeClient.js.map +6 -0
- package/dist/esm/cluster/client/ClusterClient.d.ts +10 -0
- package/dist/esm/cluster/client/ClusterClient.d.ts.map +1 -0
- package/dist/esm/cluster/client/ClusterClient.js +267 -0
- package/dist/esm/cluster/client/ClusterClient.js.map +6 -0
- package/dist/esm/cluster/client/ClusterClientTypes.d.ts +171 -0
- package/dist/esm/cluster/client/ClusterClientTypes.d.ts.map +1 -0
- package/dist/esm/cluster/client/ClusterClientTypes.js +6 -0
- package/dist/esm/cluster/client/ClusterClientTypes.js.map +6 -0
- package/dist/esm/cluster/client/EventClient.d.ts +41 -0
- package/dist/esm/cluster/client/EventClient.d.ts.map +1 -0
- package/dist/esm/cluster/client/EventClient.js +74 -0
- package/dist/esm/cluster/client/EventClient.js.map +6 -0
- package/dist/esm/cluster/client/index.d.ts +10 -0
- package/dist/esm/cluster/client/index.d.ts.map +1 -0
- package/dist/esm/cluster/client/index.js +10 -0
- package/dist/esm/cluster/client/index.js.map +6 -0
- package/dist/esm/cluster/index.d.ts +8 -0
- package/dist/esm/cluster/index.d.ts.map +1 -0
- package/dist/esm/cluster/index.js +8 -0
- package/dist/esm/cluster/index.js.map +6 -0
- package/dist/esm/cluster/server/AttributeServer.d.ts +307 -0
- package/dist/esm/cluster/server/AttributeServer.d.ts.map +1 -0
- package/dist/esm/cluster/server/AttributeServer.js +718 -0
- package/dist/esm/cluster/server/AttributeServer.js.map +6 -0
- package/dist/esm/cluster/server/ClusterDatasource.d.ts +16 -0
- package/dist/esm/cluster/server/ClusterDatasource.d.ts.map +1 -0
- package/dist/esm/cluster/server/ClusterDatasource.js +6 -0
- package/dist/esm/cluster/server/ClusterDatasource.js.map +6 -0
- package/dist/esm/cluster/server/ClusterServer.d.ts +40 -0
- package/dist/esm/cluster/server/ClusterServer.d.ts.map +1 -0
- package/dist/esm/cluster/server/ClusterServer.js +6 -0
- package/dist/esm/cluster/server/ClusterServer.js.map +6 -0
- package/dist/esm/cluster/server/CommandServer.d.ts +34 -0
- package/dist/esm/cluster/server/CommandServer.d.ts.map +1 -0
- package/dist/esm/cluster/server/CommandServer.js +56 -0
- package/dist/esm/cluster/server/CommandServer.js.map +6 -0
- package/dist/esm/cluster/server/EventServer.d.ts +41 -0
- package/dist/esm/cluster/server/EventServer.d.ts.map +1 -0
- package/dist/esm/cluster/server/EventServer.js +137 -0
- package/dist/esm/cluster/server/EventServer.js.map +6 -0
- package/dist/esm/cluster/server/index.d.ts +11 -0
- package/dist/esm/cluster/server/index.d.ts.map +1 -0
- package/dist/esm/cluster/server/index.js +11 -0
- package/dist/esm/cluster/server/index.js.map +6 -0
- package/dist/esm/codec/BtpCodec.d.ts +78 -0
- package/dist/esm/codec/BtpCodec.d.ts.map +1 -0
- package/dist/esm/codec/BtpCodec.js +234 -0
- package/dist/esm/codec/BtpCodec.js.map +6 -0
- package/dist/esm/codec/MessageCodec.d.ts +63 -0
- package/dist/esm/codec/MessageCodec.d.ts.map +1 -0
- package/dist/esm/codec/MessageCodec.js +200 -0
- package/dist/esm/codec/MessageCodec.js.map +6 -0
- package/dist/esm/codec/index.d.ts +9 -0
- package/dist/esm/codec/index.d.ts.map +1 -0
- package/dist/esm/codec/index.js +15 -0
- package/dist/esm/codec/index.js.map +6 -0
- package/dist/esm/common/FailsafeContext.d.ts +79 -0
- package/dist/esm/common/FailsafeContext.d.ts.map +1 -0
- package/dist/esm/common/FailsafeContext.js +217 -0
- package/dist/esm/common/FailsafeContext.js.map +6 -0
- package/dist/esm/common/FailsafeTimer.d.ts +25 -0
- package/dist/esm/common/FailsafeTimer.d.ts.map +1 -0
- package/dist/esm/common/FailsafeTimer.js +71 -0
- package/dist/esm/common/FailsafeTimer.js.map +6 -0
- package/dist/esm/common/InstanceBroadcaster.d.ts +273 -0
- package/dist/esm/common/InstanceBroadcaster.d.ts.map +1 -0
- package/dist/esm/common/InstanceBroadcaster.js +119 -0
- package/dist/esm/common/InstanceBroadcaster.js.map +6 -0
- package/dist/esm/common/OperationalCredentialsTypes.d.ts +21 -0
- package/dist/esm/common/OperationalCredentialsTypes.d.ts.map +1 -0
- package/dist/esm/common/OperationalCredentialsTypes.js +25 -0
- package/dist/esm/common/OperationalCredentialsTypes.js.map +6 -0
- package/dist/esm/common/Scanner.d.ts +121 -0
- package/dist/esm/common/Scanner.d.ts.map +1 -0
- package/dist/esm/common/Scanner.js +31 -0
- package/dist/esm/common/Scanner.js.map +6 -0
- package/dist/esm/common/index.d.ts +12 -0
- package/dist/esm/common/index.d.ts.map +1 -0
- package/dist/esm/common/index.js +12 -0
- package/dist/esm/common/index.js.map +6 -0
- package/dist/esm/endpoint/EndpointInterface.d.ts +37 -0
- package/dist/esm/endpoint/EndpointInterface.d.ts.map +1 -0
- package/dist/esm/endpoint/EndpointInterface.js +6 -0
- package/dist/esm/endpoint/EndpointInterface.js.map +6 -0
- package/dist/esm/endpoint/EndpointStructureLogger.d.ts +31 -0
- package/dist/esm/endpoint/EndpointStructureLogger.d.ts.map +1 -0
- package/dist/esm/endpoint/EndpointStructureLogger.js +216 -0
- package/dist/esm/endpoint/EndpointStructureLogger.js.map +6 -0
- package/dist/esm/endpoint/index.d.ts +8 -0
- package/dist/esm/endpoint/index.d.ts.map +1 -0
- package/dist/esm/endpoint/index.js +8 -0
- package/dist/esm/endpoint/index.js.map +6 -0
- package/dist/esm/fabric/Fabric.d.ts +121 -0
- package/dist/esm/fabric/Fabric.d.ts.map +1 -0
- package/dist/esm/fabric/Fabric.js +422 -0
- package/dist/esm/fabric/Fabric.js.map +6 -0
- package/dist/esm/fabric/FabricManager.d.ts +44 -0
- package/dist/esm/fabric/FabricManager.d.ts.map +1 -0
- package/dist/esm/fabric/FabricManager.js +200 -0
- package/dist/esm/fabric/FabricManager.js.map +6 -0
- package/dist/esm/fabric/index.d.ts +8 -0
- package/dist/esm/fabric/index.d.ts.map +1 -0
- package/dist/esm/fabric/index.js +8 -0
- package/dist/esm/fabric/index.js.map +6 -0
- package/dist/esm/index.d.ts +20 -0
- package/dist/esm/index.d.ts.map +1 -0
- package/dist/esm/index.js +20 -0
- package/dist/esm/index.js.map +6 -0
- package/dist/esm/interaction/AccessControlManager.d.ts +49 -0
- package/dist/esm/interaction/AccessControlManager.d.ts.map +1 -0
- package/dist/esm/interaction/AccessControlManager.js +228 -0
- package/dist/esm/interaction/AccessControlManager.js.map +6 -0
- package/dist/esm/interaction/AttributeDataDecoder.d.ts +52 -0
- package/dist/esm/interaction/AttributeDataDecoder.d.ts.map +1 -0
- package/dist/esm/interaction/AttributeDataDecoder.js +171 -0
- package/dist/esm/interaction/AttributeDataDecoder.js.map +6 -0
- package/dist/esm/interaction/AttributeDataEncoder.d.ts +71 -0
- package/dist/esm/interaction/AttributeDataEncoder.d.ts.map +1 -0
- package/dist/esm/interaction/AttributeDataEncoder.js +174 -0
- package/dist/esm/interaction/AttributeDataEncoder.js.map +6 -0
- package/dist/esm/interaction/EventDataDecoder.d.ts +30 -0
- package/dist/esm/interaction/EventDataDecoder.d.ts.map +1 -0
- package/dist/esm/interaction/EventDataDecoder.js +87 -0
- package/dist/esm/interaction/EventDataDecoder.js.map +6 -0
- package/dist/esm/interaction/EventHandler.d.ts +42 -0
- package/dist/esm/interaction/EventHandler.d.ts.map +1 -0
- package/dist/esm/interaction/EventHandler.js +96 -0
- package/dist/esm/interaction/EventHandler.js.map +6 -0
- package/dist/esm/interaction/InteractionClient.d.ts +294 -0
- package/dist/esm/interaction/InteractionClient.d.ts.map +1 -0
- package/dist/esm/interaction/InteractionClient.js +827 -0
- package/dist/esm/interaction/InteractionClient.js.map +6 -0
- package/dist/esm/interaction/InteractionEndpointStructure.d.ts +59 -0
- package/dist/esm/interaction/InteractionEndpointStructure.d.ts.map +1 -0
- package/dist/esm/interaction/InteractionEndpointStructure.js +343 -0
- package/dist/esm/interaction/InteractionEndpointStructure.js.map +6 -0
- package/dist/esm/interaction/InteractionMessenger.d.ts +315 -0
- package/dist/esm/interaction/InteractionMessenger.d.ts.map +1 -0
- package/dist/esm/interaction/InteractionMessenger.js +489 -0
- package/dist/esm/interaction/InteractionMessenger.js.map +6 -0
- package/dist/esm/interaction/InteractionServer.d.ts +97 -0
- package/dist/esm/interaction/InteractionServer.d.ts.map +1 -0
- package/dist/esm/interaction/InteractionServer.js +1027 -0
- package/dist/esm/interaction/InteractionServer.js.map +6 -0
- package/dist/esm/interaction/ServerSubscription.d.ts +121 -0
- package/dist/esm/interaction/ServerSubscription.d.ts.map +1 -0
- package/dist/esm/interaction/ServerSubscription.js +669 -0
- package/dist/esm/interaction/ServerSubscription.js.map +6 -0
- package/dist/esm/interaction/Subscription.d.ts +44 -0
- package/dist/esm/interaction/Subscription.d.ts.map +1 -0
- package/dist/esm/interaction/Subscription.js +65 -0
- package/dist/esm/interaction/Subscription.js.map +6 -0
- package/dist/esm/interaction/SubscriptionOptions.d.ts +43 -0
- package/dist/esm/interaction/SubscriptionOptions.d.ts.map +1 -0
- package/dist/esm/interaction/SubscriptionOptions.js +26 -0
- package/dist/esm/interaction/SubscriptionOptions.js.map +6 -0
- package/dist/esm/interaction/index.d.ts +17 -0
- package/dist/esm/interaction/index.d.ts.map +1 -0
- package/dist/esm/interaction/index.js +17 -0
- package/dist/esm/interaction/index.js.map +6 -0
- package/dist/esm/mdns/MdnsBroadcaster.d.ts +34 -0
- package/dist/esm/mdns/MdnsBroadcaster.d.ts.map +1 -0
- package/dist/esm/mdns/MdnsBroadcaster.js +351 -0
- package/dist/esm/mdns/MdnsBroadcaster.js.map +6 -0
- package/dist/esm/mdns/MdnsConsts.d.ts +19 -0
- package/dist/esm/mdns/MdnsConsts.d.ts.map +1 -0
- package/dist/esm/mdns/MdnsConsts.js +32 -0
- package/dist/esm/mdns/MdnsConsts.js.map +6 -0
- package/dist/esm/mdns/MdnsInstanceBroadcaster.d.ts +28 -0
- package/dist/esm/mdns/MdnsInstanceBroadcaster.d.ts.map +1 -0
- package/dist/esm/mdns/MdnsInstanceBroadcaster.js +67 -0
- package/dist/esm/mdns/MdnsInstanceBroadcaster.js.map +6 -0
- package/dist/esm/mdns/MdnsScanner.d.ts +79 -0
- package/dist/esm/mdns/MdnsScanner.d.ts.map +1 -0
- package/dist/esm/mdns/MdnsScanner.js +847 -0
- package/dist/esm/mdns/MdnsScanner.js.map +6 -0
- package/dist/esm/mdns/MdnsServer.d.ts +29 -0
- package/dist/esm/mdns/MdnsServer.d.ts.map +1 -0
- package/dist/esm/mdns/MdnsServer.js +266 -0
- package/dist/esm/mdns/MdnsServer.js.map +6 -0
- package/dist/esm/mdns/MdnsService.d.ts +28 -0
- package/dist/esm/mdns/MdnsService.d.ts.map +1 -0
- package/dist/esm/mdns/MdnsService.js +83 -0
- package/dist/esm/mdns/MdnsService.js.map +6 -0
- package/dist/esm/mdns/index.d.ts +12 -0
- package/dist/esm/mdns/index.d.ts.map +1 -0
- package/dist/esm/mdns/index.js +12 -0
- package/dist/esm/mdns/index.js.map +6 -0
- package/dist/esm/package.json +10 -0
- package/dist/esm/peer/ControllerCommissioner.d.ts +82 -0
- package/dist/esm/peer/ControllerCommissioner.d.ts.map +1 -0
- package/dist/esm/peer/ControllerCommissioner.js +211 -0
- package/dist/esm/peer/ControllerCommissioner.js.map +6 -0
- package/dist/esm/peer/ControllerCommissioningFlow.d.ts +88 -0
- package/dist/esm/peer/ControllerCommissioningFlow.d.ts.map +1 -0
- package/dist/esm/peer/ControllerCommissioningFlow.js +832 -0
- package/dist/esm/peer/ControllerCommissioningFlow.js.map +6 -0
- package/dist/esm/peer/ControllerDiscovery.d.ts +43 -0
- package/dist/esm/peer/ControllerDiscovery.d.ts.map +1 -0
- package/dist/esm/peer/ControllerDiscovery.js +172 -0
- package/dist/esm/peer/ControllerDiscovery.js.map +6 -0
- package/dist/esm/peer/OperationalPeer.d.ts +28 -0
- package/dist/esm/peer/OperationalPeer.d.ts.map +1 -0
- package/dist/esm/peer/OperationalPeer.js +6 -0
- package/dist/esm/peer/OperationalPeer.js.map +6 -0
- package/dist/esm/peer/PeerAddress.d.ts +30 -0
- package/dist/esm/peer/PeerAddress.d.ts.map +1 -0
- package/dist/esm/peer/PeerAddress.js +51 -0
- package/dist/esm/peer/PeerAddress.js.map +6 -0
- package/dist/esm/peer/PeerSet.d.ts +98 -0
- package/dist/esm/peer/PeerSet.d.ts.map +1 -0
- package/dist/esm/peer/PeerSet.js +495 -0
- package/dist/esm/peer/PeerSet.js.map +6 -0
- package/dist/esm/peer/PeerStore.d.ts +17 -0
- package/dist/esm/peer/PeerStore.d.ts.map +1 -0
- package/dist/esm/peer/PeerStore.js +11 -0
- package/dist/esm/peer/PeerStore.js.map +6 -0
- package/dist/esm/peer/index.d.ts +13 -0
- package/dist/esm/peer/index.d.ts.map +1 -0
- package/dist/esm/peer/index.js +13 -0
- package/dist/esm/peer/index.js.map +6 -0
- package/dist/esm/protocol/ChannelManager.d.ts +30 -0
- package/dist/esm/protocol/ChannelManager.d.ts.map +1 -0
- package/dist/esm/protocol/ChannelManager.js +148 -0
- package/dist/esm/protocol/ChannelManager.js.map +6 -0
- package/dist/esm/protocol/DeviceAdvertiser.d.ts +43 -0
- package/dist/esm/protocol/DeviceAdvertiser.d.ts.map +1 -0
- package/dist/esm/protocol/DeviceAdvertiser.js +173 -0
- package/dist/esm/protocol/DeviceAdvertiser.js.map +6 -0
- package/dist/esm/protocol/DeviceCommissioner.d.ts +49 -0
- package/dist/esm/protocol/DeviceCommissioner.d.ts.map +1 -0
- package/dist/esm/protocol/DeviceCommissioner.js +187 -0
- package/dist/esm/protocol/DeviceCommissioner.js.map +6 -0
- package/dist/esm/protocol/ExchangeManager.d.ts +73 -0
- package/dist/esm/protocol/ExchangeManager.d.ts.map +1 -0
- package/dist/esm/protocol/ExchangeManager.js +398 -0
- package/dist/esm/protocol/ExchangeManager.js.map +6 -0
- package/dist/esm/protocol/MessageCounter.d.ts +57 -0
- package/dist/esm/protocol/MessageCounter.d.ts.map +1 -0
- package/dist/esm/protocol/MessageCounter.js +84 -0
- package/dist/esm/protocol/MessageCounter.js.map +6 -0
- package/dist/esm/protocol/MessageExchange.d.ts +84 -0
- package/dist/esm/protocol/MessageExchange.d.ts.map +1 -0
- package/dist/esm/protocol/MessageExchange.js +504 -0
- package/dist/esm/protocol/MessageExchange.js.map +6 -0
- package/dist/esm/protocol/MessageReceptionState.d.ts +65 -0
- package/dist/esm/protocol/MessageReceptionState.d.ts.map +1 -0
- package/dist/esm/protocol/MessageReceptionState.js +153 -0
- package/dist/esm/protocol/MessageReceptionState.js.map +6 -0
- package/dist/esm/protocol/ProtocolHandler.d.ts +13 -0
- package/dist/esm/protocol/ProtocolHandler.d.ts.map +1 -0
- package/dist/esm/protocol/ProtocolHandler.js +6 -0
- package/dist/esm/protocol/ProtocolHandler.js.map +6 -0
- package/dist/esm/protocol/index.d.ts +14 -0
- package/dist/esm/protocol/index.d.ts.map +1 -0
- package/dist/esm/protocol/index.js +14 -0
- package/dist/esm/protocol/index.js.map +6 -0
- package/dist/esm/securechannel/SecureChannelMessenger.d.ts +53 -0
- package/dist/esm/securechannel/SecureChannelMessenger.d.ts.map +1 -0
- package/dist/esm/securechannel/SecureChannelMessenger.js +128 -0
- package/dist/esm/securechannel/SecureChannelMessenger.js.map +6 -0
- package/dist/esm/securechannel/SecureChannelProtocol.d.ts +31 -0
- package/dist/esm/securechannel/SecureChannelProtocol.d.ts.map +1 -0
- package/dist/esm/securechannel/SecureChannelProtocol.js +127 -0
- package/dist/esm/securechannel/SecureChannelProtocol.js.map +6 -0
- package/dist/esm/securechannel/SecureChannelStatusMessageSchema.d.ts +23 -0
- package/dist/esm/securechannel/SecureChannelStatusMessageSchema.d.ts.map +1 -0
- package/dist/esm/securechannel/SecureChannelStatusMessageSchema.js +33 -0
- package/dist/esm/securechannel/SecureChannelStatusMessageSchema.js.map +6 -0
- package/dist/esm/securechannel/index.d.ts +9 -0
- package/dist/esm/securechannel/index.d.ts.map +1 -0
- package/dist/esm/securechannel/index.js +9 -0
- package/dist/esm/securechannel/index.js.map +6 -0
- package/dist/esm/session/InsecureSession.d.ts +38 -0
- package/dist/esm/session/InsecureSession.d.ts.map +1 -0
- package/dist/esm/session/InsecureSession.js +75 -0
- package/dist/esm/session/InsecureSession.js.map +6 -0
- package/dist/esm/session/SecureSession.d.ts +81 -0
- package/dist/esm/session/SecureSession.d.ts.map +1 -0
- package/dist/esm/session/SecureSession.js +281 -0
- package/dist/esm/session/SecureSession.js.map +6 -0
- package/dist/esm/session/Session.d.ts +102 -0
- package/dist/esm/session/Session.d.ts.map +1 -0
- package/dist/esm/session/Session.js +121 -0
- package/dist/esm/session/Session.js.map +6 -0
- package/dist/esm/session/SessionManager.d.ts +132 -0
- package/dist/esm/session/SessionManager.d.ts.map +1 -0
- package/dist/esm/session/SessionManager.js +411 -0
- package/dist/esm/session/SessionManager.js.map +6 -0
- package/dist/esm/session/case/CaseClient.d.ts +18 -0
- package/dist/esm/session/case/CaseClient.d.ts.map +1 -0
- package/dist/esm/session/case/CaseClient.js +208 -0
- package/dist/esm/session/case/CaseClient.js.map +6 -0
- package/dist/esm/session/case/CaseMessages.d.ts +82 -0
- package/dist/esm/session/case/CaseMessages.d.ts.map +1 -0
- package/dist/esm/session/case/CaseMessages.js +83 -0
- package/dist/esm/session/case/CaseMessages.js.map +6 -0
- package/dist/esm/session/case/CaseMessenger.d.ts +79 -0
- package/dist/esm/session/case/CaseMessenger.d.ts.map +1 -0
- package/dist/esm/session/case/CaseMessenger.js +54 -0
- package/dist/esm/session/case/CaseMessenger.js.map +6 -0
- package/dist/esm/session/case/CaseServer.d.ts +18 -0
- package/dist/esm/session/case/CaseServer.d.ts.map +1 -0
- package/dist/esm/session/case/CaseServer.js +224 -0
- package/dist/esm/session/case/CaseServer.js.map +6 -0
- package/dist/esm/session/index.d.ts +18 -0
- package/dist/esm/session/index.d.ts.map +1 -0
- package/dist/esm/session/index.js +18 -0
- package/dist/esm/session/index.js.map +6 -0
- package/dist/esm/session/pase/PaseClient.d.ts +18 -0
- package/dist/esm/session/pase/PaseClient.d.ts.map +1 -0
- package/dist/esm/session/pase/PaseClient.js +81 -0
- package/dist/esm/session/pase/PaseClient.js.map +6 -0
- package/dist/esm/session/pase/PaseMessages.d.ts +85 -0
- package/dist/esm/session/pase/PaseMessages.d.ts.map +1 -0
- package/dist/esm/session/pase/PaseMessages.js +68 -0
- package/dist/esm/session/pase/PaseMessages.js.map +6 -0
- package/dist/esm/session/pase/PaseMessenger.d.ts +75 -0
- package/dist/esm/session/pase/PaseMessenger.d.ts.map +1 -0
- package/dist/esm/session/pase/PaseMessenger.js +75 -0
- package/dist/esm/session/pase/PaseMessenger.js.map +6 -0
- package/dist/esm/session/pase/PaseServer.d.ts +29 -0
- package/dist/esm/session/pase/PaseServer.d.ts.map +1 -0
- package/dist/esm/session/pase/PaseServer.js +148 -0
- package/dist/esm/session/pase/PaseServer.js.map +6 -0
- package/dist/esm/tsconfig.tsbuildinfo +1 -0
- package/package.json +83 -0
- package/src/MatterDevice.ts +319 -0
- package/src/ble/Ble.ts +40 -0
- package/src/ble/BleConsts.ts +41 -0
- package/src/ble/BtpSessionHandler.ts +490 -0
- package/src/ble/index.ts +9 -0
- package/src/certificate/AttestationCertificateManager.ts +166 -0
- package/src/certificate/CertificateManager.ts +1136 -0
- package/src/certificate/CertificationDeclarationManager.ts +52 -0
- package/src/certificate/ChipPAAuthorities.ts +35 -0
- package/src/certificate/DeviceCertification.ts +116 -0
- package/src/certificate/RootCertificateManager.ts +179 -0
- package/src/certificate/index.ts +12 -0
- package/src/cluster/client/AttributeClient.ts +196 -0
- package/src/cluster/client/ClusterClient.ts +354 -0
- package/src/cluster/client/ClusterClientTypes.ts +257 -0
- package/src/cluster/client/EventClient.ts +110 -0
- package/src/cluster/client/index.ts +10 -0
- package/src/cluster/index.ts +8 -0
- package/src/cluster/server/AttributeServer.ts +986 -0
- package/src/cluster/server/ClusterDatasource.ts +17 -0
- package/src/cluster/server/ClusterServer.ts +46 -0
- package/src/cluster/server/CommandServer.ts +89 -0
- package/src/cluster/server/EventServer.ts +198 -0
- package/src/cluster/server/index.ts +11 -0
- package/src/codec/BtpCodec.ts +333 -0
- package/src/codec/MessageCodec.ts +276 -0
- package/src/codec/index.ts +9 -0
- package/src/common/FailsafeContext.ts +330 -0
- package/src/common/FailsafeTimer.ts +91 -0
- package/src/common/InstanceBroadcaster.ts +220 -0
- package/src/common/OperationalCredentialsTypes.ts +24 -0
- package/src/common/Scanner.ts +188 -0
- package/src/common/index.ts +12 -0
- package/src/endpoint/EndpointInterface.ts +41 -0
- package/src/endpoint/EndpointStructureLogger.ts +277 -0
- package/src/endpoint/index.ts +8 -0
- package/src/fabric/Fabric.ts +528 -0
- package/src/fabric/FabricManager.ts +231 -0
- package/src/fabric/index.ts +8 -0
- package/src/index.ts +20 -0
- package/src/interaction/AccessControlManager.ts +343 -0
- package/src/interaction/AttributeDataDecoder.ts +266 -0
- package/src/interaction/AttributeDataEncoder.ts +268 -0
- package/src/interaction/EventDataDecoder.ts +133 -0
- package/src/interaction/EventHandler.ts +141 -0
- package/src/interaction/InteractionClient.ts +1215 -0
- package/src/interaction/InteractionEndpointStructure.ts +462 -0
- package/src/interaction/InteractionMessenger.ts +592 -0
- package/src/interaction/InteractionServer.ts +1428 -0
- package/src/interaction/ServerSubscription.ts +908 -0
- package/src/interaction/Subscription.ts +89 -0
- package/src/interaction/SubscriptionOptions.ts +49 -0
- package/src/interaction/index.ts +17 -0
- package/src/mdns/MdnsBroadcaster.ts +415 -0
- package/src/mdns/MdnsConsts.ts +24 -0
- package/src/mdns/MdnsInstanceBroadcaster.ts +88 -0
- package/src/mdns/MdnsScanner.ts +1042 -0
- package/src/mdns/MdnsServer.ts +322 -0
- package/src/mdns/MdnsService.ts +102 -0
- package/src/mdns/index.ts +12 -0
- package/src/peer/ControllerCommissioner.ts +372 -0
- package/src/peer/ControllerCommissioningFlow.ts +1127 -0
- package/src/peer/ControllerDiscovery.ts +231 -0
- package/src/peer/OperationalPeer.ts +32 -0
- package/src/peer/PeerAddress.ts +78 -0
- package/src/peer/PeerSet.ts +684 -0
- package/src/peer/PeerStore.ts +19 -0
- package/src/peer/index.ts +13 -0
- package/src/protocol/ChannelManager.ts +168 -0
- package/src/protocol/DeviceAdvertiser.ts +208 -0
- package/src/protocol/DeviceCommissioner.ts +280 -0
- package/src/protocol/ExchangeManager.ts +493 -0
- package/src/protocol/MessageCounter.ts +128 -0
- package/src/protocol/MessageExchange.ts +662 -0
- package/src/protocol/MessageReceptionState.ts +207 -0
- package/src/protocol/ProtocolHandler.ts +14 -0
- package/src/protocol/index.ts +14 -0
- package/src/securechannel/SecureChannelMessenger.ts +166 -0
- package/src/securechannel/SecureChannelProtocol.ts +150 -0
- package/src/securechannel/SecureChannelStatusMessageSchema.ts +40 -0
- package/src/securechannel/index.ts +10 -0
- package/src/session/InsecureSession.ts +96 -0
- package/src/session/SecureSession.ts +349 -0
- package/src/session/Session.ts +188 -0
- package/src/session/SessionManager.ts +559 -0
- package/src/session/case/CaseClient.ts +235 -0
- package/src/session/case/CaseMessages.ts +81 -0
- package/src/session/case/CaseMessenger.ts +57 -0
- package/src/session/case/CaseServer.ts +269 -0
- package/src/session/index.ts +21 -0
- package/src/session/pase/PaseClient.ts +100 -0
- package/src/session/pase/PaseMessages.ts +72 -0
- package/src/session/pase/PaseMessenger.ts +86 -0
- package/src/session/pase/PaseServer.ts +187 -0
- package/src/tsconfig.json +20 -0
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2022-2024 Matter.js Authors
|
|
4
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
export * from "./ControllerCommissioner.js";
|
|
8
|
+
export * from "./ControllerCommissioningFlow.js";
|
|
9
|
+
export * from "./ControllerDiscovery.js";
|
|
10
|
+
export * from "./OperationalPeer.js";
|
|
11
|
+
export * from "./PeerAddress.js";
|
|
12
|
+
export * from "./PeerSet.js";
|
|
13
|
+
export * from "./PeerStore.js";
|
|
@@ -0,0 +1,168 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2022-2024 Matter.js Authors
|
|
4
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
import { Channel, Environment, Environmental, Logger, MatterError } from "#general";
|
|
8
|
+
import { PeerAddress, PeerAddressMap } from "#peer/PeerAddress.js";
|
|
9
|
+
import { SecureSession } from "../session/SecureSession.js";
|
|
10
|
+
import { Session } from "../session/Session.js";
|
|
11
|
+
import { MessageChannel } from "./ExchangeManager.js";
|
|
12
|
+
|
|
13
|
+
const logger = Logger.get("ChannelManager");
|
|
14
|
+
|
|
15
|
+
export class NoChannelError extends MatterError {}
|
|
16
|
+
|
|
17
|
+
export class ChannelManager {
|
|
18
|
+
readonly #channels = new PeerAddressMap<MessageChannel[]>();
|
|
19
|
+
readonly #paseChannels = new Map<Session, MessageChannel>();
|
|
20
|
+
#caseSessionsPerFabricAndNode: number;
|
|
21
|
+
|
|
22
|
+
// TODO evaluate with controller the effects of limiting the entries just for FabricIndex and not also NodeId
|
|
23
|
+
constructor(caseSessionsPerFabricAndNode = 3) {
|
|
24
|
+
this.#caseSessionsPerFabricAndNode = caseSessionsPerFabricAndNode;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
[Environmental.create](env: Environment) {
|
|
28
|
+
const instance = new ChannelManager();
|
|
29
|
+
env.set(ChannelManager, this);
|
|
30
|
+
return instance;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
set caseSessionsPerFabricAndNode(count: number) {
|
|
34
|
+
this.#caseSessionsPerFabricAndNode = count;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
#findLeastActiveChannel(channels: MessageChannel[]) {
|
|
38
|
+
let oldest = channels[0];
|
|
39
|
+
for (const channel of channels) {
|
|
40
|
+
if (channel.session.timestamp < oldest.session.timestamp) {
|
|
41
|
+
oldest = channel;
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
return oldest;
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
async setChannel(address: PeerAddress, channel: MessageChannel) {
|
|
48
|
+
channel.closeCallback = async () => this.removeChannel(address, channel.session);
|
|
49
|
+
const currentChannels = this.#channels.get(address) ?? [];
|
|
50
|
+
currentChannels.push(channel);
|
|
51
|
+
this.#channels.set(address, currentChannels);
|
|
52
|
+
if (currentChannels.length > this.#caseSessionsPerFabricAndNode) {
|
|
53
|
+
const oldestChannel = this.#findLeastActiveChannel(currentChannels);
|
|
54
|
+
|
|
55
|
+
const { session: oldSession } = oldestChannel;
|
|
56
|
+
// Should always be the case
|
|
57
|
+
if (channel.session.id !== oldSession.id) {
|
|
58
|
+
await oldSession.destroy(false, false);
|
|
59
|
+
}
|
|
60
|
+
logger.info(`Close oldest channel for fabric ${PeerAddress(address)} (from session ${oldSession.id})`);
|
|
61
|
+
await oldestChannel.close();
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
hasChannel(address: PeerAddress) {
|
|
66
|
+
return !!this.#channels.get(address)?.length;
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
getChannel(address: PeerAddress, session?: Session) {
|
|
70
|
+
let results = this.#channels.get(address) ?? [];
|
|
71
|
+
if (session !== undefined) {
|
|
72
|
+
results = results.filter(channel => channel.session.id === session.id);
|
|
73
|
+
}
|
|
74
|
+
if (results.length === 0)
|
|
75
|
+
throw new NoChannelError(
|
|
76
|
+
`Can't find a channel to ${PeerAddress(address)}${session !== undefined ? ` session ${session.id}` : ""}`,
|
|
77
|
+
);
|
|
78
|
+
return results[results.length - 1]; // Return the latest added channel (or the one belonging to the session requested)
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
/**
|
|
82
|
+
* Returns the last established session for a Fabric and Node
|
|
83
|
+
*/
|
|
84
|
+
getChannelForSession(session: Session) {
|
|
85
|
+
if (session.isSecure && !session.isPase) {
|
|
86
|
+
const secureSession = session as SecureSession;
|
|
87
|
+
const fabric = secureSession.fabric;
|
|
88
|
+
const nodeId = secureSession.peerNodeId;
|
|
89
|
+
if (fabric === undefined) {
|
|
90
|
+
return this.#paseChannels.get(session);
|
|
91
|
+
}
|
|
92
|
+
return this.getChannel(fabric.addressOf(nodeId), session);
|
|
93
|
+
}
|
|
94
|
+
return this.#paseChannels.get(session);
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
async removeAllNodeChannels(address: PeerAddress) {
|
|
98
|
+
const channelsToRemove = this.#channels.get(address) ?? [];
|
|
99
|
+
for (const channel of channelsToRemove) {
|
|
100
|
+
await channel.close();
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
async removeChannel(address: PeerAddress, session: Session) {
|
|
105
|
+
const fabricChannels = this.#channels.get(address) ?? [];
|
|
106
|
+
const channelEntryIndex = fabricChannels.findIndex(
|
|
107
|
+
({ session: entrySession }) => entrySession.id === session.id,
|
|
108
|
+
);
|
|
109
|
+
if (channelEntryIndex === -1) {
|
|
110
|
+
// Seems already removed
|
|
111
|
+
return;
|
|
112
|
+
}
|
|
113
|
+
const channelEntry = fabricChannels.splice(channelEntryIndex, 1)[0];
|
|
114
|
+
if (channelEntry === undefined) {
|
|
115
|
+
return;
|
|
116
|
+
}
|
|
117
|
+
await channelEntry.close();
|
|
118
|
+
this.#channels.set(address, fabricChannels);
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
private getOrCreateAsPaseChannel(byteArrayChannel: Channel<Uint8Array>, session: Session) {
|
|
122
|
+
const msgChannel = new MessageChannel(
|
|
123
|
+
byteArrayChannel,
|
|
124
|
+
session,
|
|
125
|
+
async () => void this.#paseChannels.delete(session),
|
|
126
|
+
);
|
|
127
|
+
this.#paseChannels.set(session, msgChannel);
|
|
128
|
+
return msgChannel;
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
async getOrCreateChannel(byteArrayChannel: Channel<Uint8Array>, session: Session) {
|
|
132
|
+
if (!session.isSecure) {
|
|
133
|
+
return this.getOrCreateAsPaseChannel(byteArrayChannel, session);
|
|
134
|
+
}
|
|
135
|
+
const secureSession = session as SecureSession;
|
|
136
|
+
const fabric = secureSession.fabric;
|
|
137
|
+
const nodeId = secureSession.peerNodeId;
|
|
138
|
+
if (fabric === undefined) {
|
|
139
|
+
return this.getOrCreateAsPaseChannel(byteArrayChannel, session);
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
// Try to get
|
|
143
|
+
const address = fabric.addressOf(nodeId);
|
|
144
|
+
try {
|
|
145
|
+
return this.getChannel(address, session);
|
|
146
|
+
} catch (e) {
|
|
147
|
+
NoChannelError.accept(e);
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
// Need to create
|
|
151
|
+
const result = new MessageChannel(byteArrayChannel, session, async () => this.removeChannel(address, session));
|
|
152
|
+
await this.setChannel(address, result);
|
|
153
|
+
return result;
|
|
154
|
+
}
|
|
155
|
+
|
|
156
|
+
async close() {
|
|
157
|
+
for (const channel of this.#paseChannels.values()) {
|
|
158
|
+
await channel.close();
|
|
159
|
+
}
|
|
160
|
+
this.#paseChannels.clear();
|
|
161
|
+
for (const channels of this.#channels.values()) {
|
|
162
|
+
for (const channel of channels) {
|
|
163
|
+
await channel.close();
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
this.#channels.clear();
|
|
167
|
+
}
|
|
168
|
+
}
|
|
@@ -0,0 +1,208 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2022-2024 Matter.js Authors
|
|
4
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
import { CommissioningMode, CommissioningModeInstanceData, InstanceBroadcaster } from "#common/InstanceBroadcaster.js";
|
|
8
|
+
import { Fabric } from "#fabric/Fabric.js";
|
|
9
|
+
import { FabricManager } from "#fabric/FabricManager.js";
|
|
10
|
+
import {
|
|
11
|
+
AsyncObservable,
|
|
12
|
+
Diagnostic,
|
|
13
|
+
Environment,
|
|
14
|
+
Environmental,
|
|
15
|
+
Logger,
|
|
16
|
+
Mutex,
|
|
17
|
+
ObserverGroup,
|
|
18
|
+
Time,
|
|
19
|
+
Timer,
|
|
20
|
+
} from "#general";
|
|
21
|
+
import { SessionManager } from "#session/SessionManager.js";
|
|
22
|
+
import { DEVICE_ANNOUNCEMENT_DURATION_MS, DEVICE_ANNOUNCEMENT_INTERVAL_MS } from "#types";
|
|
23
|
+
|
|
24
|
+
const logger = Logger.get("DeviceAdvertiser");
|
|
25
|
+
|
|
26
|
+
/**
|
|
27
|
+
* Interfaces the {@link DeviceAdvertiser} with other components.
|
|
28
|
+
*/
|
|
29
|
+
export interface DeviceAdvertiserContext {
|
|
30
|
+
fabrics: FabricManager;
|
|
31
|
+
sessions: SessionManager;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
/**
|
|
35
|
+
* Advertises a node for commissioning (if uncommissioned) or operationally (if commissioned).
|
|
36
|
+
*/
|
|
37
|
+
export class DeviceAdvertiser {
|
|
38
|
+
readonly #context: DeviceAdvertiserContext;
|
|
39
|
+
readonly #broadcasters = new Set<InstanceBroadcaster>();
|
|
40
|
+
readonly #timedOut = AsyncObservable<[]>();
|
|
41
|
+
readonly #operationalModeEnded = new AsyncObservable<[]>();
|
|
42
|
+
readonly #observers = new ObserverGroup();
|
|
43
|
+
#interval: Timer;
|
|
44
|
+
#startTime: number | null = null;
|
|
45
|
+
#isClosing = false;
|
|
46
|
+
#commissioningMode = CommissioningMode.NotCommissioning;
|
|
47
|
+
|
|
48
|
+
// Currently we do not put much effort into synchronizing announcements as it probably isn't really necessary. But
|
|
49
|
+
// this mutex prevents automated announcements from piling up and allows us to ensure announcements are complete on
|
|
50
|
+
// close
|
|
51
|
+
#mutex = new Mutex(this);
|
|
52
|
+
|
|
53
|
+
constructor(context: DeviceAdvertiserContext) {
|
|
54
|
+
this.#context = context;
|
|
55
|
+
|
|
56
|
+
this.#interval = Time.getPeriodicTimer("Server node announcement", DEVICE_ANNOUNCEMENT_INTERVAL_MS, () =>
|
|
57
|
+
// Announcement needs to await a previous announcement because otherwise in testing at least announcement
|
|
58
|
+
// may crash if started simultaneously
|
|
59
|
+
this.#mutex.run(() => this.advertise()),
|
|
60
|
+
);
|
|
61
|
+
|
|
62
|
+
this.#observers.on(this.#context.fabrics.events.deleted, async () => {
|
|
63
|
+
if (this.#context.fabrics.getFabrics().length === 0) {
|
|
64
|
+
// Last fabric got removed, so expire all announcements
|
|
65
|
+
await this.#exitOperationalMode();
|
|
66
|
+
}
|
|
67
|
+
});
|
|
68
|
+
|
|
69
|
+
this.#observers.on(this.#context.sessions.resubmissionStarted, (nodeId?) => {
|
|
70
|
+
logger.debug(`Resubmission started, re-announce node ${nodeId}`);
|
|
71
|
+
this.advertise(true).catch(error => logger.warn("Error sending announcement:", error));
|
|
72
|
+
});
|
|
73
|
+
|
|
74
|
+
this.#observers.on(this.#context.sessions.subscriptionsChanged, (_session, subscription) => {
|
|
75
|
+
if (subscription.isCanceledByPeer) {
|
|
76
|
+
logger.debug(`Subscription canceled by peer, re-announce`);
|
|
77
|
+
this.startAdvertising().catch(error => logger.warn("Error sending announcement:", error));
|
|
78
|
+
}
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
[Environmental.create](env: Environment) {
|
|
83
|
+
const instance = new DeviceAdvertiser({
|
|
84
|
+
fabrics: env.get(FabricManager),
|
|
85
|
+
sessions: env.get(SessionManager),
|
|
86
|
+
});
|
|
87
|
+
env.set(DeviceAdvertiser, instance);
|
|
88
|
+
return instance;
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
/**
|
|
92
|
+
* Emitted when the advertising window closes with no response.
|
|
93
|
+
*/
|
|
94
|
+
get timedOut() {
|
|
95
|
+
return this.#timedOut;
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
/**
|
|
99
|
+
* Emitted when the device stops advertising due to decommissioning.
|
|
100
|
+
*/
|
|
101
|
+
get operationalModeEnded() {
|
|
102
|
+
return this.#operationalModeEnded;
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
async enterCommissioningMode(mode: CommissioningMode, deviceData: CommissioningModeInstanceData) {
|
|
106
|
+
this.#commissioningMode = mode;
|
|
107
|
+
for (const broadcaster of this.#broadcasters) {
|
|
108
|
+
await broadcaster.setCommissionMode(mode, deviceData);
|
|
109
|
+
}
|
|
110
|
+
await this.startAdvertising();
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
async exitCommissioningMode() {
|
|
114
|
+
this.#commissioningMode = CommissioningMode.NotCommissioning;
|
|
115
|
+
this.#interval.stop();
|
|
116
|
+
this.#startTime = null;
|
|
117
|
+
for (const broadcaster of this.#broadcasters) {
|
|
118
|
+
await broadcaster.expireCommissioningAnnouncement();
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
async startAdvertising() {
|
|
123
|
+
if (this.#isClosing) return;
|
|
124
|
+
if (this.#interval.isRunning) {
|
|
125
|
+
this.#interval.stop();
|
|
126
|
+
}
|
|
127
|
+
this.#startTime = Time.nowMs();
|
|
128
|
+
this.#interval.start();
|
|
129
|
+
await this.advertise();
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
async advertise(once = false) {
|
|
133
|
+
if (!once) {
|
|
134
|
+
// Stop announcement if duration is reached
|
|
135
|
+
if (this.#startTime !== null && Time.nowMs() - this.#startTime > DEVICE_ANNOUNCEMENT_DURATION_MS) {
|
|
136
|
+
logger.debug("Announcement duration reached, stop announcing");
|
|
137
|
+
await this.#timedOut.emit();
|
|
138
|
+
return;
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
if (this.#commissioningMode !== CommissioningMode.NotCommissioning) {
|
|
142
|
+
// Re-Announce but do not reset Fabrics
|
|
143
|
+
for (const broadcaster of this.#broadcasters) {
|
|
144
|
+
await broadcaster.announce();
|
|
145
|
+
}
|
|
146
|
+
return;
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
const fabrics = this.#context.fabrics.getFabrics();
|
|
151
|
+
|
|
152
|
+
if (fabrics.length) {
|
|
153
|
+
let fabricsWithoutSessions = 0;
|
|
154
|
+
for (const fabric of fabrics) {
|
|
155
|
+
const session = this.#context.sessions.getSessionForNode(fabric.addressOf(fabric.rootNodeId));
|
|
156
|
+
if (session === undefined || !session.isSecure || session.subscriptions.size === 0) {
|
|
157
|
+
fabricsWithoutSessions++;
|
|
158
|
+
logger.debug("Announcing", Diagnostic.dict({ fabric: fabric.fabricId }));
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
for (const broadcaster of this.#broadcasters) {
|
|
162
|
+
await broadcaster.setFabrics(fabrics);
|
|
163
|
+
if (fabricsWithoutSessions > 0 || this.#commissioningMode !== CommissioningMode.NotCommissioning) {
|
|
164
|
+
await broadcaster.announce();
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
} else {
|
|
168
|
+
// Expire operational Fabric announcements (if fabric got just deleted)
|
|
169
|
+
await this.#exitOperationalMode();
|
|
170
|
+
await this.#operationalModeEnded.emit();
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
async advertiseFabrics(fabrics: Fabric[], expireCommissioningAnnouncement = false) {
|
|
175
|
+
for (const broadcaster of this.#broadcasters) {
|
|
176
|
+
await broadcaster.setFabrics(fabrics, expireCommissioningAnnouncement);
|
|
177
|
+
await broadcaster.announce();
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
async #exitOperationalMode() {
|
|
182
|
+
for (const broadcaster of this.#broadcasters) {
|
|
183
|
+
await broadcaster.expireFabricAnnouncement();
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
|
|
187
|
+
async close() {
|
|
188
|
+
await this.#mutex;
|
|
189
|
+
this.#observers.close();
|
|
190
|
+
for (const broadcaster of this.#broadcasters) {
|
|
191
|
+
await broadcaster.close();
|
|
192
|
+
}
|
|
193
|
+
}
|
|
194
|
+
|
|
195
|
+
hasBroadcaster(broadcaster: InstanceBroadcaster) {
|
|
196
|
+
return this.#broadcasters.has(broadcaster);
|
|
197
|
+
}
|
|
198
|
+
|
|
199
|
+
addBroadcaster(broadcaster: InstanceBroadcaster) {
|
|
200
|
+
this.#broadcasters.add(broadcaster);
|
|
201
|
+
}
|
|
202
|
+
|
|
203
|
+
async deleteBroadcaster(broadcaster: InstanceBroadcaster) {
|
|
204
|
+
if (this.#broadcasters.delete(broadcaster)) {
|
|
205
|
+
await broadcaster.expireAllAnnouncements();
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
}
|
|
@@ -0,0 +1,280 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2022-2024 Matter.js Authors
|
|
4
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
import { AdministratorCommissioning } from "#clusters/administrator-commissioning";
|
|
8
|
+
import { FailsafeContext } from "#common/FailsafeContext.js";
|
|
9
|
+
import { CommissioningMode } from "#common/InstanceBroadcaster.js";
|
|
10
|
+
import { FabricManager } from "#fabric/FabricManager.js";
|
|
11
|
+
import {
|
|
12
|
+
Crypto,
|
|
13
|
+
Diagnostic,
|
|
14
|
+
Environment,
|
|
15
|
+
Environmental,
|
|
16
|
+
InternalError,
|
|
17
|
+
Lifecycle,
|
|
18
|
+
Logger,
|
|
19
|
+
MatterFlowError,
|
|
20
|
+
ObserverGroup,
|
|
21
|
+
} from "#general";
|
|
22
|
+
import { SecureChannelProtocol } from "#securechannel/SecureChannelProtocol.js";
|
|
23
|
+
import { PaseServer, SessionManager } from "#session/index.js";
|
|
24
|
+
import { CommissioningOptions, StatusCode, StatusResponseError } from "#types";
|
|
25
|
+
import type { ControllerCommissioner } from "../peer/ControllerCommissioner.js";
|
|
26
|
+
import { DeviceAdvertiser } from "./DeviceAdvertiser.js";
|
|
27
|
+
|
|
28
|
+
const logger = Logger.get("DeviceCommissioner");
|
|
29
|
+
|
|
30
|
+
/**
|
|
31
|
+
* The component allows commissioning configuration to change after the {@link DeviceCommissioner} is initialized.
|
|
32
|
+
*/
|
|
33
|
+
export abstract class CommissioningConfigProvider {
|
|
34
|
+
abstract values: CommissioningOptions.Configuration;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
/**
|
|
38
|
+
* Interfaces the {@link DeviceCommissioner} with other components.
|
|
39
|
+
*/
|
|
40
|
+
export interface DeviceCommissionerContext {
|
|
41
|
+
fabrics: FabricManager;
|
|
42
|
+
sessions: SessionManager;
|
|
43
|
+
advertiser: DeviceAdvertiser;
|
|
44
|
+
secureChannelProtocol: SecureChannelProtocol;
|
|
45
|
+
commissioningConfig: CommissioningConfigProvider;
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
/**
|
|
49
|
+
* Implements commissioning for devices.
|
|
50
|
+
*
|
|
51
|
+
* Note this implements commissioning for a *local* device; use {@link ControllerCommissioner} to commission a *remote*
|
|
52
|
+
* device.
|
|
53
|
+
*/
|
|
54
|
+
export class DeviceCommissioner {
|
|
55
|
+
#context: DeviceCommissionerContext;
|
|
56
|
+
#failsafeContext?: FailsafeContext;
|
|
57
|
+
#windowStatus = AdministratorCommissioning.CommissioningWindowStatus.WindowNotOpen;
|
|
58
|
+
#activeDiscriminator?: number;
|
|
59
|
+
#activeCommissioningEndCallback?: () => void;
|
|
60
|
+
#observers = new ObserverGroup(this);
|
|
61
|
+
|
|
62
|
+
constructor(context: DeviceCommissionerContext) {
|
|
63
|
+
this.#context = context;
|
|
64
|
+
|
|
65
|
+
this.#observers.on(this.#context.advertiser.timedOut, this.endCommissioning);
|
|
66
|
+
|
|
67
|
+
// If a commissioning window is open then we reannounce this because it was ended as fabric got added
|
|
68
|
+
this.#observers.on(this.#context.fabrics.events.deleted, this.reactivateAdvertiser);
|
|
69
|
+
|
|
70
|
+
// No fabric paired yet, so announce as "ready for commissioning"
|
|
71
|
+
this.#observers.on(this.#context.advertiser.operationalModeEnded, this.allowBasicCommissioning);
|
|
72
|
+
|
|
73
|
+
// Cancel commissioning when there are too many PASE errors
|
|
74
|
+
this.#observers.on(this.#context.secureChannelProtocol.tooManyPaseErrors, async () => {
|
|
75
|
+
logger.info("Maximum number of PASE pairing errors reached, canceling commissioning");
|
|
76
|
+
await this.endCommissioning();
|
|
77
|
+
});
|
|
78
|
+
|
|
79
|
+
this.#observers.on(this.#context.sessions.sessions.deleted, session => {
|
|
80
|
+
const currentFabricIndex = session.fabric?.fabricIndex;
|
|
81
|
+
|
|
82
|
+
// Verify if the session associated fabric still exists
|
|
83
|
+
const existingSessionFabric =
|
|
84
|
+
currentFabricIndex === undefined
|
|
85
|
+
? undefined
|
|
86
|
+
: this.#context.fabrics.findByIndex(currentFabricIndex)?.fabricIndex;
|
|
87
|
+
|
|
88
|
+
// When a session closes, announce existing fabrics again so that controller can detect the device again.
|
|
89
|
+
// When session was closed and no fabric exist anymore then this is triggering a factory reset in upper
|
|
90
|
+
// layer and it would be not good to announce a commissionable device and then reset that again with the
|
|
91
|
+
// factory reset
|
|
92
|
+
if (this.#context.fabrics.getFabrics().length > 0 || session.isPase || !existingSessionFabric) {
|
|
93
|
+
this.#context.advertiser
|
|
94
|
+
.startAdvertising()
|
|
95
|
+
.catch(error => logger.warn(`Error while announcing`, error));
|
|
96
|
+
}
|
|
97
|
+
});
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
[Environmental.create](env: Environment) {
|
|
101
|
+
const instance = new DeviceCommissioner({
|
|
102
|
+
fabrics: env.get(FabricManager),
|
|
103
|
+
sessions: env.get(SessionManager),
|
|
104
|
+
advertiser: env.get(DeviceAdvertiser),
|
|
105
|
+
secureChannelProtocol: env.get(SecureChannelProtocol),
|
|
106
|
+
commissioningConfig: env.get(CommissioningConfigProvider),
|
|
107
|
+
});
|
|
108
|
+
env.set(DeviceCommissioner, instance);
|
|
109
|
+
return instance;
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
get failsafeContext() {
|
|
113
|
+
this.assertFailsafeArmed();
|
|
114
|
+
return this.#failsafeContext!;
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
async allowEnhancedCommissioning(
|
|
118
|
+
discriminator: number,
|
|
119
|
+
paseServer: PaseServer,
|
|
120
|
+
commissioningEndCallback: () => void,
|
|
121
|
+
) {
|
|
122
|
+
if (this.#windowStatus === AdministratorCommissioning.CommissioningWindowStatus.BasicWindowOpen) {
|
|
123
|
+
throw new MatterFlowError(
|
|
124
|
+
"Basic commissioning window is already open! Cannot set Enhanced commissioning mode.",
|
|
125
|
+
);
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
this.#context.secureChannelProtocol.setPaseCommissioner(paseServer);
|
|
129
|
+
await this.#becomeCommissionable(
|
|
130
|
+
AdministratorCommissioning.CommissioningWindowStatus.EnhancedWindowOpen,
|
|
131
|
+
commissioningEndCallback,
|
|
132
|
+
discriminator,
|
|
133
|
+
);
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
async allowBasicCommissioning(commissioningEndCallback?: () => void) {
|
|
137
|
+
if (this.#windowStatus === AdministratorCommissioning.CommissioningWindowStatus.EnhancedWindowOpen) {
|
|
138
|
+
throw new MatterFlowError(
|
|
139
|
+
"Enhanced commissioning window is already open! Cannot set Basic commissioning mode.",
|
|
140
|
+
);
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
this.#context.secureChannelProtocol.setPaseCommissioner(
|
|
144
|
+
await PaseServer.fromPin(this.#context.sessions, this.#context.commissioningConfig.values.passcode, {
|
|
145
|
+
iterations: 1000,
|
|
146
|
+
salt: Crypto.get().getRandomData(32),
|
|
147
|
+
}),
|
|
148
|
+
);
|
|
149
|
+
|
|
150
|
+
await this.#becomeCommissionable(
|
|
151
|
+
AdministratorCommissioning.CommissioningWindowStatus.BasicWindowOpen,
|
|
152
|
+
commissioningEndCallback,
|
|
153
|
+
);
|
|
154
|
+
}
|
|
155
|
+
|
|
156
|
+
async beginTimed(failsafeContext: FailsafeContext) {
|
|
157
|
+
await failsafeContext.construction;
|
|
158
|
+
|
|
159
|
+
this.#failsafeContext = failsafeContext;
|
|
160
|
+
|
|
161
|
+
this.#context.fabrics.events.added.on(fabric => {
|
|
162
|
+
const fabrics = this.#context.fabrics.getFabrics();
|
|
163
|
+
this.#context.advertiser
|
|
164
|
+
.advertiseFabrics(fabrics, true)
|
|
165
|
+
.catch(error =>
|
|
166
|
+
logger.warn(`Error sending Fabric announcement for Index ${fabric.fabricIndex}`, error),
|
|
167
|
+
);
|
|
168
|
+
logger.info("Announce done", Diagnostic.dict({ fabric: fabric.fabricId, fabricIndex: fabric.fabricIndex }));
|
|
169
|
+
});
|
|
170
|
+
|
|
171
|
+
failsafeContext.commissioned.on(async () => await this.endCommissioning());
|
|
172
|
+
|
|
173
|
+
failsafeContext.construction.change.on(status => {
|
|
174
|
+
if (status === Lifecycle.Status.Destroyed) {
|
|
175
|
+
this.#failsafeContext = undefined;
|
|
176
|
+
}
|
|
177
|
+
});
|
|
178
|
+
}
|
|
179
|
+
|
|
180
|
+
get isFailsafeArmed() {
|
|
181
|
+
return this.#failsafeContext !== undefined;
|
|
182
|
+
}
|
|
183
|
+
|
|
184
|
+
assertFailsafeArmed(message?: string) {
|
|
185
|
+
if (this.isFailsafeArmed) return;
|
|
186
|
+
throw new StatusResponseError(
|
|
187
|
+
message ?? "Failsafe timer needs to be armed to execute this action.",
|
|
188
|
+
StatusCode.FailsafeRequired,
|
|
189
|
+
);
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
reactivateAdvertiser() {
|
|
193
|
+
if (this.#windowStatus === AdministratorCommissioning.CommissioningWindowStatus.WindowNotOpen) {
|
|
194
|
+
return;
|
|
195
|
+
}
|
|
196
|
+
this.#enterCommissioningMode(this.#windowStatus, this.#activeDiscriminator).catch(error =>
|
|
197
|
+
logger.warn("Error sending announcement:", error),
|
|
198
|
+
);
|
|
199
|
+
}
|
|
200
|
+
|
|
201
|
+
async #enterCommissioningMode(
|
|
202
|
+
windowStatus: AdministratorCommissioning.CommissioningWindowStatus,
|
|
203
|
+
discriminator?: number,
|
|
204
|
+
) {
|
|
205
|
+
this.#windowStatus = windowStatus;
|
|
206
|
+
const commissioningConfig = this.#context.commissioningConfig.values;
|
|
207
|
+
await this.#context.advertiser.enterCommissioningMode(
|
|
208
|
+
windowStatus === AdministratorCommissioning.CommissioningWindowStatus.EnhancedWindowOpen
|
|
209
|
+
? CommissioningMode.Enhanced
|
|
210
|
+
: CommissioningMode.Basic,
|
|
211
|
+
{
|
|
212
|
+
...commissioningConfig.productDescription,
|
|
213
|
+
discriminator: discriminator ?? commissioningConfig.discriminator,
|
|
214
|
+
},
|
|
215
|
+
);
|
|
216
|
+
}
|
|
217
|
+
|
|
218
|
+
async #becomeCommissionable(
|
|
219
|
+
windowStatus: AdministratorCommissioning.CommissioningWindowStatus,
|
|
220
|
+
activeCommissioningEndCallback?: () => void,
|
|
221
|
+
discriminator?: number,
|
|
222
|
+
) {
|
|
223
|
+
if (
|
|
224
|
+
this.#windowStatus === windowStatus &&
|
|
225
|
+
(discriminator === undefined || discriminator === this.#activeDiscriminator)
|
|
226
|
+
) {
|
|
227
|
+
// We want to re-announce
|
|
228
|
+
return this.reactivateAdvertiser();
|
|
229
|
+
}
|
|
230
|
+
if (this.#windowStatus !== AdministratorCommissioning.CommissioningWindowStatus.WindowNotOpen) {
|
|
231
|
+
throw new InternalError(`Commissioning window already open with different mode (${this.#windowStatus})!`);
|
|
232
|
+
}
|
|
233
|
+
if (this.#activeCommissioningEndCallback !== undefined) {
|
|
234
|
+
throw new InternalError("Commissioning window already open with different callback!");
|
|
235
|
+
}
|
|
236
|
+
this.#activeCommissioningEndCallback = activeCommissioningEndCallback;
|
|
237
|
+
this.#activeDiscriminator = discriminator;
|
|
238
|
+
|
|
239
|
+
// MDNS is sent in parallel
|
|
240
|
+
// TODO - untracked promise
|
|
241
|
+
this.#enterCommissioningMode(windowStatus, discriminator).catch(error =>
|
|
242
|
+
logger.warn("Error sending announcement:", error),
|
|
243
|
+
);
|
|
244
|
+
}
|
|
245
|
+
|
|
246
|
+
async endCommissioning() {
|
|
247
|
+
if (this.#windowStatus === AdministratorCommissioning.CommissioningWindowStatus.WindowNotOpen) {
|
|
248
|
+
return;
|
|
249
|
+
}
|
|
250
|
+
|
|
251
|
+
logger.debug("Commissioning mode ended, stop announcements.");
|
|
252
|
+
// Remove PASE responder when we close enhanced commissioning window or node is commissioned
|
|
253
|
+
if (
|
|
254
|
+
this.#windowStatus === AdministratorCommissioning.CommissioningWindowStatus.EnhancedWindowOpen ||
|
|
255
|
+
this.#context.fabrics.getFabrics().length > 0
|
|
256
|
+
) {
|
|
257
|
+
this.#context.secureChannelProtocol.removePaseCommissioner();
|
|
258
|
+
}
|
|
259
|
+
this.#windowStatus = AdministratorCommissioning.CommissioningWindowStatus.WindowNotOpen;
|
|
260
|
+
|
|
261
|
+
if (this.#activeCommissioningEndCallback !== undefined) {
|
|
262
|
+
const activeCommissioningEndCallback = this.#activeCommissioningEndCallback;
|
|
263
|
+
this.#activeCommissioningEndCallback = undefined;
|
|
264
|
+
activeCommissioningEndCallback();
|
|
265
|
+
}
|
|
266
|
+
|
|
267
|
+
await this.#context.advertiser.exitCommissioningMode();
|
|
268
|
+
|
|
269
|
+
logger.info("All announcements stopped");
|
|
270
|
+
}
|
|
271
|
+
|
|
272
|
+
async close() {
|
|
273
|
+
this.#observers.close();
|
|
274
|
+
await this.endCommissioning();
|
|
275
|
+
if (this.#failsafeContext) {
|
|
276
|
+
await this.#failsafeContext.close();
|
|
277
|
+
this.#failsafeContext = undefined;
|
|
278
|
+
}
|
|
279
|
+
}
|
|
280
|
+
}
|