@matter/protocol 0.16.0-alpha.0-20250913-0bc2515df → 0.16.0-alpha.0-20250920-809524dba
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/dist/cjs/bdx/BdxClient.d.ts +31 -0
- package/dist/cjs/bdx/BdxClient.d.ts.map +1 -0
- package/dist/cjs/bdx/BdxClient.js +57 -0
- package/dist/cjs/bdx/BdxClient.js.map +6 -0
- package/dist/cjs/bdx/BdxError.d.ts +21 -0
- package/dist/cjs/bdx/BdxError.d.ts.map +1 -0
- package/dist/cjs/bdx/BdxError.js +54 -0
- package/dist/cjs/bdx/BdxError.js.map +6 -0
- package/dist/cjs/bdx/BdxMessenger.d.ts +77 -0
- package/dist/cjs/bdx/BdxMessenger.d.ts.map +1 -0
- package/dist/cjs/bdx/BdxMessenger.js +245 -0
- package/dist/cjs/bdx/BdxMessenger.js.map +6 -0
- package/dist/cjs/bdx/BdxProtocol.d.ts +25 -0
- package/dist/cjs/bdx/BdxProtocol.d.ts.map +1 -0
- package/dist/cjs/bdx/BdxProtocol.js +102 -0
- package/dist/cjs/bdx/BdxProtocol.js.map +6 -0
- package/dist/cjs/bdx/BdxSession.d.ts +36 -0
- package/dist/cjs/bdx/BdxSession.d.ts.map +1 -0
- package/dist/cjs/bdx/BdxSession.js +153 -0
- package/dist/cjs/bdx/BdxSession.js.map +6 -0
- package/dist/cjs/bdx/BdxSessionConfiguration.d.ts +61 -0
- package/dist/cjs/bdx/BdxSessionConfiguration.d.ts.map +1 -0
- package/dist/cjs/bdx/BdxSessionConfiguration.js +95 -0
- package/dist/cjs/bdx/BdxSessionConfiguration.js.map +6 -0
- package/dist/cjs/bdx/FileDesignator.d.ts +21 -0
- package/dist/cjs/bdx/FileDesignator.d.ts.map +1 -0
- package/dist/cjs/bdx/FileDesignator.js +62 -0
- package/dist/cjs/bdx/FileDesignator.js.map +6 -0
- package/dist/cjs/bdx/PersistedFileDesignator.d.ts +16 -0
- package/dist/cjs/bdx/PersistedFileDesignator.d.ts.map +1 -0
- package/dist/cjs/bdx/PersistedFileDesignator.js +57 -0
- package/dist/cjs/bdx/PersistedFileDesignator.js.map +6 -0
- package/dist/cjs/bdx/bdx-session-initiator.d.ts +14 -0
- package/dist/cjs/bdx/bdx-session-initiator.d.ts.map +1 -0
- package/dist/cjs/bdx/bdx-session-initiator.js +218 -0
- package/dist/cjs/bdx/bdx-session-initiator.js.map +6 -0
- package/dist/cjs/bdx/flow/DrivenSendingFlow.d.ts +15 -0
- package/dist/cjs/bdx/flow/DrivenSendingFlow.d.ts.map +1 -0
- package/dist/cjs/bdx/flow/DrivenSendingFlow.js +49 -0
- package/dist/cjs/bdx/flow/DrivenSendingFlow.js.map +6 -0
- package/dist/cjs/bdx/flow/DrivingReceivingFlow.d.ts +15 -0
- package/dist/cjs/bdx/flow/DrivingReceivingFlow.d.ts.map +1 -0
- package/dist/cjs/bdx/flow/DrivingReceivingFlow.js +47 -0
- package/dist/cjs/bdx/flow/DrivingReceivingFlow.js.map +6 -0
- package/dist/cjs/bdx/flow/Flow.d.ts +48 -0
- package/dist/cjs/bdx/flow/Flow.d.ts.map +1 -0
- package/dist/cjs/bdx/flow/Flow.js +112 -0
- package/dist/cjs/bdx/flow/Flow.js.map +6 -0
- package/dist/cjs/bdx/flow/FollowingReceivingFlow.d.ts +16 -0
- package/dist/cjs/bdx/flow/FollowingReceivingFlow.d.ts.map +1 -0
- package/dist/cjs/bdx/flow/FollowingReceivingFlow.js +60 -0
- package/dist/cjs/bdx/flow/FollowingReceivingFlow.js.map +6 -0
- package/dist/cjs/bdx/flow/FollowingSendingFlow.d.ts +15 -0
- package/dist/cjs/bdx/flow/FollowingSendingFlow.d.ts.map +1 -0
- package/dist/cjs/bdx/flow/FollowingSendingFlow.js +49 -0
- package/dist/cjs/bdx/flow/FollowingSendingFlow.js.map +6 -0
- package/dist/cjs/bdx/flow/InboundFlow.d.ts +26 -0
- package/dist/cjs/bdx/flow/InboundFlow.d.ts.map +1 -0
- package/dist/cjs/bdx/flow/InboundFlow.js +101 -0
- package/dist/cjs/bdx/flow/InboundFlow.js.map +6 -0
- package/dist/cjs/bdx/flow/OutboundFlow.d.ts +31 -0
- package/dist/cjs/bdx/flow/OutboundFlow.d.ts.map +1 -0
- package/dist/cjs/bdx/flow/OutboundFlow.js +124 -0
- package/dist/cjs/bdx/flow/OutboundFlow.js.map +6 -0
- package/dist/cjs/bdx/index.d.ts +16 -0
- package/dist/cjs/bdx/index.d.ts.map +1 -0
- package/dist/cjs/bdx/index.js +33 -0
- package/dist/cjs/bdx/index.js.map +6 -0
- package/dist/cjs/bdx/schema/BdxAcceptMessagesSchema.d.ts +50 -0
- package/dist/cjs/bdx/schema/BdxAcceptMessagesSchema.d.ts.map +1 -0
- package/dist/cjs/bdx/schema/BdxAcceptMessagesSchema.js +125 -0
- package/dist/cjs/bdx/schema/BdxAcceptMessagesSchema.js.map +6 -0
- package/dist/cjs/bdx/schema/BdxBlockMessagesSchema.d.ts +53 -0
- package/dist/cjs/bdx/schema/BdxBlockMessagesSchema.d.ts.map +1 -0
- package/dist/cjs/bdx/schema/BdxBlockMessagesSchema.js +92 -0
- package/dist/cjs/bdx/schema/BdxBlockMessagesSchema.js.map +6 -0
- package/dist/cjs/bdx/schema/BdxInitMessagesSchema.d.ts +117 -0
- package/dist/cjs/bdx/schema/BdxInitMessagesSchema.d.ts.map +1 -0
- package/dist/cjs/bdx/schema/BdxInitMessagesSchema.js +153 -0
- package/dist/cjs/bdx/schema/BdxInitMessagesSchema.js.map +6 -0
- package/dist/cjs/bdx/schema/BdxMessage.d.ts +23 -0
- package/dist/cjs/bdx/schema/BdxMessage.d.ts.map +1 -0
- package/dist/cjs/bdx/schema/BdxMessage.js +75 -0
- package/dist/cjs/bdx/schema/BdxMessage.js.map +6 -0
- package/dist/cjs/bdx/schema/BdxStatusMessageSchema.d.ts +12 -0
- package/dist/cjs/bdx/schema/BdxStatusMessageSchema.d.ts.map +1 -0
- package/dist/cjs/bdx/schema/BdxStatusMessageSchema.js +35 -0
- package/dist/cjs/bdx/schema/BdxStatusMessageSchema.js.map +6 -0
- package/dist/cjs/bdx/schema/index.d.ts +11 -0
- package/dist/cjs/bdx/schema/index.d.ts.map +1 -0
- package/dist/cjs/bdx/schema/index.js +28 -0
- package/dist/cjs/bdx/schema/index.js.map +6 -0
- package/dist/cjs/index.d.ts +1 -0
- package/dist/cjs/index.d.ts.map +1 -1
- package/dist/cjs/index.js +1 -0
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/mdns/MdnsClient.js +2 -2
- package/dist/cjs/mdns/MdnsClient.js.map +1 -1
- package/dist/cjs/protocol/ExchangeManager.d.ts.map +1 -1
- package/dist/cjs/protocol/ExchangeManager.js +4 -2
- package/dist/cjs/protocol/ExchangeManager.js.map +1 -1
- package/dist/cjs/protocol/MessageExchange.d.ts +2 -0
- package/dist/cjs/protocol/MessageExchange.d.ts.map +1 -1
- package/dist/cjs/protocol/MessageExchange.js +14 -8
- package/dist/cjs/protocol/MessageExchange.js.map +2 -2
- package/dist/cjs/protocol/ProtocolStatusMessage.d.ts +1 -1
- package/dist/cjs/protocol/ProtocolStatusMessage.d.ts.map +1 -1
- package/dist/cjs/protocol/ProtocolStatusMessage.js.map +1 -1
- package/dist/esm/bdx/BdxClient.d.ts +31 -0
- package/dist/esm/bdx/BdxClient.d.ts.map +1 -0
- package/dist/esm/bdx/BdxClient.js +37 -0
- package/dist/esm/bdx/BdxClient.js.map +6 -0
- package/dist/esm/bdx/BdxError.d.ts +21 -0
- package/dist/esm/bdx/BdxError.d.ts.map +1 -0
- package/dist/esm/bdx/BdxError.js +34 -0
- package/dist/esm/bdx/BdxError.js.map +6 -0
- package/dist/esm/bdx/BdxMessenger.d.ts +77 -0
- package/dist/esm/bdx/BdxMessenger.d.ts.map +1 -0
- package/dist/esm/bdx/BdxMessenger.js +233 -0
- package/dist/esm/bdx/BdxMessenger.js.map +6 -0
- package/dist/esm/bdx/BdxProtocol.d.ts +25 -0
- package/dist/esm/bdx/BdxProtocol.d.ts.map +1 -0
- package/dist/esm/bdx/BdxProtocol.js +82 -0
- package/dist/esm/bdx/BdxProtocol.js.map +6 -0
- package/dist/esm/bdx/BdxSession.d.ts +36 -0
- package/dist/esm/bdx/BdxSession.d.ts.map +1 -0
- package/dist/esm/bdx/BdxSession.js +133 -0
- package/dist/esm/bdx/BdxSession.js.map +6 -0
- package/dist/esm/bdx/BdxSessionConfiguration.d.ts +61 -0
- package/dist/esm/bdx/BdxSessionConfiguration.d.ts.map +1 -0
- package/dist/esm/bdx/BdxSessionConfiguration.js +75 -0
- package/dist/esm/bdx/BdxSessionConfiguration.js.map +6 -0
- package/dist/esm/bdx/FileDesignator.d.ts +21 -0
- package/dist/esm/bdx/FileDesignator.d.ts.map +1 -0
- package/dist/esm/bdx/FileDesignator.js +42 -0
- package/dist/esm/bdx/FileDesignator.js.map +6 -0
- package/dist/esm/bdx/PersistedFileDesignator.d.ts +16 -0
- package/dist/esm/bdx/PersistedFileDesignator.d.ts.map +1 -0
- package/dist/esm/bdx/PersistedFileDesignator.js +37 -0
- package/dist/esm/bdx/PersistedFileDesignator.js.map +6 -0
- package/dist/esm/bdx/bdx-session-initiator.d.ts +14 -0
- package/dist/esm/bdx/bdx-session-initiator.d.ts.map +1 -0
- package/dist/esm/bdx/bdx-session-initiator.js +198 -0
- package/dist/esm/bdx/bdx-session-initiator.js.map +6 -0
- package/dist/esm/bdx/flow/DrivenSendingFlow.d.ts +15 -0
- package/dist/esm/bdx/flow/DrivenSendingFlow.d.ts.map +1 -0
- package/dist/esm/bdx/flow/DrivenSendingFlow.js +29 -0
- package/dist/esm/bdx/flow/DrivenSendingFlow.js.map +6 -0
- package/dist/esm/bdx/flow/DrivingReceivingFlow.d.ts +15 -0
- package/dist/esm/bdx/flow/DrivingReceivingFlow.d.ts.map +1 -0
- package/dist/esm/bdx/flow/DrivingReceivingFlow.js +27 -0
- package/dist/esm/bdx/flow/DrivingReceivingFlow.js.map +6 -0
- package/dist/esm/bdx/flow/Flow.d.ts +48 -0
- package/dist/esm/bdx/flow/Flow.d.ts.map +1 -0
- package/dist/esm/bdx/flow/Flow.js +92 -0
- package/dist/esm/bdx/flow/Flow.js.map +6 -0
- package/dist/esm/bdx/flow/FollowingReceivingFlow.d.ts +16 -0
- package/dist/esm/bdx/flow/FollowingReceivingFlow.d.ts.map +1 -0
- package/dist/esm/bdx/flow/FollowingReceivingFlow.js +40 -0
- package/dist/esm/bdx/flow/FollowingReceivingFlow.js.map +6 -0
- package/dist/esm/bdx/flow/FollowingSendingFlow.d.ts +15 -0
- package/dist/esm/bdx/flow/FollowingSendingFlow.d.ts.map +1 -0
- package/dist/esm/bdx/flow/FollowingSendingFlow.js +29 -0
- package/dist/esm/bdx/flow/FollowingSendingFlow.js.map +6 -0
- package/dist/esm/bdx/flow/InboundFlow.d.ts +26 -0
- package/dist/esm/bdx/flow/InboundFlow.d.ts.map +1 -0
- package/dist/esm/bdx/flow/InboundFlow.js +81 -0
- package/dist/esm/bdx/flow/InboundFlow.js.map +6 -0
- package/dist/esm/bdx/flow/OutboundFlow.d.ts +31 -0
- package/dist/esm/bdx/flow/OutboundFlow.d.ts.map +1 -0
- package/dist/esm/bdx/flow/OutboundFlow.js +104 -0
- package/dist/esm/bdx/flow/OutboundFlow.js.map +6 -0
- package/dist/esm/bdx/index.d.ts +16 -0
- package/dist/esm/bdx/index.d.ts.map +1 -0
- package/dist/esm/bdx/index.js +16 -0
- package/dist/esm/bdx/index.js.map +6 -0
- package/dist/esm/bdx/schema/BdxAcceptMessagesSchema.d.ts +50 -0
- package/dist/esm/bdx/schema/BdxAcceptMessagesSchema.d.ts.map +1 -0
- package/dist/esm/bdx/schema/BdxAcceptMessagesSchema.js +109 -0
- package/dist/esm/bdx/schema/BdxAcceptMessagesSchema.js.map +6 -0
- package/dist/esm/bdx/schema/BdxBlockMessagesSchema.d.ts +53 -0
- package/dist/esm/bdx/schema/BdxBlockMessagesSchema.d.ts.map +1 -0
- package/dist/esm/bdx/schema/BdxBlockMessagesSchema.js +72 -0
- package/dist/esm/bdx/schema/BdxBlockMessagesSchema.js.map +6 -0
- package/dist/esm/bdx/schema/BdxInitMessagesSchema.d.ts +117 -0
- package/dist/esm/bdx/schema/BdxInitMessagesSchema.d.ts.map +1 -0
- package/dist/esm/bdx/schema/BdxInitMessagesSchema.js +133 -0
- package/dist/esm/bdx/schema/BdxInitMessagesSchema.js.map +6 -0
- package/dist/esm/bdx/schema/BdxMessage.d.ts +23 -0
- package/dist/esm/bdx/schema/BdxMessage.d.ts.map +1 -0
- package/dist/esm/bdx/schema/BdxMessage.js +62 -0
- package/dist/esm/bdx/schema/BdxMessage.js.map +6 -0
- package/dist/esm/bdx/schema/BdxStatusMessageSchema.d.ts +12 -0
- package/dist/esm/bdx/schema/BdxStatusMessageSchema.d.ts.map +1 -0
- package/dist/esm/bdx/schema/BdxStatusMessageSchema.js +15 -0
- package/dist/esm/bdx/schema/BdxStatusMessageSchema.js.map +6 -0
- package/dist/esm/bdx/schema/index.d.ts +11 -0
- package/dist/esm/bdx/schema/index.d.ts.map +1 -0
- package/dist/esm/bdx/schema/index.js +11 -0
- package/dist/esm/bdx/schema/index.js.map +6 -0
- package/dist/esm/index.d.ts +1 -0
- package/dist/esm/index.d.ts.map +1 -1
- package/dist/esm/index.js +1 -0
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/mdns/MdnsClient.js +2 -2
- package/dist/esm/mdns/MdnsClient.js.map +1 -1
- package/dist/esm/protocol/ExchangeManager.d.ts.map +1 -1
- package/dist/esm/protocol/ExchangeManager.js +4 -2
- package/dist/esm/protocol/ExchangeManager.js.map +1 -1
- package/dist/esm/protocol/MessageExchange.d.ts +2 -0
- package/dist/esm/protocol/MessageExchange.d.ts.map +1 -1
- package/dist/esm/protocol/MessageExchange.js +14 -8
- package/dist/esm/protocol/MessageExchange.js.map +2 -2
- package/dist/esm/protocol/ProtocolStatusMessage.d.ts +1 -1
- package/dist/esm/protocol/ProtocolStatusMessage.d.ts.map +1 -1
- package/dist/esm/protocol/ProtocolStatusMessage.js.map +1 -1
- package/package.json +6 -6
- package/src/bdx/BdxClient.ts +47 -0
- package/src/bdx/BdxError.ts +39 -0
- package/src/bdx/BdxMessenger.ts +291 -0
- package/src/bdx/BdxProtocol.ts +93 -0
- package/src/bdx/BdxSession.ts +174 -0
- package/src/bdx/BdxSessionConfiguration.ts +134 -0
- package/src/bdx/FileDesignator.ts +49 -0
- package/src/bdx/PersistedFileDesignator.ts +40 -0
- package/src/bdx/bdx-session-initiator.ts +246 -0
- package/src/bdx/flow/DrivenSendingFlow.ts +40 -0
- package/src/bdx/flow/DrivingReceivingFlow.ts +39 -0
- package/src/bdx/flow/Flow.ts +124 -0
- package/src/bdx/flow/FollowingReceivingFlow.ts +53 -0
- package/src/bdx/flow/FollowingSendingFlow.ts +38 -0
- package/src/bdx/flow/InboundFlow.ts +104 -0
- package/src/bdx/flow/OutboundFlow.ts +124 -0
- package/src/bdx/index.ts +16 -0
- package/src/bdx/schema/BdxAcceptMessagesSchema.ts +159 -0
- package/src/bdx/schema/BdxBlockMessagesSchema.ts +99 -0
- package/src/bdx/schema/BdxInitMessagesSchema.ts +213 -0
- package/src/bdx/schema/BdxMessage.ts +70 -0
- package/src/bdx/schema/BdxStatusMessageSchema.ts +14 -0
- package/src/bdx/schema/index.ts +11 -0
- package/src/index.ts +1 -0
- package/src/mdns/MdnsClient.ts +2 -2
- package/src/protocol/ExchangeManager.ts +2 -0
- package/src/protocol/MessageExchange.ts +17 -6
- package/src/protocol/ProtocolStatusMessage.ts +1 -1
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/bdx/PersistedFileDesignator.ts"],
|
|
4
|
+
"mappings": ";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAMA,qBAA2D;AAC3D,4BAA+B;AAP/B;AAAA;AAAA;AAAA;AAAA;AAUO,MAAM,gCAAgC,qCAAe;AAAA,EACxD;AAAA,EACA;AAAA,EAEA,YAAY,IAAoB,SAAyB;AACrD,UAAM,EAAE;AACR,SAAK,WAAW;AAAA,EACpB;AAAA,EAEA,SAAS;AACL,WAAO,KAAK,SAAS,IAAI,KAAK,IAAI;AAAA,EACtC;AAAA,EAEA,MAAM,WAAW;AACb,QAAI,KAAK,UAAU,QAAW;AAC1B,YAAM,WAAW,KAAK;AACtB,UAAI,CAAC,KAAK,SAAS,IAAI,QAAQ,GAAG;AAC9B,cAAM,IAAI;AAAA,UACN;AAAA,QACJ;AAAA,MACJ;AACA,WAAK,QAAQ,MAAM,KAAK,SAAS,SAAS,QAAQ;AAAA,IACtD;AACA,WAAO,KAAK;AAAA,EAChB;AAAA,EAEA,gBAAgB,QAA+B;AAC3C,WAAO,KAAK,SAAS,oBAAoB,KAAK,MAAM,MAAM;AAAA,EAC9D;AACJ;",
|
|
5
|
+
"names": []
|
|
6
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2022-2025 Matter.js Authors
|
|
4
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
+
*/
|
|
6
|
+
import { BdxMessenger } from "./BdxMessenger.js";
|
|
7
|
+
import { BdxSessionConfiguration } from "./BdxSessionConfiguration.js";
|
|
8
|
+
import { Flow } from "./flow/Flow.js";
|
|
9
|
+
/**
|
|
10
|
+
* Handles the initiation of a BDX session by exchanging *Init and *Accept messages and negotiating the transfer
|
|
11
|
+
* parameters.
|
|
12
|
+
*/
|
|
13
|
+
export declare function bdxSessionInitiator(messenger: BdxMessenger, config: BdxSessionConfiguration): Promise<Flow.TransferOptions>;
|
|
14
|
+
//# sourceMappingURL=bdx-session-initiator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"bdx-session-initiator.d.ts","sourceRoot":"","sources":["../../../src/bdx/bdx-session-initiator.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAKH,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,uBAAuB,EAAE,MAAM,8BAA8B,CAAC;AACvE,OAAO,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AAMtC;;;GAGG;AACH,wBAAsB,mBAAmB,CAAC,SAAS,EAAE,YAAY,EAAE,MAAM,EAAE,uBAAuB,iCAgOjG"}
|
|
@@ -0,0 +1,218 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
var bdx_session_initiator_exports = {};
|
|
20
|
+
__export(bdx_session_initiator_exports, {
|
|
21
|
+
bdxSessionInitiator: () => bdxSessionInitiator
|
|
22
|
+
});
|
|
23
|
+
module.exports = __toCommonJS(bdx_session_initiator_exports);
|
|
24
|
+
var import_general = require("#general");
|
|
25
|
+
var import_types = require("#types");
|
|
26
|
+
var import_BdxError = require("./BdxError.js");
|
|
27
|
+
var import_BdxMessenger = require("./BdxMessenger.js");
|
|
28
|
+
var import_Flow = require("./flow/Flow.js");
|
|
29
|
+
var import_BdxInitMessagesSchema = require("./schema/BdxInitMessagesSchema.js");
|
|
30
|
+
/**
|
|
31
|
+
* @license
|
|
32
|
+
* Copyright 2022-2025 Matter.js Authors
|
|
33
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
34
|
+
*/
|
|
35
|
+
const logger = import_general.Logger.get("bdxSessionInitiator");
|
|
36
|
+
async function bdxSessionInitiator(messenger, config) {
|
|
37
|
+
if (config.isInitiator) {
|
|
38
|
+
if (config.isSender) {
|
|
39
|
+
const initMessage2 = await buildInitMessage();
|
|
40
|
+
const acceptMessage3 = await messenger.sendSendInit(initMessage2);
|
|
41
|
+
return collectAcceptParameters(
|
|
42
|
+
acceptMessage3,
|
|
43
|
+
// We define the data, so we know it are numbers
|
|
44
|
+
initMessage2.startOffset !== void 0 ? Number(initMessage2.startOffset) : void 0,
|
|
45
|
+
initMessage2.maxLength !== void 0 ? Number(initMessage2.maxLength) : void 0
|
|
46
|
+
);
|
|
47
|
+
}
|
|
48
|
+
const acceptMessage2 = await messenger.sendReceiveInit(await buildInitMessage());
|
|
49
|
+
return collectAcceptParameters(acceptMessage2);
|
|
50
|
+
}
|
|
51
|
+
const initMessage = config.initMessage;
|
|
52
|
+
if (initMessage === void 0) {
|
|
53
|
+
throw new import_general.InternalError("Initial message must be set before starting from initial message");
|
|
54
|
+
}
|
|
55
|
+
logger.debug(`Initialize BDX ${config.isSender ? "ReceiveInit" : "SendInit"} from incoming Message`, initMessage);
|
|
56
|
+
if (config.isSender) {
|
|
57
|
+
if (!config.fileDesignator.exists()) {
|
|
58
|
+
throw new import_BdxError.BdxError(
|
|
59
|
+
`File designator ${config.fileDesignator.text} does not point to an existing file in the storage to send data`,
|
|
60
|
+
import_types.BdxStatusCode.FileDesignatorUnknown
|
|
61
|
+
);
|
|
62
|
+
}
|
|
63
|
+
let { startOffset } = initMessage;
|
|
64
|
+
if (startOffset !== void 0) {
|
|
65
|
+
startOffset = import_BdxMessenger.BdxMessenger.asSafeNumber(startOffset, "Start offset", import_types.BdxStatusCode.StartOffsetNotSupported);
|
|
66
|
+
}
|
|
67
|
+
const acceptMessage2 = await determineAcceptParameters(initMessage);
|
|
68
|
+
const length = "length" in acceptMessage2 && typeof acceptMessage2.length === "number" ? acceptMessage2.length : void 0;
|
|
69
|
+
const blobToRead = await config.fileDesignator.openBlob();
|
|
70
|
+
if (length !== void 0 && length > 0) {
|
|
71
|
+
const availableSize = blobToRead.size - (startOffset ?? 0);
|
|
72
|
+
if (length > availableSize) {
|
|
73
|
+
throw new import_BdxError.BdxError(
|
|
74
|
+
`Requested maxLength ${length}bytes${startOffset ? ` with startOffset ${startOffset}` : ""} exceeds available size ${blobToRead.size} for blob ${config.fileDesignator.text}`,
|
|
75
|
+
import_types.BdxStatusCode.LengthTooLarge
|
|
76
|
+
);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
await messenger.sendReceiveAccept(acceptMessage2);
|
|
80
|
+
return collectAcceptParameters(acceptMessage2, startOffset, length);
|
|
81
|
+
}
|
|
82
|
+
const acceptMessage = {
|
|
83
|
+
...await determineAcceptParameters(initMessage),
|
|
84
|
+
length: void 0
|
|
85
|
+
// Length is not included in SendAccept, so take out to not confuse in logs
|
|
86
|
+
};
|
|
87
|
+
await messenger.sendSendAccept(acceptMessage);
|
|
88
|
+
return collectAcceptParameters(acceptMessage);
|
|
89
|
+
async function buildInitMessage() {
|
|
90
|
+
const {
|
|
91
|
+
senderStartOffset,
|
|
92
|
+
maxTransferSize,
|
|
93
|
+
senderMaxLength,
|
|
94
|
+
preferredDriverModes,
|
|
95
|
+
asynchronousTransferAllowed
|
|
96
|
+
} = config.transferConfig;
|
|
97
|
+
const { isSender, fileDesignator } = config;
|
|
98
|
+
let startOffset;
|
|
99
|
+
let maxLength;
|
|
100
|
+
if (isSender) {
|
|
101
|
+
maxLength = (await fileDesignator.openBlob()).size;
|
|
102
|
+
if (senderStartOffset !== void 0) {
|
|
103
|
+
if (maxLength <= senderStartOffset) {
|
|
104
|
+
throw new import_general.ImplementationError(
|
|
105
|
+
`Available data of ${maxLength}bytes are smaller than senderStartOffset ${senderStartOffset}bytes`
|
|
106
|
+
);
|
|
107
|
+
}
|
|
108
|
+
startOffset = senderStartOffset;
|
|
109
|
+
maxLength -= startOffset;
|
|
110
|
+
}
|
|
111
|
+
if (maxTransferSize !== void 0) {
|
|
112
|
+
if (maxLength > maxTransferSize) {
|
|
113
|
+
throw new import_general.ImplementationError(
|
|
114
|
+
`Requested maxLength ${maxLength}bytes exceeds maximum transfer size ${maxTransferSize}bytes`
|
|
115
|
+
);
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
if (senderMaxLength !== void 0) {
|
|
119
|
+
if (maxLength >= senderMaxLength) {
|
|
120
|
+
maxLength = senderMaxLength;
|
|
121
|
+
} else {
|
|
122
|
+
logger.info(
|
|
123
|
+
`Ignoring requested senderMaxLength ${senderMaxLength}bytes as it is larger then the relevant payload size of ${maxLength}bytes`
|
|
124
|
+
);
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
let maxBlockSize = messenger.maxPayloadSize - 4;
|
|
129
|
+
const requestedBlockSize = config.transferConfig.maxBlockSize;
|
|
130
|
+
if (requestedBlockSize !== void 0) {
|
|
131
|
+
if (maxBlockSize > requestedBlockSize) {
|
|
132
|
+
maxBlockSize = requestedBlockSize;
|
|
133
|
+
} else {
|
|
134
|
+
logger.info(
|
|
135
|
+
`Ignoring requested maxBlockSize ${requestedBlockSize}, as it is larger then the transport max payload size ${maxBlockSize}bytes`
|
|
136
|
+
);
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
return {
|
|
140
|
+
transferProtocol: {
|
|
141
|
+
version: import_BdxInitMessagesSchema.BDX_VERSION,
|
|
142
|
+
senderDrive: !!preferredDriverModes?.includes(import_Flow.Flow.DriverMode.SenderDrive),
|
|
143
|
+
receiverDrive: !!preferredDriverModes?.includes(import_Flow.Flow.DriverMode.ReceiverDrive),
|
|
144
|
+
asynchronousTransfer: asynchronousTransferAllowed
|
|
145
|
+
// always false for now
|
|
146
|
+
},
|
|
147
|
+
maxBlockSize,
|
|
148
|
+
fileDesignator: fileDesignator.bytes,
|
|
149
|
+
startOffset,
|
|
150
|
+
maxLength
|
|
151
|
+
};
|
|
152
|
+
}
|
|
153
|
+
async function determineAcceptParameters(initMessage2) {
|
|
154
|
+
const { transferProtocol, maxLength: initMaxLength = 0 } = initMessage2;
|
|
155
|
+
let { maxBlockSize } = initMessage2;
|
|
156
|
+
let finalDriverMode;
|
|
157
|
+
for (const mode of config.transferConfig.preferredDriverModes) {
|
|
158
|
+
if (transferProtocol[mode]) {
|
|
159
|
+
finalDriverMode = mode;
|
|
160
|
+
break;
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
if (finalDriverMode === void 0) {
|
|
164
|
+
throw new import_BdxError.BdxError("Can not determine a valid transfer mode", import_types.BdxStatusCode.TransferMethodNotSupported);
|
|
165
|
+
}
|
|
166
|
+
const requestedMaxBlockSize = config.transferConfig.maxBlockSize;
|
|
167
|
+
if (requestedMaxBlockSize !== void 0 && maxBlockSize > requestedMaxBlockSize) {
|
|
168
|
+
maxBlockSize = requestedMaxBlockSize;
|
|
169
|
+
}
|
|
170
|
+
const maxLength = import_BdxMessenger.BdxMessenger.asSafeNumber(initMaxLength, "Max length", import_types.BdxStatusCode.LengthTooLarge);
|
|
171
|
+
const transferControl = {
|
|
172
|
+
version: import_BdxInitMessagesSchema.BDX_VERSION,
|
|
173
|
+
// We support the minimum version, so no need for further checks
|
|
174
|
+
[finalDriverMode]: true,
|
|
175
|
+
// this sets either senderDrive or receiveDriver property
|
|
176
|
+
asynchronousTransfer: false
|
|
177
|
+
// Not supported so ignore if it was received
|
|
178
|
+
};
|
|
179
|
+
return {
|
|
180
|
+
transferControl,
|
|
181
|
+
maxBlockSize,
|
|
182
|
+
length: maxLength > 0 ? maxLength : void 0
|
|
183
|
+
};
|
|
184
|
+
}
|
|
185
|
+
function collectAcceptParameters(acceptMessage2, startOffset = 0, maxLength) {
|
|
186
|
+
const {
|
|
187
|
+
transferControl: { senderDrive, asynchronousTransfer },
|
|
188
|
+
maxBlockSize
|
|
189
|
+
} = acceptMessage2;
|
|
190
|
+
if (asynchronousTransfer) {
|
|
191
|
+
throw new import_BdxError.BdxError(
|
|
192
|
+
"Asynchronous transfer is not supported in this implementation",
|
|
193
|
+
import_types.BdxStatusCode.TransferMethodNotSupported
|
|
194
|
+
);
|
|
195
|
+
}
|
|
196
|
+
const dataLength = "length" in acceptMessage2 && acceptMessage2.length !== void 0 ? import_BdxMessenger.BdxMessenger.asSafeNumber(
|
|
197
|
+
acceptMessage2.length,
|
|
198
|
+
"Accept message length field",
|
|
199
|
+
import_types.BdxStatusCode.LengthTooLarge
|
|
200
|
+
) : maxLength;
|
|
201
|
+
const transferParameters = {
|
|
202
|
+
transferMode: senderDrive ? import_Flow.Flow.DriverMode.SenderDrive : import_Flow.Flow.DriverMode.ReceiverDrive,
|
|
203
|
+
asynchronousTransfer: false,
|
|
204
|
+
// always false for now
|
|
205
|
+
dataLength,
|
|
206
|
+
startOffset,
|
|
207
|
+
blockSize: maxBlockSize,
|
|
208
|
+
isDriver: config.isSender && senderDrive || !config.isSender && !senderDrive,
|
|
209
|
+
fileDesignator: config.fileDesignator
|
|
210
|
+
};
|
|
211
|
+
logger.debug(
|
|
212
|
+
`${transferParameters.isDriver ? "We are" : "Peer is"} driving-${config.isSender ? "sender" : "receiver"} with negotiated transfer parameters`,
|
|
213
|
+
transferParameters
|
|
214
|
+
);
|
|
215
|
+
return transferParameters;
|
|
216
|
+
}
|
|
217
|
+
}
|
|
218
|
+
//# sourceMappingURL=bdx-session-initiator.js.map
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/bdx/bdx-session-initiator.ts"],
|
|
4
|
+
"mappings": "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",
|
|
5
|
+
"names": ["initMessage", "acceptMessage"]
|
|
6
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2022-2025 Matter.js Authors
|
|
4
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
+
*/
|
|
6
|
+
import { OutboundFlow } from "./OutboundFlow.js";
|
|
7
|
+
/**
|
|
8
|
+
* BDX Transport flow logic for a "BDX Driving Sender":
|
|
9
|
+
* - Send out the Block and wait for Ack (if synchronous transfer is used)
|
|
10
|
+
* - Last message is sent with BlockEof and expects AckEof
|
|
11
|
+
*/
|
|
12
|
+
export declare class DrivenSendingFlow extends OutboundFlow {
|
|
13
|
+
protected transferNextChunk(): Promise<boolean>;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=DrivenSendingFlow.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DrivenSendingFlow.d.ts","sourceRoot":"","sources":["../../../../src/bdx/flow/DrivenSendingFlow.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AAEjD;;;;GAIG;AACH,qBAAa,iBAAkB,SAAQ,YAAY;cAC/B,iBAAiB;CAyBpC"}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
var DrivenSendingFlow_exports = {};
|
|
20
|
+
__export(DrivenSendingFlow_exports, {
|
|
21
|
+
DrivenSendingFlow: () => DrivenSendingFlow
|
|
22
|
+
});
|
|
23
|
+
module.exports = __toCommonJS(DrivenSendingFlow_exports);
|
|
24
|
+
var import_OutboundFlow = require("./OutboundFlow.js");
|
|
25
|
+
/**
|
|
26
|
+
* @license
|
|
27
|
+
* Copyright 2022-2025 Matter.js Authors
|
|
28
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
29
|
+
*/
|
|
30
|
+
class DrivenSendingFlow extends import_OutboundFlow.OutboundFlow {
|
|
31
|
+
async transferNextChunk() {
|
|
32
|
+
const { asynchronousTransfer } = this.transferParameters;
|
|
33
|
+
const { iterator } = this.stream;
|
|
34
|
+
const blockCounter = this.nextMessageCounter;
|
|
35
|
+
const { data, done } = await this.readDataChunk(iterator);
|
|
36
|
+
if (done) {
|
|
37
|
+
await this.messenger.sendBlockEof({ data: data ?? new Uint8Array(), blockCounter });
|
|
38
|
+
this.finalBlockCounter = blockCounter;
|
|
39
|
+
return true;
|
|
40
|
+
}
|
|
41
|
+
await this.messenger.sendBlock({ data, blockCounter });
|
|
42
|
+
if (!asynchronousTransfer) {
|
|
43
|
+
const { blockCounter: ackedBlockCounter } = await this.messenger.readBlockAck();
|
|
44
|
+
this.validateCounter(ackedBlockCounter, blockCounter);
|
|
45
|
+
}
|
|
46
|
+
return false;
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
//# sourceMappingURL=DrivenSendingFlow.js.map
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../src/bdx/flow/DrivenSendingFlow.ts"],
|
|
4
|
+
"mappings": ";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAMA,0BAA6B;AAN7B;AAAA;AAAA;AAAA;AAAA;AAaO,MAAM,0BAA0B,iCAAa;AAAA,EAChD,MAAgB,oBAAoB;AAChC,UAAM,EAAE,qBAAqB,IAAI,KAAK;AACtC,UAAM,EAAE,SAAS,IAAI,KAAK;AAE1B,UAAM,eAAe,KAAK;AAE1B,UAAM,EAAE,MAAM,KAAK,IAAI,MAAM,KAAK,cAAc,QAAQ;AAExD,QAAI,MAAM;AAEN,YAAM,KAAK,UAAU,aAAa,EAAE,MAAM,QAAQ,IAAI,WAAW,GAAG,aAAa,CAAC;AAClF,WAAK,oBAAoB;AACzB,aAAO;AAAA,IACX;AAGA,UAAM,KAAK,UAAU,UAAU,EAAE,MAAM,aAAa,CAAC;AAGrD,QAAI,CAAC,sBAAsB;AACvB,YAAM,EAAE,cAAc,kBAAkB,IAAI,MAAM,KAAK,UAAU,aAAa;AAC9E,WAAK,gBAAgB,mBAAmB,YAAY;AAAA,IACxD;AACA,WAAO;AAAA,EACX;AACJ;",
|
|
5
|
+
"names": []
|
|
6
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2022-2025 Matter.js Authors
|
|
4
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
+
*/
|
|
6
|
+
import { InboundFlow } from "./InboundFlow.js";
|
|
7
|
+
/**
|
|
8
|
+
* BDX Transport flow logic for a "BDX Driving Receiver":
|
|
9
|
+
* - Requests the next Blow using BlockQuery and then reads the Block
|
|
10
|
+
* - Last message is confirmed with an AckEof
|
|
11
|
+
*/
|
|
12
|
+
export declare class DrivingReceivingFlow extends InboundFlow {
|
|
13
|
+
transferNextChunk(): Promise<boolean>;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=DrivingReceivingFlow.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DrivingReceivingFlow.d.ts","sourceRoot":"","sources":["../../../../src/bdx/flow/DrivingReceivingFlow.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAE/C;;;;GAIG;AACH,qBAAa,oBAAqB,SAAQ,WAAW;IAC3C,iBAAiB;CAwB1B"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
var DrivingReceivingFlow_exports = {};
|
|
20
|
+
__export(DrivingReceivingFlow_exports, {
|
|
21
|
+
DrivingReceivingFlow: () => DrivingReceivingFlow
|
|
22
|
+
});
|
|
23
|
+
module.exports = __toCommonJS(DrivingReceivingFlow_exports);
|
|
24
|
+
var import_InboundFlow = require("./InboundFlow.js");
|
|
25
|
+
/**
|
|
26
|
+
* @license
|
|
27
|
+
* Copyright 2022-2025 Matter.js Authors
|
|
28
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
29
|
+
*/
|
|
30
|
+
class DrivingReceivingFlow extends import_InboundFlow.InboundFlow {
|
|
31
|
+
async transferNextChunk() {
|
|
32
|
+
const { writeController } = this.stream;
|
|
33
|
+
const blockCounter = this.nextMessageCounter;
|
|
34
|
+
await this.messenger.sendBlockQuery({ blockCounter });
|
|
35
|
+
const {
|
|
36
|
+
kind: messageType,
|
|
37
|
+
message: { blockCounter: dataBlockCounter, data }
|
|
38
|
+
} = await this.messenger.readBlock();
|
|
39
|
+
this.validateCounter(dataBlockCounter, blockCounter);
|
|
40
|
+
if (this.writeDataChunk(writeController, data, messageType)) {
|
|
41
|
+
this.finalBlockCounter = dataBlockCounter;
|
|
42
|
+
return true;
|
|
43
|
+
}
|
|
44
|
+
return false;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=DrivingReceivingFlow.js.map
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../src/bdx/flow/DrivingReceivingFlow.ts"],
|
|
4
|
+
"mappings": ";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAMA,yBAA4B;AAN5B;AAAA;AAAA;AAAA;AAAA;AAaO,MAAM,6BAA6B,+BAAY;AAAA,EAClD,MAAM,oBAAoB;AACtB,UAAM,EAAE,gBAAgB,IAAI,KAAK;AAEjC,UAAM,eAAe,KAAK;AAI1B,UAAM,KAAK,UAAU,eAAe,EAAE,aAAa,CAAC;AAGpD,UAAM;AAAA,MACF,MAAM;AAAA,MACN,SAAS,EAAE,cAAc,kBAAkB,KAAK;AAAA,IACpD,IAAI,MAAM,KAAK,UAAU,UAAU;AACnC,SAAK,gBAAgB,kBAAkB,YAAY;AAGnD,QAAI,KAAK,eAAe,iBAAiB,MAAM,WAAW,GAAG;AACzD,WAAK,oBAAoB;AACzB,aAAO;AAAA,IACX;AAEA,WAAO;AAAA,EACX;AACJ;",
|
|
5
|
+
"names": []
|
|
6
|
+
}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2022-2025 Matter.js Authors
|
|
4
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
+
*/
|
|
6
|
+
import { BdxMessenger } from "../BdxMessenger.js";
|
|
7
|
+
import { PersistedFileDesignator } from "../PersistedFileDesignator.js";
|
|
8
|
+
/** Base class for BDX transfer flows. */
|
|
9
|
+
export declare abstract class Flow {
|
|
10
|
+
#private;
|
|
11
|
+
constructor(messenger: BdxMessenger, transferParameters: Flow.TransferOptions);
|
|
12
|
+
protected get transferParameters(): Flow.TransferOptions;
|
|
13
|
+
protected get isClosed(): boolean;
|
|
14
|
+
protected get messenger(): BdxMessenger;
|
|
15
|
+
protected get bytesLeft(): number | undefined;
|
|
16
|
+
protected set bytesLeft(value: number);
|
|
17
|
+
protected set finalBlockCounter(blockCounter: number);
|
|
18
|
+
protected get finalBlockCounter(): number;
|
|
19
|
+
/** Determines the next message counter to use for the next message, also handles wrapping around at 2^32. */
|
|
20
|
+
protected get nextMessageCounter(): number;
|
|
21
|
+
/** Utility function to check if a block counter is valid */
|
|
22
|
+
protected validateCounter(messageBlockCounter: number, expectedCounter?: number): number;
|
|
23
|
+
close(_error?: unknown): Promise<void>;
|
|
24
|
+
/**
|
|
25
|
+
* Main logic method to execute the flow.
|
|
26
|
+
* The promise resolves when the flow is complete, or rejects on any error or unexpected conditions.
|
|
27
|
+
*/
|
|
28
|
+
processTransfer(): Promise<void>;
|
|
29
|
+
protected abstract initTransfer(): Promise<void>;
|
|
30
|
+
protected abstract transferNextChunk(): Promise<boolean>;
|
|
31
|
+
protected abstract finalizeTransfer(): Promise<void>;
|
|
32
|
+
}
|
|
33
|
+
export declare namespace Flow {
|
|
34
|
+
interface TransferOptions {
|
|
35
|
+
transferMode: DriverMode;
|
|
36
|
+
asynchronousTransfer: false;
|
|
37
|
+
dataLength?: number;
|
|
38
|
+
startOffset: number;
|
|
39
|
+
blockSize: number;
|
|
40
|
+
isDriver: boolean;
|
|
41
|
+
fileDesignator: PersistedFileDesignator;
|
|
42
|
+
}
|
|
43
|
+
enum DriverMode {
|
|
44
|
+
SenderDrive = "senderDrive",
|
|
45
|
+
ReceiverDrive = "receiverDrive"
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
//# sourceMappingURL=Flow.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Flow.d.ts","sourceRoot":"","sources":["../../../../src/bdx/flow/Flow.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAKH,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,uBAAuB,EAAE,MAAM,+BAA+B,CAAC;AAExE,yCAAyC;AACzC,8BAAsB,IAAI;;gBAQV,SAAS,EAAE,YAAY,EAAE,kBAAkB,EAAE,IAAI,CAAC,eAAe;IAM7E,SAAS,KAAK,kBAAkB,IAAI,IAAI,CAAC,eAAe,CAEvD;IAED,SAAS,KAAK,QAAQ,YAErB;IAED,SAAS,KAAK,SAAS,iBAEtB;IAED,SAAS,KAAK,SAAS,IAAI,MAAM,GAAG,SAAS,CAE5C;IAED,SAAS,KAAK,SAAS,CAAC,KAAK,EAAE,MAAM,EAEpC;IAED,SAAS,KAAK,iBAAiB,CAAC,YAAY,EAAE,MAAM,EAKnD;IAED,SAAS,KAAK,iBAAiB,IAPe,MAAM,CAYnD;IAED,6GAA6G;IAC7G,SAAS,KAAK,kBAAkB,WAG/B;IAED,4DAA4D;IAC5D,SAAS,CAAC,eAAe,CAAC,mBAAmB,EAAE,MAAM,EAAE,eAAe,SAA0B;IAU1F,KAAK,CAAC,MAAM,CAAC,EAAE,OAAO;IAI5B;;;OAGG;IACG,eAAe;IAerB,SAAS,CAAC,QAAQ,CAAC,YAAY,IAAI,OAAO,CAAC,IAAI,CAAC;IAEhD,SAAS,CAAC,QAAQ,CAAC,iBAAiB,IAAI,OAAO,CAAC,OAAO,CAAC;IAExD,SAAS,CAAC,QAAQ,CAAC,gBAAgB,IAAI,OAAO,CAAC,IAAI,CAAC;CACvD;AAED,yBAAiB,IAAI,CAAC;IAClB,UAAiB,eAAe;QAC5B,YAAY,EAAE,UAAU,CAAC;QACzB,oBAAoB,EAAE,KAAK,CAAC;QAC5B,UAAU,CAAC,EAAE,MAAM,CAAC;QACpB,WAAW,EAAE,MAAM,CAAC;QACpB,SAAS,EAAE,MAAM,CAAC;QAClB,QAAQ,EAAE,OAAO,CAAC;QAClB,cAAc,EAAE,uBAAuB,CAAC;KAC3C;IAED,KAAY,UAAU;QAClB,WAAW,gBAAgB;QAC3B,aAAa,kBAAkB;KAClC;CACJ"}
|
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
var Flow_exports = {};
|
|
20
|
+
__export(Flow_exports, {
|
|
21
|
+
Flow: () => Flow
|
|
22
|
+
});
|
|
23
|
+
module.exports = __toCommonJS(Flow_exports);
|
|
24
|
+
var import_general = require("#general");
|
|
25
|
+
var import_types = require("#types");
|
|
26
|
+
var import_BdxError = require("../BdxError.js");
|
|
27
|
+
/**
|
|
28
|
+
* @license
|
|
29
|
+
* Copyright 2022-2025 Matter.js Authors
|
|
30
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
31
|
+
*/
|
|
32
|
+
class Flow {
|
|
33
|
+
#transferParameters;
|
|
34
|
+
#messenger;
|
|
35
|
+
#isClosed = false;
|
|
36
|
+
#blockCounter = 0;
|
|
37
|
+
#bytesLeft;
|
|
38
|
+
#finalBlockCounter;
|
|
39
|
+
constructor(messenger, transferParameters) {
|
|
40
|
+
this.#messenger = messenger;
|
|
41
|
+
this.#transferParameters = transferParameters;
|
|
42
|
+
this.#bytesLeft = transferParameters.dataLength;
|
|
43
|
+
}
|
|
44
|
+
get transferParameters() {
|
|
45
|
+
return this.#transferParameters;
|
|
46
|
+
}
|
|
47
|
+
get isClosed() {
|
|
48
|
+
return this.#isClosed;
|
|
49
|
+
}
|
|
50
|
+
get messenger() {
|
|
51
|
+
return this.#messenger;
|
|
52
|
+
}
|
|
53
|
+
get bytesLeft() {
|
|
54
|
+
return this.#bytesLeft;
|
|
55
|
+
}
|
|
56
|
+
set bytesLeft(value) {
|
|
57
|
+
this.#bytesLeft = value;
|
|
58
|
+
}
|
|
59
|
+
set finalBlockCounter(blockCounter) {
|
|
60
|
+
if (this.#finalBlockCounter !== void 0) {
|
|
61
|
+
throw new import_general.InternalError("Transfer already finalized. finalizeTransfer() should only be called once.");
|
|
62
|
+
}
|
|
63
|
+
this.#finalBlockCounter = blockCounter;
|
|
64
|
+
}
|
|
65
|
+
get finalBlockCounter() {
|
|
66
|
+
if (this.#finalBlockCounter === void 0) {
|
|
67
|
+
throw new import_general.InternalError("Transfer not finalized. Call finalizeTransfer() after completing the transfer.");
|
|
68
|
+
}
|
|
69
|
+
return this.#finalBlockCounter;
|
|
70
|
+
}
|
|
71
|
+
/** Determines the next message counter to use for the next message, also handles wrapping around at 2^32. */
|
|
72
|
+
get nextMessageCounter() {
|
|
73
|
+
this.#blockCounter = (this.#blockCounter + 1) % 4294967296;
|
|
74
|
+
return this.#blockCounter;
|
|
75
|
+
}
|
|
76
|
+
/** Utility function to check if a block counter is valid */
|
|
77
|
+
validateCounter(messageBlockCounter, expectedCounter = this.nextMessageCounter) {
|
|
78
|
+
if (messageBlockCounter !== expectedCounter) {
|
|
79
|
+
throw new import_BdxError.BdxError(
|
|
80
|
+
`Received Block with unexpected block counter: ${messageBlockCounter}, expected: ${expectedCounter}`,
|
|
81
|
+
import_types.BdxStatusCode.BadBlockCounter
|
|
82
|
+
);
|
|
83
|
+
}
|
|
84
|
+
return messageBlockCounter;
|
|
85
|
+
}
|
|
86
|
+
async close(_error) {
|
|
87
|
+
this.#isClosed = true;
|
|
88
|
+
}
|
|
89
|
+
/**
|
|
90
|
+
* Main logic method to execute the flow.
|
|
91
|
+
* The promise resolves when the flow is complete, or rejects on any error or unexpected conditions.
|
|
92
|
+
*/
|
|
93
|
+
async processTransfer() {
|
|
94
|
+
await this.initTransfer();
|
|
95
|
+
while (!this.isClosed) {
|
|
96
|
+
if (await this.transferNextChunk()) {
|
|
97
|
+
break;
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
if (!this.isClosed) {
|
|
101
|
+
await this.finalizeTransfer();
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
((Flow2) => {
|
|
106
|
+
let DriverMode;
|
|
107
|
+
((DriverMode2) => {
|
|
108
|
+
DriverMode2["SenderDrive"] = "senderDrive";
|
|
109
|
+
DriverMode2["ReceiverDrive"] = "receiverDrive";
|
|
110
|
+
})(DriverMode = Flow2.DriverMode || (Flow2.DriverMode = {}));
|
|
111
|
+
})(Flow || (Flow = {}));
|
|
112
|
+
//# sourceMappingURL=Flow.js.map
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../src/bdx/flow/Flow.ts"],
|
|
4
|
+
"mappings": ";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAMA,qBAA8B;AAC9B,mBAA8B;AAC9B,sBAAyB;AARzB;AAAA;AAAA;AAAA;AAAA;AAaO,MAAe,KAAK;AAAA,EACd;AAAA,EACA;AAAA,EACT,YAAY;AAAA,EACZ,gBAAgB;AAAA,EAChB;AAAA,EACA;AAAA,EAEA,YAAY,WAAyB,oBAA0C;AAC3E,SAAK,aAAa;AAClB,SAAK,sBAAsB;AAC3B,SAAK,aAAa,mBAAmB;AAAA,EACzC;AAAA,EAEA,IAAc,qBAA2C;AACrD,WAAO,KAAK;AAAA,EAChB;AAAA,EAEA,IAAc,WAAW;AACrB,WAAO,KAAK;AAAA,EAChB;AAAA,EAEA,IAAc,YAAY;AACtB,WAAO,KAAK;AAAA,EAChB;AAAA,EAEA,IAAc,YAAgC;AAC1C,WAAO,KAAK;AAAA,EAChB;AAAA,EAEA,IAAc,UAAU,OAAe;AACnC,SAAK,aAAa;AAAA,EACtB;AAAA,EAEA,IAAc,kBAAkB,cAAsB;AAClD,QAAI,KAAK,uBAAuB,QAAW;AACvC,YAAM,IAAI,6BAAc,4EAA4E;AAAA,IACxG;AACA,SAAK,qBAAqB;AAAA,EAC9B;AAAA,EAEA,IAAc,oBAAoB;AAC9B,QAAI,KAAK,uBAAuB,QAAW;AACvC,YAAM,IAAI,6BAAc,gFAAgF;AAAA,IAC5G;AACA,WAAO,KAAK;AAAA,EAChB;AAAA;AAAA,EAGA,IAAc,qBAAqB;AAC/B,SAAK,iBAAiB,KAAK,gBAAgB,KAAK;AAChD,WAAO,KAAK;AAAA,EAChB;AAAA;AAAA,EAGU,gBAAgB,qBAA6B,kBAAkB,KAAK,oBAAoB;AAC9F,QAAI,wBAAwB,iBAAiB;AACzC,YAAM,IAAI;AAAA,QACN,iDAAiD,mBAAmB,eAAe,eAAe;AAAA,QAClG,2BAAc;AAAA,MAClB;AAAA,IACJ;AACA,WAAO;AAAA,EACX;AAAA,EAEA,MAAM,MAAM,QAAkB;AAC1B,SAAK,YAAY;AAAA,EACrB;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,MAAM,kBAAkB;AACpB,UAAM,KAAK,aAAa;AAGxB,WAAO,CAAC,KAAK,UAAU;AACnB,UAAI,MAAM,KAAK,kBAAkB,GAAG;AAChC;AAAA,MACJ;AAAA,IACJ;AAEA,QAAI,CAAC,KAAK,UAAU;AAChB,YAAM,KAAK,iBAAiB;AAAA,IAChC;AAAA,EACJ;AAOJ;AAAA,CAEO,CAAUA,UAAV;AAWI,MAAK;AAAL,IAAKC,gBAAL;AACH,IAAAA,YAAA,iBAAc;AACd,IAAAA,YAAA,mBAAgB;AAAA,KAFR,aAAAD,MAAA,eAAAA,MAAA;AAAA,GAXC;",
|
|
5
|
+
"names": ["Flow", "DriverMode"]
|
|
6
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2022-2025 Matter.js Authors
|
|
4
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
+
*/
|
|
6
|
+
import { OutboundFlow } from "./OutboundFlow.js";
|
|
7
|
+
/**
|
|
8
|
+
* BDX Transport flow logic for a "BDX Following Receiver":
|
|
9
|
+
* - Reads BlockQuery(WithSkip) messages and responds with Block or (for last block) BlockEof.
|
|
10
|
+
* Data are skipped over when requested by the peer.
|
|
11
|
+
* - After the last block is send it expects an AckEof
|
|
12
|
+
*/
|
|
13
|
+
export declare class FollowingReceivingFlow extends OutboundFlow {
|
|
14
|
+
protected transferNextChunk(): Promise<boolean>;
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=FollowingReceivingFlow.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FollowingReceivingFlow.d.ts","sourceRoot":"","sources":["../../../../src/bdx/flow/FollowingReceivingFlow.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAMH,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AAGjD;;;;;GAKG;AACH,qBAAa,sBAAuB,SAAQ,YAAY;cACpC,iBAAiB;CAgCpC"}
|