@atomicfinance/types 4.2.8 → 4.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.turbo/turbo-build.log +5 -4
- package/.turbo/turbo-lint.log +5 -0
- package/.turbo/turbo-test.log +0 -0
- package/.yalc/@node-dlc/bitcoin/.nyc_output/982e80bf-a70c-452f-b63d-d749ae385531.json +1 -0
- package/.yalc/@node-dlc/bitcoin/.nyc_output/processinfo/982e80bf-a70c-452f-b63d-d749ae385531.json +1 -0
- package/.yalc/@node-dlc/bitcoin/.nyc_output/processinfo/index.json +1 -0
- package/.yalc/@node-dlc/bitcoin/README.md +11 -0
- package/.yalc/@node-dlc/bitcoin/__tests__/bitcoin/amount.spec.ts +330 -0
- package/.yalc/@node-dlc/bitcoin/__tests__/bitcoin/value.spec.ts +320 -0
- package/.yalc/@node-dlc/bitcoin/__tests__/tsconfig.json +8 -0
- package/.yalc/@node-dlc/bitcoin/coverage/lcov-report/Amount.ts.html +290 -0
- package/.yalc/@node-dlc/bitcoin/coverage/lcov-report/Base58.ts.html +269 -0
- package/.yalc/@node-dlc/bitcoin/coverage/lcov-report/Base58Check.ts.html +182 -0
- package/.yalc/@node-dlc/bitcoin/coverage/lcov-report/BitcoinError.ts.html +173 -0
- package/.yalc/@node-dlc/bitcoin/coverage/lcov-report/BitcoinErrorCode.ts.html +110 -0
- package/.yalc/@node-dlc/bitcoin/coverage/lcov-report/HashByteOrder.ts.html +143 -0
- package/.yalc/@node-dlc/bitcoin/coverage/lcov-report/HashValue.ts.html +350 -0
- package/.yalc/@node-dlc/bitcoin/coverage/lcov-report/LexicographicalSorters.ts.html +191 -0
- package/.yalc/@node-dlc/bitcoin/coverage/lcov-report/LockTime.ts.html +386 -0
- package/.yalc/@node-dlc/bitcoin/coverage/lcov-report/OpCodes.ts.html +437 -0
- package/.yalc/@node-dlc/bitcoin/coverage/lcov-report/OutPoint.ts.html +383 -0
- package/.yalc/@node-dlc/bitcoin/coverage/lcov-report/Script.ts.html +1607 -0
- package/.yalc/@node-dlc/bitcoin/coverage/lcov-report/Sequence.ts.html +713 -0
- package/.yalc/@node-dlc/bitcoin/coverage/lcov-report/SigHashType.ts.html +137 -0
- package/.yalc/@node-dlc/bitcoin/coverage/lcov-report/Stack.ts.html +323 -0
- package/.yalc/@node-dlc/bitcoin/coverage/lcov-report/TimeLockMode.ts.html +128 -0
- package/.yalc/@node-dlc/bitcoin/coverage/lcov-report/Tx.ts.html +1520 -0
- package/.yalc/@node-dlc/bitcoin/coverage/lcov-report/TxBuilder.ts.html +971 -0
- package/.yalc/@node-dlc/bitcoin/coverage/lcov-report/TxIn.ts.html +425 -0
- package/.yalc/@node-dlc/bitcoin/coverage/lcov-report/TxOut.ts.html +341 -0
- package/.yalc/@node-dlc/bitcoin/coverage/lcov-report/Value.ts.html +683 -0
- package/.yalc/@node-dlc/bitcoin/coverage/lcov-report/Wif.ts.html +311 -0
- package/.yalc/@node-dlc/bitcoin/coverage/lcov-report/Witness.ts.html +275 -0
- package/.yalc/@node-dlc/bitcoin/coverage/lcov-report/base.css +224 -0
- package/.yalc/@node-dlc/bitcoin/coverage/lcov-report/block-navigation.js +79 -0
- package/.yalc/@node-dlc/bitcoin/coverage/lcov-report/favicon.png +0 -0
- package/.yalc/@node-dlc/bitcoin/coverage/lcov-report/index.html +126 -0
- package/.yalc/@node-dlc/bitcoin/coverage/lcov-report/index.ts.html +164 -0
- package/.yalc/@node-dlc/bitcoin/coverage/lcov-report/prettify.css +1 -0
- package/.yalc/@node-dlc/bitcoin/coverage/lcov-report/prettify.js +2 -0
- package/.yalc/@node-dlc/bitcoin/coverage/lcov-report/sort-arrow-sprite.png +0 -0
- package/.yalc/@node-dlc/bitcoin/coverage/lcov-report/sorter.js +170 -0
- package/.yalc/@node-dlc/bitcoin/coverage/lcov.info +123 -0
- package/.yalc/@node-dlc/bitcoin/dist/Amount.d.ts +48 -0
- package/.yalc/@node-dlc/bitcoin/dist/Amount.js +68 -0
- package/.yalc/@node-dlc/bitcoin/dist/Amount.js.map +1 -0
- package/.yalc/@node-dlc/bitcoin/dist/Base58.d.ts +22 -0
- package/.yalc/@node-dlc/bitcoin/dist/Base58.js +62 -0
- package/.yalc/@node-dlc/bitcoin/dist/Base58.js.map +1 -0
- package/.yalc/@node-dlc/bitcoin/dist/Base58Check.d.ts +14 -0
- package/.yalc/@node-dlc/bitcoin/dist/Base58Check.js +36 -0
- package/.yalc/@node-dlc/bitcoin/dist/Base58Check.js.map +1 -0
- package/.yalc/@node-dlc/bitcoin/dist/BitcoinError.d.ts +6 -0
- package/.yalc/@node-dlc/bitcoin/dist/BitcoinError.js +36 -0
- package/.yalc/@node-dlc/bitcoin/dist/BitcoinError.js.map +1 -0
- package/.yalc/@node-dlc/bitcoin/dist/BitcoinErrorCode.d.ts +10 -0
- package/.yalc/@node-dlc/bitcoin/dist/BitcoinErrorCode.js +15 -0
- package/.yalc/@node-dlc/bitcoin/dist/BitcoinErrorCode.js.map +1 -0
- package/.yalc/@node-dlc/bitcoin/dist/Block.d.ts +19 -0
- package/.yalc/@node-dlc/bitcoin/dist/Block.js +3 -0
- package/.yalc/@node-dlc/bitcoin/dist/Block.js.map +1 -0
- package/.yalc/@node-dlc/bitcoin/dist/HashByteOrder.d.ts +20 -0
- package/.yalc/@node-dlc/bitcoin/dist/HashByteOrder.js +25 -0
- package/.yalc/@node-dlc/bitcoin/dist/HashByteOrder.js.map +1 -0
- package/.yalc/@node-dlc/bitcoin/dist/HashValue.d.ts +55 -0
- package/.yalc/@node-dlc/bitcoin/dist/HashValue.js +82 -0
- package/.yalc/@node-dlc/bitcoin/dist/HashValue.js.map +1 -0
- package/.yalc/@node-dlc/bitcoin/dist/ICloneable.d.ts +3 -0
- package/.yalc/@node-dlc/bitcoin/dist/ICloneable.js +3 -0
- package/.yalc/@node-dlc/bitcoin/dist/ICloneable.js.map +1 -0
- package/.yalc/@node-dlc/bitcoin/dist/LexicographicalSorters.d.ts +18 -0
- package/.yalc/@node-dlc/bitcoin/dist/LexicographicalSorters.js +41 -0
- package/.yalc/@node-dlc/bitcoin/dist/LexicographicalSorters.js.map +1 -0
- package/.yalc/@node-dlc/bitcoin/dist/LockTime.d.ts +61 -0
- package/.yalc/@node-dlc/bitcoin/dist/LockTime.js +94 -0
- package/.yalc/@node-dlc/bitcoin/dist/LockTime.js.map +1 -0
- package/.yalc/@node-dlc/bitcoin/dist/OpCodes.d.ts +102 -0
- package/.yalc/@node-dlc/bitcoin/dist/OpCodes.js +116 -0
- package/.yalc/@node-dlc/bitcoin/dist/OpCodes.js.map +1 -0
- package/.yalc/@node-dlc/bitcoin/dist/OutPoint.d.ts +57 -0
- package/.yalc/@node-dlc/bitcoin/dist/OutPoint.js +88 -0
- package/.yalc/@node-dlc/bitcoin/dist/OutPoint.js.map +1 -0
- package/.yalc/@node-dlc/bitcoin/dist/Script.d.ts +185 -0
- package/.yalc/@node-dlc/bitcoin/dist/Script.js +404 -0
- package/.yalc/@node-dlc/bitcoin/dist/Script.js.map +1 -0
- package/.yalc/@node-dlc/bitcoin/dist/ScriptCmd.d.ts +3 -0
- package/.yalc/@node-dlc/bitcoin/dist/ScriptCmd.js +3 -0
- package/.yalc/@node-dlc/bitcoin/dist/ScriptCmd.js.map +1 -0
- package/.yalc/@node-dlc/bitcoin/dist/Sequence.d.ts +116 -0
- package/.yalc/@node-dlc/bitcoin/dist/Sequence.js +187 -0
- package/.yalc/@node-dlc/bitcoin/dist/Sequence.js.map +1 -0
- package/.yalc/@node-dlc/bitcoin/dist/SigHashType.d.ts +7 -0
- package/.yalc/@node-dlc/bitcoin/dist/SigHashType.js +27 -0
- package/.yalc/@node-dlc/bitcoin/dist/SigHashType.js.map +1 -0
- package/.yalc/@node-dlc/bitcoin/dist/SizeResult.d.ts +5 -0
- package/.yalc/@node-dlc/bitcoin/dist/SizeResult.js +3 -0
- package/.yalc/@node-dlc/bitcoin/dist/SizeResult.js.map +1 -0
- package/.yalc/@node-dlc/bitcoin/dist/Sorter.d.ts +1 -0
- package/.yalc/@node-dlc/bitcoin/dist/Sorter.js +3 -0
- package/.yalc/@node-dlc/bitcoin/dist/Sorter.js.map +1 -0
- package/.yalc/@node-dlc/bitcoin/dist/Stack.d.ts +15 -0
- package/.yalc/@node-dlc/bitcoin/dist/Stack.js +77 -0
- package/.yalc/@node-dlc/bitcoin/dist/Stack.js.map +1 -0
- package/.yalc/@node-dlc/bitcoin/dist/TimeLockMode.d.ts +15 -0
- package/.yalc/@node-dlc/bitcoin/dist/TimeLockMode.js +20 -0
- package/.yalc/@node-dlc/bitcoin/dist/TimeLockMode.js.map +1 -0
- package/.yalc/@node-dlc/bitcoin/dist/Tx.d.ts +150 -0
- package/.yalc/@node-dlc/bitcoin/dist/Tx.js +408 -0
- package/.yalc/@node-dlc/bitcoin/dist/Tx.js.map +1 -0
- package/.yalc/@node-dlc/bitcoin/dist/TxBuilder.d.ts +110 -0
- package/.yalc/@node-dlc/bitcoin/dist/TxBuilder.js +238 -0
- package/.yalc/@node-dlc/bitcoin/dist/TxBuilder.js.map +1 -0
- package/.yalc/@node-dlc/bitcoin/dist/TxIn.d.ts +71 -0
- package/.yalc/@node-dlc/bitcoin/dist/TxIn.js +79 -0
- package/.yalc/@node-dlc/bitcoin/dist/TxIn.js.map +1 -0
- package/.yalc/@node-dlc/bitcoin/dist/TxOut.d.ts +57 -0
- package/.yalc/@node-dlc/bitcoin/dist/TxOut.js +68 -0
- package/.yalc/@node-dlc/bitcoin/dist/TxOut.js.map +1 -0
- package/.yalc/@node-dlc/bitcoin/dist/Value.d.ts +122 -0
- package/.yalc/@node-dlc/bitcoin/dist/Value.js +180 -0
- package/.yalc/@node-dlc/bitcoin/dist/Value.js.map +1 -0
- package/.yalc/@node-dlc/bitcoin/dist/Wif.d.ts +41 -0
- package/.yalc/@node-dlc/bitcoin/dist/Wif.js +62 -0
- package/.yalc/@node-dlc/bitcoin/dist/Wif.js.map +1 -0
- package/.yalc/@node-dlc/bitcoin/dist/Witness.d.ts +41 -0
- package/.yalc/@node-dlc/bitcoin/dist/Witness.js +63 -0
- package/.yalc/@node-dlc/bitcoin/dist/Witness.js.map +1 -0
- package/.yalc/@node-dlc/bitcoin/dist/index.d.ts +28 -0
- package/.yalc/@node-dlc/bitcoin/dist/index.js +45 -0
- package/.yalc/@node-dlc/bitcoin/dist/index.js.map +1 -0
- package/.yalc/@node-dlc/bitcoin/lib/Amount.ts +70 -0
- package/.yalc/@node-dlc/bitcoin/lib/Base58.ts +63 -0
- package/.yalc/@node-dlc/bitcoin/lib/Base58Check.ts +34 -0
- package/.yalc/@node-dlc/bitcoin/lib/BitcoinError.ts +31 -0
- package/.yalc/@node-dlc/bitcoin/lib/BitcoinErrorCode.ts +10 -0
- package/.yalc/@node-dlc/bitcoin/lib/Block.ts +20 -0
- package/.yalc/@node-dlc/bitcoin/lib/HashByteOrder.ts +21 -0
- package/.yalc/@node-dlc/bitcoin/lib/HashValue.ts +90 -0
- package/.yalc/@node-dlc/bitcoin/lib/ICloneable.ts +3 -0
- package/.yalc/@node-dlc/bitcoin/lib/LexicographicalSorters.ts +37 -0
- package/.yalc/@node-dlc/bitcoin/lib/LockTime.ts +102 -0
- package/.yalc/@node-dlc/bitcoin/lib/OpCodes.ts +119 -0
- package/.yalc/@node-dlc/bitcoin/lib/OutPoint.ts +101 -0
- package/.yalc/@node-dlc/bitcoin/lib/Script.ts +509 -0
- package/.yalc/@node-dlc/bitcoin/lib/ScriptCmd.ts +3 -0
- package/.yalc/@node-dlc/bitcoin/lib/Sequence.ts +211 -0
- package/.yalc/@node-dlc/bitcoin/lib/SigHashType.ts +19 -0
- package/.yalc/@node-dlc/bitcoin/lib/SizeResult.ts +5 -0
- package/.yalc/@node-dlc/bitcoin/lib/Sorter.ts +1 -0
- package/.yalc/@node-dlc/bitcoin/lib/Stack.ts +81 -0
- package/.yalc/@node-dlc/bitcoin/lib/TimeLockMode.ts +16 -0
- package/.yalc/@node-dlc/bitcoin/lib/Tx.ts +480 -0
- package/.yalc/@node-dlc/bitcoin/lib/TxBuilder.ts +297 -0
- package/.yalc/@node-dlc/bitcoin/lib/TxIn.ts +115 -0
- package/.yalc/@node-dlc/bitcoin/lib/TxOut.ts +87 -0
- package/.yalc/@node-dlc/bitcoin/lib/Value.ts +201 -0
- package/.yalc/@node-dlc/bitcoin/lib/Wif.ts +77 -0
- package/.yalc/@node-dlc/bitcoin/lib/Witness.ts +65 -0
- package/.yalc/@node-dlc/bitcoin/lib/index.ts +28 -0
- package/.yalc/@node-dlc/bitcoin/package.json +31 -0
- package/.yalc/@node-dlc/bitcoin/tsconfig.json +8 -0
- package/.yalc/@node-dlc/bitcoin/yalc.sig +1 -0
- package/.yalc/@node-dlc/messaging/.nyc_output/83d37f9d-cecf-4c52-a753-115ff80bbca0.json +1 -0
- package/.yalc/@node-dlc/messaging/.nyc_output/processinfo/83d37f9d-cecf-4c52-a753-115ff80bbca0.json +1 -0
- package/.yalc/@node-dlc/messaging/.nyc_output/processinfo/index.json +1 -0
- package/.yalc/@node-dlc/messaging/README.md +24 -0
- package/.yalc/@node-dlc/messaging/__tests__/_test-utils.ts +13 -0
- package/.yalc/@node-dlc/messaging/__tests__/chain/ChainManager.spec.ts +178 -0
- package/.yalc/@node-dlc/messaging/__tests__/compatibility/dlcspecs-compatibility.spec.ts +439 -0
- package/.yalc/@node-dlc/messaging/__tests__/compatibility/rust-dlc-cross-language.spec.ts +255 -0
- package/.yalc/@node-dlc/messaging/__tests__/compatibility/true-serialization-compatibility.spec.ts +342 -0
- package/.yalc/@node-dlc/messaging/__tests__/dlc_message_test.json +155 -0
- package/.yalc/@node-dlc/messaging/__tests__/irc/IrcMessage.spec.ts +94 -0
- package/.yalc/@node-dlc/messaging/__tests__/messages/AddressCache.spec.ts +79 -0
- package/.yalc/@node-dlc/messaging/__tests__/messages/BatchFundingGroup.spec.ts +72 -0
- package/.yalc/@node-dlc/messaging/__tests__/messages/CetAdaptorSignatures.spec.ts +57 -0
- package/.yalc/@node-dlc/messaging/__tests__/messages/ContractDescriptor.spec.ts +266 -0
- package/.yalc/@node-dlc/messaging/__tests__/messages/ContractInfo.spec.ts +419 -0
- package/.yalc/@node-dlc/messaging/__tests__/messages/DigitDecompositionEventDescriptor.spec.ts +59 -0
- package/.yalc/@node-dlc/messaging/__tests__/messages/DlcAccept.spec.ts +314 -0
- package/.yalc/@node-dlc/messaging/__tests__/messages/DlcCancel.spec.ts +42 -0
- package/.yalc/@node-dlc/messaging/__tests__/messages/DlcClose.spec.ts +315 -0
- package/.yalc/@node-dlc/messaging/__tests__/messages/DlcInput.spec.ts +111 -0
- package/.yalc/@node-dlc/messaging/__tests__/messages/DlcOffer.spec.ts +589 -0
- package/.yalc/@node-dlc/messaging/__tests__/messages/DlcSign.spec.ts +118 -0
- package/.yalc/@node-dlc/messaging/__tests__/messages/DlcTransactions.spec.ts +157 -0
- package/.yalc/@node-dlc/messaging/__tests__/messages/EnumEventDescriptor.spec.ts +50 -0
- package/.yalc/@node-dlc/messaging/__tests__/messages/EventDescriptor.spec.ts +93 -0
- package/.yalc/@node-dlc/messaging/__tests__/messages/FundingInput.spec.ts +169 -0
- package/.yalc/@node-dlc/messaging/__tests__/messages/FundingSignatures.spec.ts +83 -0
- package/.yalc/@node-dlc/messaging/__tests__/messages/NegotiationFields.spec.ts +328 -0
- package/.yalc/@node-dlc/messaging/__tests__/messages/NodeAnnouncementMessage.spec.ts +115 -0
- package/.yalc/@node-dlc/messaging/__tests__/messages/OracleAnnouncement.spec.ts +415 -0
- package/.yalc/@node-dlc/messaging/__tests__/messages/OracleAttestation.spec.ts +324 -0
- package/.yalc/@node-dlc/messaging/__tests__/messages/OracleEvent.spec.ts +143 -0
- package/.yalc/@node-dlc/messaging/__tests__/messages/OracleEventContainer.spec.ts +95 -0
- package/.yalc/@node-dlc/messaging/__tests__/messages/OracleIdentifier.spec.ts +48 -0
- package/.yalc/@node-dlc/messaging/__tests__/messages/OracleInfo.spec.ts +116 -0
- package/.yalc/@node-dlc/messaging/__tests__/messages/OrderAccept.spec.ts +75 -0
- package/.yalc/@node-dlc/messaging/__tests__/messages/OrderNegotiationFields.spec.ts +299 -0
- package/.yalc/@node-dlc/messaging/__tests__/messages/OrderOffer.spec.ts +121 -0
- package/.yalc/@node-dlc/messaging/__tests__/messages/OrderPositionInfo.spec.ts +75 -0
- package/.yalc/@node-dlc/messaging/__tests__/messages/PayoutCurvePiece.spec.ts +220 -0
- package/.yalc/@node-dlc/messaging/__tests__/messages/PayoutFunction.spec.ts +101 -0
- package/.yalc/@node-dlc/messaging/__tests__/messages/RoundingIntervals.spec.ts +75 -0
- package/.yalc/@node-dlc/messaging/__tests__/serialize/F64.spec.ts +261 -0
- package/.yalc/@node-dlc/messaging/__tests__/tsconfig.json +8 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/base.css +224 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/block-navigation.js +79 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/favicon.png +0 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/index.html +201 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/MessageType.ts.html +500 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/chain/ChainManager.ts.html +1061 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/chain/ChainMemoryStore.ts.html +182 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/chain/index.html +126 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/domain/Address.ts.html +272 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/domain/index.html +111 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/index.html +141 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/index.ts.html +215 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/irc/IrcMessage.ts.html +563 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/irc/index.html +111 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/AddressCache.ts.html +302 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/BatchFundingGroup.ts.html +503 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/CetAdaptorSignatures.ts.html +347 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/CetAdaptorSignaturesV0.ts.html +356 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/CloseTLV.ts.html +344 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/ContractDescriptor.ts.html +1031 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/ContractInfo.ts.html +1397 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/DlcAccept.ts.html +1997 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/DlcCancel.ts.html +251 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/DlcClose.ts.html +995 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/DlcCloseMetadata.ts.html +434 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/DlcIds.ts.html +281 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/DlcInfo.ts.html +323 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/DlcInput.ts.html +581 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/DlcMessage.ts.html +341 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/DlcOffer.ts.html +2075 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/DlcSign.ts.html +1157 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/DlcTransactions.ts.html +719 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/EventDescriptor.ts.html +962 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/FundingInput.ts.html +860 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/FundingSignatures.ts.html +374 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/FundingSignaturesV0.ts.html +344 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/NegotiationFields.ts.html +848 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/NodeAnnouncementMessage.ts.html +515 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/OracleAnnouncement.ts.html +608 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/OracleAnnouncementV0.ts.html +383 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/OracleAttestation.ts.html +956 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/OracleAttestationV0.ts.html +479 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/OracleEvent.ts.html +830 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/OracleEventContainer.ts.html +347 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/OracleEventContainerV0.ts.html +347 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/OracleEventV0.ts.html +503 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/OracleIdentifier.ts.html +314 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/OracleIdentifierV0.ts.html +314 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/OracleInfo.ts.html +1658 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/OracleInfoV0.ts.html +308 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/OrderAccept.ts.html +602 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/OrderIrcInfo.ts.html +380 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/OrderMetadata.ts.html +437 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/OrderNegotiationFields.ts.html +710 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/OrderOffer.ts.html +1334 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/OrderPositionInfo.ts.html +521 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/PayoutCurvePiece.ts.html +1442 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/PayoutFunction.ts.html +806 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/RoundingIntervals.ts.html +464 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/RoundingIntervalsV0.ts.html +428 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/ScriptWitnessV0.ts.html +269 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/messages/index.html +651 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/serialize/F64.ts.html +1091 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/serialize/deserializeTlv.ts.html +125 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/serialize/getTlv.ts.html +143 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/serialize/index.html +141 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/util.ts.html +191 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/validation/index.html +111 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/lib/validation/validate.ts.html +182 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/prettify.css +1 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/prettify.js +2 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/sort-arrow-sprite.png +0 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov-report/sorter.js +170 -0
- package/.yalc/@node-dlc/messaging/coverage/lcov.info +5617 -0
- package/.yalc/@node-dlc/messaging/dist/MessageType.d.ts +101 -0
- package/.yalc/@node-dlc/messaging/dist/MessageType.js +118 -0
- package/.yalc/@node-dlc/messaging/dist/MessageType.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/chain/ChainManager.d.ts +50 -0
- package/.yalc/@node-dlc/messaging/dist/chain/ChainManager.js +212 -0
- package/.yalc/@node-dlc/messaging/dist/chain/ChainManager.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/chain/ChainMemoryStore.d.ts +14 -0
- package/.yalc/@node-dlc/messaging/dist/chain/ChainMemoryStore.js +28 -0
- package/.yalc/@node-dlc/messaging/dist/chain/ChainMemoryStore.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/chain/DlcStore.d.ts +11 -0
- package/.yalc/@node-dlc/messaging/dist/chain/DlcStore.js +3 -0
- package/.yalc/@node-dlc/messaging/dist/chain/DlcStore.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/chain/IChainFilterChainClient.d.ts +48 -0
- package/.yalc/@node-dlc/messaging/dist/chain/IChainFilterChainClient.js +3 -0
- package/.yalc/@node-dlc/messaging/dist/chain/IChainFilterChainClient.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/domain/Address.d.ts +24 -0
- package/.yalc/@node-dlc/messaging/dist/domain/Address.js +46 -0
- package/.yalc/@node-dlc/messaging/dist/domain/Address.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/index.d.ts +45 -0
- package/.yalc/@node-dlc/messaging/dist/index.js +64 -0
- package/.yalc/@node-dlc/messaging/dist/index.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/irc/IrcMessage.d.ts +43 -0
- package/.yalc/@node-dlc/messaging/dist/irc/IrcMessage.js +116 -0
- package/.yalc/@node-dlc/messaging/dist/irc/IrcMessage.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/AddressCache.d.ts +15 -0
- package/.yalc/@node-dlc/messaging/dist/messages/AddressCache.js +51 -0
- package/.yalc/@node-dlc/messaging/dist/messages/AddressCache.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/BatchFundingGroup.d.ts +61 -0
- package/.yalc/@node-dlc/messaging/dist/messages/BatchFundingGroup.js +113 -0
- package/.yalc/@node-dlc/messaging/dist/messages/BatchFundingGroup.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/CetAdaptorSignatures.d.ts +40 -0
- package/.yalc/@node-dlc/messaging/dist/messages/CetAdaptorSignatures.js +67 -0
- package/.yalc/@node-dlc/messaging/dist/messages/CetAdaptorSignatures.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/CetAdaptorSignaturesV0.d.ts +42 -0
- package/.yalc/@node-dlc/messaging/dist/messages/CetAdaptorSignaturesV0.js +68 -0
- package/.yalc/@node-dlc/messaging/dist/messages/CetAdaptorSignaturesV0.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/CloseTLV.d.ts +38 -0
- package/.yalc/@node-dlc/messaging/dist/messages/CloseTLV.js +59 -0
- package/.yalc/@node-dlc/messaging/dist/messages/CloseTLV.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/ContractDescriptor.d.ts +121 -0
- package/.yalc/@node-dlc/messaging/dist/messages/ContractDescriptor.js +221 -0
- package/.yalc/@node-dlc/messaging/dist/messages/ContractDescriptor.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/ContractInfo.d.ts +135 -0
- package/.yalc/@node-dlc/messaging/dist/messages/ContractInfo.js +308 -0
- package/.yalc/@node-dlc/messaging/dist/messages/ContractInfo.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/DlcAccept.d.ts +160 -0
- package/.yalc/@node-dlc/messaging/dist/messages/DlcAccept.js +469 -0
- package/.yalc/@node-dlc/messaging/dist/messages/DlcAccept.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/DlcCancel.d.ts +31 -0
- package/.yalc/@node-dlc/messaging/dist/messages/DlcCancel.js +51 -0
- package/.yalc/@node-dlc/messaging/dist/messages/DlcCancel.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/DlcClose.d.ts +68 -0
- package/.yalc/@node-dlc/messaging/dist/messages/DlcClose.js +214 -0
- package/.yalc/@node-dlc/messaging/dist/messages/DlcClose.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/DlcCloseMetadata.d.ts +44 -0
- package/.yalc/@node-dlc/messaging/dist/messages/DlcCloseMetadata.js +74 -0
- package/.yalc/@node-dlc/messaging/dist/messages/DlcCloseMetadata.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/DlcIds.d.ts +26 -0
- package/.yalc/@node-dlc/messaging/dist/messages/DlcIds.js +58 -0
- package/.yalc/@node-dlc/messaging/dist/messages/DlcIds.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/DlcInfo.d.ts +31 -0
- package/.yalc/@node-dlc/messaging/dist/messages/DlcInfo.js +61 -0
- package/.yalc/@node-dlc/messaging/dist/messages/DlcInfo.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/DlcInput.d.ts +56 -0
- package/.yalc/@node-dlc/messaging/dist/messages/DlcInput.js +135 -0
- package/.yalc/@node-dlc/messaging/dist/messages/DlcInput.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/DlcMessage.d.ts +23 -0
- package/.yalc/@node-dlc/messaging/dist/messages/DlcMessage.js +54 -0
- package/.yalc/@node-dlc/messaging/dist/messages/DlcMessage.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/DlcOffer.d.ts +146 -0
- package/.yalc/@node-dlc/messaging/dist/messages/DlcOffer.js +463 -0
- package/.yalc/@node-dlc/messaging/dist/messages/DlcOffer.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/DlcSign.d.ts +96 -0
- package/.yalc/@node-dlc/messaging/dist/messages/DlcSign.js +275 -0
- package/.yalc/@node-dlc/messaging/dist/messages/DlcSign.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/DlcTransactions.d.ts +69 -0
- package/.yalc/@node-dlc/messaging/dist/messages/DlcTransactions.js +149 -0
- package/.yalc/@node-dlc/messaging/dist/messages/DlcTransactions.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/EventDescriptor.d.ts +107 -0
- package/.yalc/@node-dlc/messaging/dist/messages/EventDescriptor.js +212 -0
- package/.yalc/@node-dlc/messaging/dist/messages/EventDescriptor.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/FundingInput.d.ts +69 -0
- package/.yalc/@node-dlc/messaging/dist/messages/FundingInput.js +193 -0
- package/.yalc/@node-dlc/messaging/dist/messages/FundingInput.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/FundingSignatures.d.ts +36 -0
- package/.yalc/@node-dlc/messaging/dist/messages/FundingSignatures.js +78 -0
- package/.yalc/@node-dlc/messaging/dist/messages/FundingSignatures.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/FundingSignaturesV0.d.ts +34 -0
- package/.yalc/@node-dlc/messaging/dist/messages/FundingSignaturesV0.js +72 -0
- package/.yalc/@node-dlc/messaging/dist/messages/FundingSignaturesV0.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/IWireMessage.d.ts +6 -0
- package/.yalc/@node-dlc/messaging/dist/messages/IWireMessage.js +3 -0
- package/.yalc/@node-dlc/messaging/dist/messages/IWireMessage.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/NegotiationFields.d.ts +86 -0
- package/.yalc/@node-dlc/messaging/dist/messages/NegotiationFields.js +189 -0
- package/.yalc/@node-dlc/messaging/dist/messages/NegotiationFields.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/NodeAnnouncementMessage.d.ts +57 -0
- package/.yalc/@node-dlc/messaging/dist/messages/NodeAnnouncementMessage.js +127 -0
- package/.yalc/@node-dlc/messaging/dist/messages/NodeAnnouncementMessage.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OracleAnnouncement.d.ts +76 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OracleAnnouncement.js +131 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OracleAnnouncement.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OracleAnnouncementV0.d.ts +47 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OracleAnnouncementV0.js +76 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OracleAnnouncementV0.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OracleAttestation.d.ts +68 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OracleAttestation.js +239 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OracleAttestation.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OracleAttestationV0.d.ts +48 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OracleAttestationV0.js +100 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OracleAttestationV0.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OracleEvent.d.ts +90 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OracleEvent.js +189 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OracleEvent.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OracleEventContainer.d.ts +32 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OracleEventContainer.js +67 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OracleEventContainer.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OracleEventContainerV0.d.ts +32 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OracleEventContainerV0.js +67 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OracleEventContainerV0.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OracleEventV0.d.ts +54 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OracleEventV0.js +100 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OracleEventV0.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OracleIdentifier.d.ts +32 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OracleIdentifier.js +58 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OracleIdentifier.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OracleIdentifierV0.d.ts +32 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OracleIdentifierV0.js +58 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OracleIdentifierV0.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OracleInfo.d.ts +163 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OracleInfo.js +393 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OracleInfo.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OracleInfoV0.d.ts +35 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OracleInfoV0.js +58 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OracleInfoV0.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OrderAccept.d.ts +66 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OrderAccept.js +140 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OrderAccept.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OrderIrcInfo.d.ts +42 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OrderIrcInfo.js +74 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OrderIrcInfo.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OrderMetadata.d.ts +56 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OrderMetadata.js +87 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OrderMetadata.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OrderNegotiationFields.d.ts +81 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OrderNegotiationFields.js +161 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OrderNegotiationFields.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OrderOffer.d.ts +97 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OrderOffer.js +296 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OrderOffer.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OrderPositionInfo.d.ts +44 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OrderPositionInfo.js +111 -0
- package/.yalc/@node-dlc/messaging/dist/messages/OrderPositionInfo.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/PayoutCurvePiece.d.ts +129 -0
- package/.yalc/@node-dlc/messaging/dist/messages/PayoutCurvePiece.js +332 -0
- package/.yalc/@node-dlc/messaging/dist/messages/PayoutCurvePiece.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/PayoutFunction.d.ts +66 -0
- package/.yalc/@node-dlc/messaging/dist/messages/PayoutFunction.js +173 -0
- package/.yalc/@node-dlc/messaging/dist/messages/PayoutFunction.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/RoundingIntervals.d.ts +52 -0
- package/.yalc/@node-dlc/messaging/dist/messages/RoundingIntervals.js +96 -0
- package/.yalc/@node-dlc/messaging/dist/messages/RoundingIntervals.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/RoundingIntervalsV0.d.ts +47 -0
- package/.yalc/@node-dlc/messaging/dist/messages/RoundingIntervalsV0.js +86 -0
- package/.yalc/@node-dlc/messaging/dist/messages/RoundingIntervalsV0.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/ScriptWitnessV0.d.ts +29 -0
- package/.yalc/@node-dlc/messaging/dist/messages/ScriptWitnessV0.js +50 -0
- package/.yalc/@node-dlc/messaging/dist/messages/ScriptWitnessV0.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/messages/Tlv.d.ts +15 -0
- package/.yalc/@node-dlc/messaging/dist/messages/Tlv.js +32 -0
- package/.yalc/@node-dlc/messaging/dist/messages/Tlv.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/serialize/F64.d.ts +146 -0
- package/.yalc/@node-dlc/messaging/dist/serialize/F64.js +294 -0
- package/.yalc/@node-dlc/messaging/dist/serialize/F64.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/serialize/deserializeTlv.d.ts +9 -0
- package/.yalc/@node-dlc/messaging/dist/serialize/deserializeTlv.js +11 -0
- package/.yalc/@node-dlc/messaging/dist/serialize/deserializeTlv.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/serialize/getTlv.d.ts +4 -0
- package/.yalc/@node-dlc/messaging/dist/serialize/getTlv.js +23 -0
- package/.yalc/@node-dlc/messaging/dist/serialize/getTlv.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/serialize/readTlvs.d.ts +8 -0
- package/.yalc/@node-dlc/messaging/dist/serialize/readTlvs.js +33 -0
- package/.yalc/@node-dlc/messaging/dist/serialize/readTlvs.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/util.d.ts +13 -0
- package/.yalc/@node-dlc/messaging/dist/util.js +42 -0
- package/.yalc/@node-dlc/messaging/dist/util.js.map +1 -0
- package/.yalc/@node-dlc/messaging/dist/validation/validate.d.ts +4 -0
- package/.yalc/@node-dlc/messaging/dist/validation/validate.js +31 -0
- package/.yalc/@node-dlc/messaging/dist/validation/validate.js.map +1 -0
- package/.yalc/@node-dlc/messaging/lib/MessageType.ts +140 -0
- package/.yalc/@node-dlc/messaging/lib/chain/ChainManager.ts +327 -0
- package/.yalc/@node-dlc/messaging/lib/chain/ChainMemoryStore.ts +34 -0
- package/.yalc/@node-dlc/messaging/lib/chain/DlcStore.ts +11 -0
- package/.yalc/@node-dlc/messaging/lib/chain/IChainFilterChainClient.ts +57 -0
- package/.yalc/@node-dlc/messaging/lib/domain/Address.ts +64 -0
- package/.yalc/@node-dlc/messaging/lib/index.ts +45 -0
- package/.yalc/@node-dlc/messaging/lib/irc/IrcMessage.ts +161 -0
- package/.yalc/@node-dlc/messaging/lib/messages/AddressCache.ts +74 -0
- package/.yalc/@node-dlc/messaging/lib/messages/BatchFundingGroup.ts +141 -0
- package/.yalc/@node-dlc/messaging/lib/messages/CetAdaptorSignatures.ts +89 -0
- package/.yalc/@node-dlc/messaging/lib/messages/ContractDescriptor.ts +317 -0
- package/.yalc/@node-dlc/messaging/lib/messages/ContractInfo.ts +439 -0
- package/.yalc/@node-dlc/messaging/lib/messages/DlcAccept.ts +639 -0
- package/.yalc/@node-dlc/messaging/lib/messages/DlcCancel.ts +57 -0
- package/.yalc/@node-dlc/messaging/lib/messages/DlcClose.ts +305 -0
- package/.yalc/@node-dlc/messaging/lib/messages/DlcCloseMetadata.ts +118 -0
- package/.yalc/@node-dlc/messaging/lib/messages/DlcIds.ts +67 -0
- package/.yalc/@node-dlc/messaging/lib/messages/DlcInfo.ts +81 -0
- package/.yalc/@node-dlc/messaging/lib/messages/DlcInput.ts +167 -0
- package/.yalc/@node-dlc/messaging/lib/messages/DlcMessage.ts +87 -0
- package/.yalc/@node-dlc/messaging/lib/messages/DlcOffer.ts +665 -0
- package/.yalc/@node-dlc/messaging/lib/messages/DlcSign.ts +359 -0
- package/.yalc/@node-dlc/messaging/lib/messages/DlcTransactions.ts +213 -0
- package/.yalc/@node-dlc/messaging/lib/messages/EventDescriptor.ts +294 -0
- package/.yalc/@node-dlc/messaging/lib/messages/FundingInput.ts +260 -0
- package/.yalc/@node-dlc/messaging/lib/messages/FundingSignatures.ts +98 -0
- package/.yalc/@node-dlc/messaging/lib/messages/IWireMessage.ts +6 -0
- package/.yalc/@node-dlc/messaging/lib/messages/NegotiationFields.ts +256 -0
- package/.yalc/@node-dlc/messaging/lib/messages/NodeAnnouncementMessage.ts +145 -0
- package/.yalc/@node-dlc/messaging/lib/messages/OracleAnnouncement.ts +176 -0
- package/.yalc/@node-dlc/messaging/lib/messages/OracleAttestation.ts +292 -0
- package/.yalc/@node-dlc/messaging/lib/messages/OracleEvent.ts +250 -0
- package/.yalc/@node-dlc/messaging/lib/messages/OracleEventContainer.ts +89 -0
- package/.yalc/@node-dlc/messaging/lib/messages/OracleIdentifier.ts +78 -0
- package/.yalc/@node-dlc/messaging/lib/messages/OracleInfo.ts +526 -0
- package/.yalc/@node-dlc/messaging/lib/messages/OrderAccept.ts +174 -0
- package/.yalc/@node-dlc/messaging/lib/messages/OrderIrcInfo.ts +100 -0
- package/.yalc/@node-dlc/messaging/lib/messages/OrderMetadata.ts +119 -0
- package/.yalc/@node-dlc/messaging/lib/messages/OrderNegotiationFields.ts +210 -0
- package/.yalc/@node-dlc/messaging/lib/messages/OrderOffer.ts +418 -0
- package/.yalc/@node-dlc/messaging/lib/messages/OrderPositionInfo.ts +147 -0
- package/.yalc/@node-dlc/messaging/lib/messages/PayoutCurvePiece.ts +454 -0
- package/.yalc/@node-dlc/messaging/lib/messages/PayoutFunction.ts +242 -0
- package/.yalc/@node-dlc/messaging/lib/messages/RoundingIntervals.ts +128 -0
- package/.yalc/@node-dlc/messaging/lib/messages/ScriptWitnessV0.ts +63 -0
- package/.yalc/@node-dlc/messaging/lib/messages/Tlv.ts +40 -0
- package/.yalc/@node-dlc/messaging/lib/serialize/F64.ts +337 -0
- package/.yalc/@node-dlc/messaging/lib/serialize/deserializeTlv.ts +15 -0
- package/.yalc/@node-dlc/messaging/lib/serialize/getTlv.ts +21 -0
- package/.yalc/@node-dlc/messaging/lib/serialize/readTlvs.ts +37 -0
- package/.yalc/@node-dlc/messaging/lib/util.ts +37 -0
- package/.yalc/@node-dlc/messaging/lib/validation/validate.ts +34 -0
- package/.yalc/@node-dlc/messaging/package.json +42 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs/enum_3_of_3_test.json +212 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs/enum_3_of_5_test.json +470 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs/enum_and_numerical_3_of_5_test.json +1519 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs/enum_and_numerical_5_of_5_test.json +547 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs/enum_and_numerical_with_diff_3_of_5_test.json +4763 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs/enum_and_numerical_with_diff_5_of_5_test.json +2171 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs/enum_single_oracle_test.json +166 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs/single_oracle_numerical_hyperbola_test.json +504 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs/single_oracle_numerical_test.json +264 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs/three_of_five_oracle_numerical_with_diff_test.json +4384 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs/three_of_three_oracle_numerical_test.json +326 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs/three_of_three_oracle_numerical_with_diff_test.json +654 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs/two_of_five_oracle_numerical_test.json +1140 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs/two_of_five_oracle_numerical_with_diff_test.json +2224 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs_backup_20250718_132453/enum_3_of_3_test.json +210 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs_backup_20250718_132453/enum_3_of_5_test.json +468 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs_backup_20250718_132453/enum_and_numerical_3_of_5_test.json +1517 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs_backup_20250718_132453/enum_and_numerical_5_of_5_test.json +545 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs_backup_20250718_132453/enum_and_numerical_with_diff_3_of_5_test.json +4761 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs_backup_20250718_132453/enum_and_numerical_with_diff_5_of_5_test.json +2169 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs_backup_20250718_132453/enum_single_oracle_test.json +164 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs_backup_20250718_132453/single_oracle_numerical_hyperbola_test.json +502 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs_backup_20250718_132453/single_oracle_numerical_test.json +262 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs_backup_20250718_132453/three_of_five_oracle_numerical_with_diff_test.json +4382 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs_backup_20250718_132453/three_of_three_oracle_numerical_test.json +324 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs_backup_20250718_132453/three_of_three_oracle_numerical_with_diff_test.json +652 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs_backup_20250718_132453/two_of_five_oracle_numerical_test.json +1138 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs_backup_20250718_132453/two_of_five_oracle_numerical_with_diff_test.json +2222 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs_backup_20250719_185952/enum_3_of_3_test.json +212 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs_backup_20250719_185952/enum_3_of_5_test.json +470 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs_backup_20250719_185952/enum_and_numerical_3_of_5_test.json +1519 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs_backup_20250719_185952/enum_and_numerical_5_of_5_test.json +547 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs_backup_20250719_185952/enum_and_numerical_with_diff_3_of_5_test.json +4763 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs_backup_20250719_185952/enum_and_numerical_with_diff_5_of_5_test.json +2171 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs_backup_20250719_185952/enum_single_oracle_test.json +166 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs_backup_20250719_185952/single_oracle_numerical_hyperbola_test.json +504 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs_backup_20250719_185952/single_oracle_numerical_test.json +264 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs_backup_20250719_185952/three_of_five_oracle_numerical_with_diff_test.json +4384 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs_backup_20250719_185952/three_of_three_oracle_numerical_test.json +326 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs_backup_20250719_185952/three_of_three_oracle_numerical_with_diff_test.json +654 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs_backup_20250719_185952/two_of_five_oracle_numerical_test.json +1140 -0
- package/.yalc/@node-dlc/messaging/test_vectors/dlcspecs_backup_20250719_185952/two_of_five_oracle_numerical_with_diff_test.json +2224 -0
- package/.yalc/@node-dlc/messaging/test_vectors/oracle/external_oracle_announcements.json +0 -0
- package/.yalc/@node-dlc/messaging/test_vectors/oracle/oracle_message_test_vectors.json +115 -0
- package/.yalc/@node-dlc/messaging/test_vectors/rust-dlc/accept_msg.json +1465 -0
- package/.yalc/@node-dlc/messaging/test_vectors/rust-dlc/dlc_fee_test.json +12362 -0
- package/.yalc/@node-dlc/messaging/test_vectors/rust-dlc/dlc_fee_test_scripts.json +57 -0
- package/.yalc/@node-dlc/messaging/test_vectors/rust-dlc/dlc_test.json +2766 -0
- package/.yalc/@node-dlc/messaging/test_vectors/rust-dlc/dlc_tx_test.json +2899 -0
- package/.yalc/@node-dlc/messaging/test_vectors/rust-dlc/offer_msg.json +163 -0
- package/.yalc/@node-dlc/messaging/test_vectors/rust-dlc/offer_msg_disjoint.json +352 -0
- package/.yalc/@node-dlc/messaging/test_vectors/rust-dlc/segment_chunk_msg.json +12635 -0
- package/.yalc/@node-dlc/messaging/test_vectors/rust-dlc/segment_start_msg.json +4022 -0
- package/.yalc/@node-dlc/messaging/test_vectors/rust-dlc/sign_msg.json +383 -0
- package/.yalc/@node-dlc/messaging/tsconfig.json +7 -0
- package/.yalc/@node-dlc/messaging/yalc.sig +1 -0
- package/.yalc/@node-dlc/noise/.eslintrc +6 -0
- package/.yalc/@node-dlc/noise/.nyc_output/cce169d2-1730-4a39-9e05-4edcd8b14961.json +1 -0
- package/.yalc/@node-dlc/noise/.nyc_output/processinfo/cce169d2-1730-4a39-9e05-4edcd8b14961.json +1 -0
- package/.yalc/@node-dlc/noise/.nyc_output/processinfo/index.json +1 -0
- package/.yalc/@node-dlc/noise/README.md +165 -0
- package/.yalc/@node-dlc/noise/__integration__/ping-pong.spec.ts +85 -0
- package/.yalc/@node-dlc/noise/__tests__/noise-server.spec.ts +82 -0
- package/.yalc/@node-dlc/noise/__tests__/noise-socket.spec.ts +574 -0
- package/.yalc/@node-dlc/noise/__tests__/noise-state.spec.ts +485 -0
- package/.yalc/@node-dlc/noise/coverage/lcov-report/base.css +224 -0
- package/.yalc/@node-dlc/noise/coverage/lcov-report/block-navigation.js +79 -0
- package/.yalc/@node-dlc/noise/coverage/lcov-report/favicon.png +0 -0
- package/.yalc/@node-dlc/noise/coverage/lcov-report/handshake-state.ts.html +230 -0
- package/.yalc/@node-dlc/noise/coverage/lcov-report/index.html +201 -0
- package/.yalc/@node-dlc/noise/coverage/lcov-report/index.ts.html +344 -0
- package/.yalc/@node-dlc/noise/coverage/lcov-report/noise-error.ts.html +89 -0
- package/.yalc/@node-dlc/noise/coverage/lcov-report/noise-server.ts.html +485 -0
- package/.yalc/@node-dlc/noise/coverage/lcov-report/noise-socket.ts.html +1223 -0
- package/.yalc/@node-dlc/noise/coverage/lcov-report/noise-state.ts.html +1523 -0
- package/.yalc/@node-dlc/noise/coverage/lcov-report/prettify.css +1 -0
- package/.yalc/@node-dlc/noise/coverage/lcov-report/prettify.js +2 -0
- package/.yalc/@node-dlc/noise/coverage/lcov-report/read-state.ts.html +95 -0
- package/.yalc/@node-dlc/noise/coverage/lcov-report/sort-arrow-sprite.png +0 -0
- package/.yalc/@node-dlc/noise/coverage/lcov-report/sorter.js +170 -0
- package/.yalc/@node-dlc/noise/coverage/lcov.info +565 -0
- package/.yalc/@node-dlc/noise/dist/handshake-state.d.ts +46 -0
- package/.yalc/@node-dlc/noise/dist/handshake-state.js +51 -0
- package/.yalc/@node-dlc/noise/dist/handshake-state.js.map +1 -0
- package/.yalc/@node-dlc/noise/dist/index.d.ts +46 -0
- package/.yalc/@node-dlc/noise/dist/index.js +69 -0
- package/.yalc/@node-dlc/noise/dist/index.js.map +1 -0
- package/.yalc/@node-dlc/noise/dist/noise-error.d.ts +3 -0
- package/.yalc/@node-dlc/noise/dist/noise-error.js +11 -0
- package/.yalc/@node-dlc/noise/dist/noise-error.js.map +1 -0
- package/.yalc/@node-dlc/noise/dist/noise-server-listen-options.d.ts +23 -0
- package/.yalc/@node-dlc/noise/dist/noise-server-listen-options.js +3 -0
- package/.yalc/@node-dlc/noise/dist/noise-server-listen-options.js.map +1 -0
- package/.yalc/@node-dlc/noise/dist/noise-server-options.d.ts +13 -0
- package/.yalc/@node-dlc/noise/dist/noise-server-options.js +3 -0
- package/.yalc/@node-dlc/noise/dist/noise-server-options.js.map +1 -0
- package/.yalc/@node-dlc/noise/dist/noise-server.d.ts +71 -0
- package/.yalc/@node-dlc/noise/dist/noise-server.js +125 -0
- package/.yalc/@node-dlc/noise/dist/noise-server.js.map +1 -0
- package/.yalc/@node-dlc/noise/dist/noise-socket-options.d.ts +28 -0
- package/.yalc/@node-dlc/noise/dist/noise-socket-options.js +3 -0
- package/.yalc/@node-dlc/noise/dist/noise-socket-options.js.map +1 -0
- package/.yalc/@node-dlc/noise/dist/noise-socket.d.ts +98 -0
- package/.yalc/@node-dlc/noise/dist/noise-socket.js +278 -0
- package/.yalc/@node-dlc/noise/dist/noise-socket.js.map +1 -0
- package/.yalc/@node-dlc/noise/dist/noise-state-options.d.ts +16 -0
- package/.yalc/@node-dlc/noise/dist/noise-state-options.js +3 -0
- package/.yalc/@node-dlc/noise/dist/noise-state-options.js.map +1 -0
- package/.yalc/@node-dlc/noise/dist/noise-state.d.ts +164 -0
- package/.yalc/@node-dlc/noise/dist/noise-state.js +304 -0
- package/.yalc/@node-dlc/noise/dist/noise-state.js.map +1 -0
- package/.yalc/@node-dlc/noise/dist/read-state.d.ts +5 -0
- package/.yalc/@node-dlc/noise/dist/read-state.js +10 -0
- package/.yalc/@node-dlc/noise/dist/read-state.js.map +1 -0
- package/.yalc/@node-dlc/noise/lib/handshake-state.ts +50 -0
- package/.yalc/@node-dlc/noise/lib/index.ts +88 -0
- package/.yalc/@node-dlc/noise/lib/noise-error.ts +3 -0
- package/.yalc/@node-dlc/noise/lib/noise-server-listen-options.ts +25 -0
- package/.yalc/@node-dlc/noise/lib/noise-server-options.ts +13 -0
- package/.yalc/@node-dlc/noise/lib/noise-server.ts +135 -0
- package/.yalc/@node-dlc/noise/lib/noise-socket-options.ts +32 -0
- package/.yalc/@node-dlc/noise/lib/noise-socket.ts +381 -0
- package/.yalc/@node-dlc/noise/lib/noise-state-options.ts +18 -0
- package/.yalc/@node-dlc/noise/lib/noise-state.ts +481 -0
- package/.yalc/@node-dlc/noise/lib/read-state.ts +5 -0
- package/.yalc/@node-dlc/noise/package.json +35 -0
- package/.yalc/@node-dlc/noise/tsconfig-build.json +7 -0
- package/.yalc/@node-dlc/noise/tsconfig.json +4 -0
- package/.yalc/@node-dlc/noise/yalc.sig +1 -0
- package/CHANGELOG.md +6 -0
- package/dist/ddk.d.ts +4 -4
- package/dist/dlc.d.ts +2 -1
- package/dist/dlc.js +2 -0
- package/dist/dlc.js.map +1 -1
- package/dist/network-utils.d.ts +10 -0
- package/dist/network-utils.js +34 -0
- package/dist/network-utils.js.map +1 -0
- package/lib/ddk.ts +4 -0
- package/lib/dlc.ts +3 -0
- package/package.json +1 -1
- package/yalc.lock +20 -0
|
@@ -0,0 +1,304 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.NoiseState = void 0;
|
|
4
|
+
const crypto_1 = require("@node-dlc/crypto");
|
|
5
|
+
const crypto_2 = require("@node-dlc/crypto");
|
|
6
|
+
class NoiseState {
|
|
7
|
+
/**
|
|
8
|
+
* State machine for perforing noise-protocol handshake, message
|
|
9
|
+
* encryption and decryption, and key rotation.
|
|
10
|
+
*/
|
|
11
|
+
constructor({ ls, es, logger }) {
|
|
12
|
+
/**
|
|
13
|
+
* The official protocol name for the Lightning variant of Noise. This
|
|
14
|
+
* value is mixed into the iniitialiization function to start the
|
|
15
|
+
* handshake.
|
|
16
|
+
*/
|
|
17
|
+
this.protocolName = Buffer.from('Noise_XK_secp256k1_ChaChaPoly_SHA256');
|
|
18
|
+
/**
|
|
19
|
+
* Appended to the hash of the protocolName during initialization.
|
|
20
|
+
*/
|
|
21
|
+
this.prologue = Buffer.from('lightning');
|
|
22
|
+
this.logger = logger;
|
|
23
|
+
this.ls = ls;
|
|
24
|
+
this.lpk = (0, crypto_2.getPublicKey)(ls);
|
|
25
|
+
this.es = es;
|
|
26
|
+
this.epk = (0, crypto_2.getPublicKey)(es);
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Initiator Act1 is the starting point for the authenticated key exchange
|
|
30
|
+
* handshake. The initiator attempts to satisfy an implicit challenge by the
|
|
31
|
+
* responder: knowledge of the static public key of the responder. It also
|
|
32
|
+
* transmits the initiators ephemeral key.
|
|
33
|
+
* @param rpk remote public key
|
|
34
|
+
* @return Buffer that is 50 bytes
|
|
35
|
+
*/
|
|
36
|
+
initiatorAct1(rpk) {
|
|
37
|
+
if (this.logger)
|
|
38
|
+
this.logger.debug('initiator act1');
|
|
39
|
+
this.rpk = rpk;
|
|
40
|
+
this._initialize(this.rpk);
|
|
41
|
+
// 2. h = SHA-256(h || epk)
|
|
42
|
+
this.h = (0, crypto_1.sha256)(Buffer.concat([this.h, this.epk]));
|
|
43
|
+
// 3. es = ECDH(e.priv, rs)
|
|
44
|
+
const ss = (0, crypto_1.ecdh)(this.rpk, this.es);
|
|
45
|
+
// 4. ck, temp_k1 = HKDF(ck, es)
|
|
46
|
+
const tempK1 = (0, crypto_1.hkdf)(ss, 64, this.ck);
|
|
47
|
+
this.ck = tempK1.slice(0, 32);
|
|
48
|
+
this.tempK1 = tempK1.slice(32);
|
|
49
|
+
// 5. c = encryptWithAD(temp_k1, 0, h, zero)
|
|
50
|
+
const c = (0, crypto_1.ccpEncrypt)(this.tempK1, Buffer.alloc(12), this.h, Buffer.alloc(0));
|
|
51
|
+
// 6. h = SHA-256(h || c)
|
|
52
|
+
this.h = (0, crypto_1.sha256)(Buffer.concat([this.h, c]));
|
|
53
|
+
// 7. m = 0 || epk || c
|
|
54
|
+
const m = Buffer.concat([Buffer.alloc(1), this.epk, c]);
|
|
55
|
+
return m;
|
|
56
|
+
}
|
|
57
|
+
/**
|
|
58
|
+
* Initiator Act2 handles the response generated by the receiver's
|
|
59
|
+
* Act1, a 50-byte message. The responder's ephemeral key is extacted
|
|
60
|
+
* from the message during this phase.
|
|
61
|
+
*
|
|
62
|
+
* @param m 50-byte message from responder's act1
|
|
63
|
+
*/
|
|
64
|
+
initiatorAct2(m) {
|
|
65
|
+
if (this.logger)
|
|
66
|
+
this.logger.debug('initiator act2');
|
|
67
|
+
// 1. read exactly 50 bytes off the stream
|
|
68
|
+
if (m.length !== 50)
|
|
69
|
+
throw new Error('ACT2_READ_FAILED');
|
|
70
|
+
// 2. parse th read message m into v, re, and c
|
|
71
|
+
const v = m.slice(0, 1)[0];
|
|
72
|
+
const re = m.slice(1, 34);
|
|
73
|
+
const c = m.slice(34);
|
|
74
|
+
// 2a. convert re to public key
|
|
75
|
+
this.repk = re;
|
|
76
|
+
// 3. assert version is known version
|
|
77
|
+
if (v !== 0)
|
|
78
|
+
throw new Error('ACT2_BAD_VERSION');
|
|
79
|
+
// 4. sha256(h || re.serializedCompressed');
|
|
80
|
+
this.h = (0, crypto_1.sha256)(Buffer.concat([this.h, this.repk]));
|
|
81
|
+
// 5. ss = ECDH(re, e.priv);
|
|
82
|
+
const ss = (0, crypto_1.ecdh)(this.repk, this.es);
|
|
83
|
+
// 6. ck, temp_k2 = HKDF(cd, ss)
|
|
84
|
+
const tempK2 = (0, crypto_1.hkdf)(ss, 64, this.ck);
|
|
85
|
+
this.ck = tempK2.slice(0, 32);
|
|
86
|
+
this.tempK2 = tempK2.slice(32);
|
|
87
|
+
// 7. p = decryptWithAD()
|
|
88
|
+
(0, crypto_1.ccpDecrypt)(this.tempK2, Buffer.alloc(12), this.h, c);
|
|
89
|
+
// 8. h = sha256(h || c)
|
|
90
|
+
this.h = (0, crypto_1.sha256)(Buffer.concat([this.h, c]));
|
|
91
|
+
}
|
|
92
|
+
/**
|
|
93
|
+
* Initiator Act3 is the final phase in the authenticated
|
|
94
|
+
* key agreement. This act is executed only if act 2
|
|
95
|
+
* was successful. The initiator transports its static public key
|
|
96
|
+
* to the responder.
|
|
97
|
+
*/
|
|
98
|
+
initiatorAct3() {
|
|
99
|
+
if (this.logger)
|
|
100
|
+
this.logger.debug('initiator act3');
|
|
101
|
+
// 1. c = encryptWithAD(temp_k2, 1, h, lpk)
|
|
102
|
+
const c = (0, crypto_1.ccpEncrypt)(this.tempK2, Buffer.from([0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0]), this.h, this.lpk);
|
|
103
|
+
// 2. h = sha256(h || c)
|
|
104
|
+
this.h = (0, crypto_1.sha256)(Buffer.concat([this.h, c]));
|
|
105
|
+
// 3. ss = ECDH(re, s.priv)
|
|
106
|
+
const ss = (0, crypto_1.ecdh)(this.repk, this.ls);
|
|
107
|
+
// 4. ck, temp_k3 = HKDF(ck, ss)
|
|
108
|
+
const tempK3 = (0, crypto_1.hkdf)(ss, 64, this.ck);
|
|
109
|
+
this.ck = tempK3.slice(0, 32);
|
|
110
|
+
this.tempK3 = tempK3.slice(32);
|
|
111
|
+
// 5. t = encryptWithAD(temp_k3, 0, h, zero)
|
|
112
|
+
const t = (0, crypto_1.ccpEncrypt)(this.tempK3, Buffer.alloc(12), this.h, Buffer.alloc(0));
|
|
113
|
+
// 6. sk, rk = hkdf(ck, zero)
|
|
114
|
+
const sk = (0, crypto_1.hkdf)(Buffer.alloc(0), 64, this.ck);
|
|
115
|
+
this.rk = sk.slice(32);
|
|
116
|
+
this.sk = sk.slice(0, 32);
|
|
117
|
+
// 7. rn = 0, sn = 0
|
|
118
|
+
this.sn = Buffer.alloc(12);
|
|
119
|
+
this.rn = Buffer.alloc(12);
|
|
120
|
+
// 8. send m = 0 || c || t
|
|
121
|
+
const m = Buffer.concat([Buffer.alloc(1), c, t]);
|
|
122
|
+
return m;
|
|
123
|
+
}
|
|
124
|
+
/**
|
|
125
|
+
* Receiver Act1 extracts the initiators ephemeral key. It also
|
|
126
|
+
* validates that the initiator knows the receivers public key.
|
|
127
|
+
* @param m 50-byte message sent by the initiator
|
|
128
|
+
*/
|
|
129
|
+
receiveAct1(m) {
|
|
130
|
+
this._initialize(this.lpk);
|
|
131
|
+
if (this.logger)
|
|
132
|
+
this.logger.debug('receive act1');
|
|
133
|
+
// 1. read exactly 50 bytes off the stream
|
|
134
|
+
if (m.length !== 50)
|
|
135
|
+
throw new Error('ACT1_READ_FAILED');
|
|
136
|
+
// 2. parse th read message m into v,re, and c
|
|
137
|
+
const v = m.slice(0, 1)[0];
|
|
138
|
+
const re = m.slice(1, 34);
|
|
139
|
+
const c = m.slice(34);
|
|
140
|
+
this.repk = re;
|
|
141
|
+
// 3. assert version is known version
|
|
142
|
+
if (v !== 0)
|
|
143
|
+
throw new Error('ACT1_BAD_VERSION');
|
|
144
|
+
// 4. sha256(h || re.serializedCompressed');
|
|
145
|
+
this.h = (0, crypto_1.sha256)(Buffer.concat([this.h, re]));
|
|
146
|
+
// 5. ss = ECDH(re, ls.priv);
|
|
147
|
+
const ss = (0, crypto_1.ecdh)(re, this.ls);
|
|
148
|
+
// 6. ck, temp_k1 = HKDF(cd, ss)
|
|
149
|
+
const tempK1 = (0, crypto_1.hkdf)(ss, 64, this.ck);
|
|
150
|
+
this.ck = tempK1.slice(0, 32);
|
|
151
|
+
this.tempK1 = tempK1.slice(32);
|
|
152
|
+
// 7. p = decryptWithAD(temp_k1, 0, h, c)
|
|
153
|
+
(0, crypto_1.ccpDecrypt)(this.tempK1, Buffer.alloc(12), this.h, c);
|
|
154
|
+
// 8. h = sha256(h || c)
|
|
155
|
+
this.h = (0, crypto_1.sha256)(Buffer.concat([this.h, c]));
|
|
156
|
+
}
|
|
157
|
+
/**
|
|
158
|
+
* Receiver Act2 takes place only if Act1 was successful.
|
|
159
|
+
* This act sends responder's ephermeral key to the initiator.
|
|
160
|
+
*/
|
|
161
|
+
recieveAct2() {
|
|
162
|
+
// 1. e = generateKey() => done in initialization
|
|
163
|
+
// 2. h = sha256(h || e.pub.compressed())
|
|
164
|
+
this.h = (0, crypto_1.sha256)(Buffer.concat([this.h, this.epk]));
|
|
165
|
+
// 3. ss = ecdh(re, e.priv)
|
|
166
|
+
const ss = (0, crypto_1.ecdh)(this.repk, this.es);
|
|
167
|
+
// 4. ck, temp_k2 = hkdf(ck, ss)
|
|
168
|
+
const tempK2 = (0, crypto_1.hkdf)(ss, 64, this.ck);
|
|
169
|
+
this.ck = tempK2.slice(0, 32);
|
|
170
|
+
this.tempK2 = tempK2.slice(32);
|
|
171
|
+
// 5. c = encryptWithAd(temp_k2, 0, h, zero)
|
|
172
|
+
const c = (0, crypto_1.ccpEncrypt)(this.tempK2, Buffer.alloc(12), this.h, Buffer.alloc(0));
|
|
173
|
+
// 6. h = sha256(h || c)
|
|
174
|
+
this.h = (0, crypto_1.sha256)(Buffer.concat([this.h, c]));
|
|
175
|
+
// 7. m = 0 || e.pub.compressed() Z|| c
|
|
176
|
+
const m = Buffer.concat([Buffer.alloc(1), this.epk, c]);
|
|
177
|
+
return m;
|
|
178
|
+
}
|
|
179
|
+
/**
|
|
180
|
+
* Receiver Act3 is the final phase in the authenticated key
|
|
181
|
+
* agreement. This act is executed only if act 2 was successful.
|
|
182
|
+
* The receiver extracts the public key of the initiator.
|
|
183
|
+
* @param m 66-byte message
|
|
184
|
+
*/
|
|
185
|
+
receiveAct3(m) {
|
|
186
|
+
// 1. read exactly 66 bytes from the network buffer
|
|
187
|
+
if (m.length !== 66)
|
|
188
|
+
throw new Error('ACT3_READ_FAILED');
|
|
189
|
+
// 2. parse m into v, c, t
|
|
190
|
+
const v = m.slice(0, 1)[0];
|
|
191
|
+
const c = m.slice(1, 50);
|
|
192
|
+
const t = m.slice(50);
|
|
193
|
+
// 3. validate v is recognized
|
|
194
|
+
if (v !== 0)
|
|
195
|
+
throw new Error('ACT3_BAD_VERSION');
|
|
196
|
+
// 4. rs = decryptWithAD(temp_k2, 1, h, c)
|
|
197
|
+
const rs = (0, crypto_1.ccpDecrypt)(this.tempK2, Buffer.from('000000000100000000000000', 'hex'), this.h, c);
|
|
198
|
+
this.rpk = rs;
|
|
199
|
+
// 5. h = sha256(h || c)
|
|
200
|
+
this.h = (0, crypto_1.sha256)(Buffer.concat([this.h, c]));
|
|
201
|
+
// 6. ss = ECDH(rs, e.priv)
|
|
202
|
+
const ss = (0, crypto_1.ecdh)(this.rpk, this.es);
|
|
203
|
+
// 7. ck, temp_k3 = hkdf(cs, ss)
|
|
204
|
+
const tempK3 = (0, crypto_1.hkdf)(ss, 64, this.ck);
|
|
205
|
+
this.ck = tempK3.slice(0, 32);
|
|
206
|
+
this.tempK3 = tempK3.slice(32);
|
|
207
|
+
// 8. p = decryptWithAD(temp_k3, 0, h, t)
|
|
208
|
+
(0, crypto_1.ccpDecrypt)(this.tempK3, Buffer.alloc(12), this.h, t);
|
|
209
|
+
// 9. rk, sk = hkdf(ck, zero)
|
|
210
|
+
const sk = (0, crypto_1.hkdf)(Buffer.alloc(0), 64, this.ck);
|
|
211
|
+
this.rk = sk.slice(0, 32);
|
|
212
|
+
this.sk = sk.slice(32);
|
|
213
|
+
// 10. rn = 0, sn = 0
|
|
214
|
+
this.rn = Buffer.alloc(12);
|
|
215
|
+
this.sn = Buffer.alloc(12);
|
|
216
|
+
}
|
|
217
|
+
/**
|
|
218
|
+
* Sends an encrypted message using the shared sending key and nonce.
|
|
219
|
+
* The nonce is rotated once the message is sent. The sending key is
|
|
220
|
+
* rotated every 1000 messages.
|
|
221
|
+
* @param m
|
|
222
|
+
*/
|
|
223
|
+
encryptMessage(m) {
|
|
224
|
+
// step 1/2. serialize m length into int16
|
|
225
|
+
const l = Buffer.alloc(2);
|
|
226
|
+
l.writeUInt16BE(m.length, 0);
|
|
227
|
+
// step 3. encrypt l, using chachapoly1305, sn, sk)
|
|
228
|
+
const lc = (0, crypto_1.ccpEncrypt)(this.sk, this.sn, Buffer.alloc(0), l);
|
|
229
|
+
// step 3a: increment sn
|
|
230
|
+
if (this._incrementSendingNonce() >= 1000)
|
|
231
|
+
this._rotateSendingKeys();
|
|
232
|
+
// step 4 encrypt m using chachapoly1305, sn, sk
|
|
233
|
+
const c = (0, crypto_1.ccpEncrypt)(this.sk, this.sn, Buffer.alloc(0), m);
|
|
234
|
+
// step 4a: increment sn
|
|
235
|
+
if (this._incrementSendingNonce() >= 1000)
|
|
236
|
+
this._rotateSendingKeys();
|
|
237
|
+
// step 5 return m to be sent
|
|
238
|
+
return Buffer.concat([lc, c]);
|
|
239
|
+
}
|
|
240
|
+
/**
|
|
241
|
+
* Decrypts the length of the message using the receiving key and nonce.
|
|
242
|
+
* The receiving key is rotated every 1000 messages.
|
|
243
|
+
*/
|
|
244
|
+
decryptLength(lc) {
|
|
245
|
+
const l = (0, crypto_1.ccpDecrypt)(this.rk, this.rn, Buffer.alloc(0), lc);
|
|
246
|
+
if (this._incrementRecievingNonce() >= 1000)
|
|
247
|
+
this._rotateRecievingKeys();
|
|
248
|
+
return l.readUInt16BE(0);
|
|
249
|
+
}
|
|
250
|
+
/**
|
|
251
|
+
* Decrypts the message using the receiving key and nonce. The receiving
|
|
252
|
+
* key is rotated every 1000 messages.
|
|
253
|
+
*/
|
|
254
|
+
decryptMessage(c) {
|
|
255
|
+
const m = (0, crypto_1.ccpDecrypt)(this.rk, this.rn, Buffer.alloc(0), c);
|
|
256
|
+
if (this._incrementRecievingNonce() >= 1000)
|
|
257
|
+
this._rotateRecievingKeys();
|
|
258
|
+
return m;
|
|
259
|
+
}
|
|
260
|
+
/////////////////////////////////////
|
|
261
|
+
/**
|
|
262
|
+
* Initializes the noise state prior to Act1.
|
|
263
|
+
*/
|
|
264
|
+
_initialize(pubkey) {
|
|
265
|
+
if (this.logger)
|
|
266
|
+
this.logger.debug('initialize noise state');
|
|
267
|
+
// 1. h = SHA-256(protocolName)
|
|
268
|
+
this.h = (0, crypto_1.sha256)(Buffer.from(this.protocolName));
|
|
269
|
+
// 2. ck = h
|
|
270
|
+
this.ck = this.h;
|
|
271
|
+
// 3. h = SHA-256(h || prologue)
|
|
272
|
+
this.h = (0, crypto_1.sha256)(Buffer.concat([this.h, this.prologue]));
|
|
273
|
+
// 4. h = SHA-256(h || pubkey)
|
|
274
|
+
this.h = (0, crypto_1.sha256)(Buffer.concat([this.h, pubkey]));
|
|
275
|
+
}
|
|
276
|
+
_incrementSendingNonce() {
|
|
277
|
+
const newValue = this.sn.readUInt16LE(4) + 1;
|
|
278
|
+
this.sn.writeUInt16LE(newValue, 4);
|
|
279
|
+
return newValue;
|
|
280
|
+
}
|
|
281
|
+
_incrementRecievingNonce() {
|
|
282
|
+
const newValue = this.rn.readUInt16LE(4) + 1;
|
|
283
|
+
this.rn.writeUInt16LE(newValue, 4);
|
|
284
|
+
return newValue;
|
|
285
|
+
}
|
|
286
|
+
_rotateSendingKeys() {
|
|
287
|
+
if (this.logger)
|
|
288
|
+
this.logger.debug('rotating sending key');
|
|
289
|
+
const result = (0, crypto_1.hkdf)(this.sk, 64, this.ck);
|
|
290
|
+
this.sk = result.slice(32);
|
|
291
|
+
this.ck = result.slice(0, 32);
|
|
292
|
+
this.sn = Buffer.alloc(12);
|
|
293
|
+
}
|
|
294
|
+
_rotateRecievingKeys() {
|
|
295
|
+
if (this.logger)
|
|
296
|
+
this.logger.debug('rotating receiving key');
|
|
297
|
+
const result = (0, crypto_1.hkdf)(this.rk, 64, this.ck);
|
|
298
|
+
this.rk = result.slice(32);
|
|
299
|
+
this.ck = result.slice(0, 32);
|
|
300
|
+
this.rn = Buffer.alloc(12);
|
|
301
|
+
}
|
|
302
|
+
}
|
|
303
|
+
exports.NoiseState = NoiseState;
|
|
304
|
+
//# sourceMappingURL=noise-state.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"noise-state.js","sourceRoot":"","sources":["../lib/noise-state.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.READ_STATE = void 0;
|
|
4
|
+
var READ_STATE;
|
|
5
|
+
(function (READ_STATE) {
|
|
6
|
+
READ_STATE[READ_STATE["READY_FOR_LEN"] = 2] = "READY_FOR_LEN";
|
|
7
|
+
READ_STATE[READ_STATE["READY_FOR_BODY"] = 3] = "READY_FOR_BODY";
|
|
8
|
+
READ_STATE[READ_STATE["BLOCKED"] = 4] = "BLOCKED";
|
|
9
|
+
})(READ_STATE = exports.READ_STATE || (exports.READ_STATE = {}));
|
|
10
|
+
//# sourceMappingURL=read-state.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"read-state.js","sourceRoot":"","sources":["../lib/read-state.ts"],"names":[],"mappings":";;;AAAA,IAAY,UAIX;AAJD,WAAY,UAAU;IACpB,6DAAiB,CAAA;IACjB,+DAAkB,CAAA;IAClB,iDAAW,CAAA;AACb,CAAC,EAJW,UAAU,GAAV,kBAAU,KAAV,kBAAU,QAIrB"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* States that the handshake process can be in. States depend on
|
|
3
|
+
* whether the socket is the connection Initiator or Responder.
|
|
4
|
+
*
|
|
5
|
+
* Initiator:
|
|
6
|
+
* 1. create and send Iniatitor act1 and transition to
|
|
7
|
+
* AWAITING_RESPONDER_REPLY
|
|
8
|
+
* 2. process the Responder's reply as act2
|
|
9
|
+
* 3. create Initiator act3 reply to complete the handshake
|
|
10
|
+
* and transitions to READY
|
|
11
|
+
*
|
|
12
|
+
* Responder:
|
|
13
|
+
* 1. begins in AWAITING_INITIATOR waiting to receive act1
|
|
14
|
+
* 2. processes act1 and creates a reply as act2 and transitions
|
|
15
|
+
* to AWAITING_INITIATOR_REPLY
|
|
16
|
+
* 3. processes the Initiator's reply to complete the handshake
|
|
17
|
+
* and transition to READY
|
|
18
|
+
*/
|
|
19
|
+
export enum HANDSHAKE_STATE {
|
|
20
|
+
/**
|
|
21
|
+
* Initial state for the Initiator. Initiator will transition to
|
|
22
|
+
* AWAITING_RESPONDER_REPLY once act1 is completed and sent.
|
|
23
|
+
*/
|
|
24
|
+
INITIATOR_INITIATING = 0,
|
|
25
|
+
|
|
26
|
+
/**
|
|
27
|
+
* Responders begin in this state and wait for the Intiator to begin
|
|
28
|
+
* the handshake. Sockets originating from the NoiseServer will
|
|
29
|
+
* begin in this state.
|
|
30
|
+
*/
|
|
31
|
+
AWAITING_INITIATOR = 1,
|
|
32
|
+
|
|
33
|
+
/**
|
|
34
|
+
* Initiator has sent act1 and is awaiting the reply from the responder.
|
|
35
|
+
* Once received, the intiator will create the reply
|
|
36
|
+
*/
|
|
37
|
+
AWAITING_RESPONDER_REPLY = 2,
|
|
38
|
+
|
|
39
|
+
/**
|
|
40
|
+
* Responder has sent a reply to the inititator, the Responder will be
|
|
41
|
+
* waiting for the final stage of the handshake sent by the Initiator.
|
|
42
|
+
*/
|
|
43
|
+
AWAITING_INITIATOR_REPLY = 3,
|
|
44
|
+
|
|
45
|
+
/**
|
|
46
|
+
* Responder/Initiator have completed the handshake and we're ready to
|
|
47
|
+
* start sending and receiving over the socket.
|
|
48
|
+
*/
|
|
49
|
+
READY = 100,
|
|
50
|
+
}
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
import * as crypto from '@node-dlc/crypto';
|
|
2
|
+
import { ILogger } from '@node-dlc/logger';
|
|
3
|
+
import { Socket } from 'net';
|
|
4
|
+
|
|
5
|
+
import { NoiseServer } from './noise-server';
|
|
6
|
+
import { NoiseServerOptions } from './noise-server-options';
|
|
7
|
+
import { NoiseSocket } from './noise-socket';
|
|
8
|
+
import { NoiseState } from './noise-state';
|
|
9
|
+
|
|
10
|
+
export { NoiseError } from './noise-error';
|
|
11
|
+
export { NoiseServer } from './noise-server';
|
|
12
|
+
export { NoiseServerListenOptions } from './noise-server-listen-options';
|
|
13
|
+
export { NoiseServerOptions } from './noise-server-options';
|
|
14
|
+
export { NoiseSocket } from './noise-socket';
|
|
15
|
+
export { NoiseSocketOptions } from './noise-socket-options';
|
|
16
|
+
export { NoiseState } from './noise-state';
|
|
17
|
+
|
|
18
|
+
export type NoiseConnectOptions = {
|
|
19
|
+
/**
|
|
20
|
+
* Local secret as a 32-byte secp256k1 private key
|
|
21
|
+
*/
|
|
22
|
+
ls: Buffer;
|
|
23
|
+
|
|
24
|
+
/**
|
|
25
|
+
* Optional ephemeral 32-byte secp256k1 private key. If not provided, one is generated.
|
|
26
|
+
*/
|
|
27
|
+
es?: Buffer;
|
|
28
|
+
|
|
29
|
+
/**
|
|
30
|
+
* remote compressed public key, 33-bytes.
|
|
31
|
+
*/
|
|
32
|
+
rpk: Buffer;
|
|
33
|
+
|
|
34
|
+
/**
|
|
35
|
+
* Optional host. Defaults to localhost.
|
|
36
|
+
*/
|
|
37
|
+
host?: string;
|
|
38
|
+
|
|
39
|
+
/**
|
|
40
|
+
* Optional port. Defaults to 9735.
|
|
41
|
+
*/
|
|
42
|
+
port?: number;
|
|
43
|
+
|
|
44
|
+
/**
|
|
45
|
+
* Optional logger
|
|
46
|
+
*/
|
|
47
|
+
logger?: ILogger;
|
|
48
|
+
};
|
|
49
|
+
|
|
50
|
+
/**
|
|
51
|
+
* Connect to a remote noise socket server.
|
|
52
|
+
*/
|
|
53
|
+
export function connect({
|
|
54
|
+
ls,
|
|
55
|
+
es,
|
|
56
|
+
rpk,
|
|
57
|
+
host,
|
|
58
|
+
port = 9735,
|
|
59
|
+
logger,
|
|
60
|
+
}: NoiseConnectOptions): NoiseSocket {
|
|
61
|
+
if (!es) {
|
|
62
|
+
es = crypto.createPrivateKey();
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
const noiseLogger = logger
|
|
66
|
+
? logger.sub('noise', rpk.slice(0, 8).toString('hex'))
|
|
67
|
+
: undefined;
|
|
68
|
+
const noiseState = new NoiseState({ ls, es, logger: noiseLogger });
|
|
69
|
+
const socket = new Socket();
|
|
70
|
+
const instance = new NoiseSocket({
|
|
71
|
+
socket,
|
|
72
|
+
noiseState,
|
|
73
|
+
rpk,
|
|
74
|
+
logger: noiseLogger,
|
|
75
|
+
});
|
|
76
|
+
socket.connect({ host, port });
|
|
77
|
+
return instance;
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
/**
|
|
81
|
+
* Factory function to create a new server
|
|
82
|
+
*/
|
|
83
|
+
export function createServer(
|
|
84
|
+
{ ls, esFactory }: NoiseServerOptions,
|
|
85
|
+
connListener: (socket: NoiseSocket) => void,
|
|
86
|
+
): NoiseServer {
|
|
87
|
+
return new NoiseServer({ ls, esFactory }, connListener);
|
|
88
|
+
}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
export type NoiseServerListenOptions = {
|
|
2
|
+
/**
|
|
3
|
+
* Optional port to listen on. If port is omitted or is 0,
|
|
4
|
+
* the operating system will assign an arbitrary unused port, which can be retrieved
|
|
5
|
+
* by using server.address().port after the 'listening' event has been emitted.
|
|
6
|
+
*/
|
|
7
|
+
port?: number;
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* Optional host to listen on. If host is omitted, the server
|
|
11
|
+
* will accept connections on the unspecified IPv6 address (::) when IPv6 is available,
|
|
12
|
+
* or the unspecified IPv4 address (0.0.0.0) otherwise. In most operating systems,
|
|
13
|
+
* listening to the unspecified IPv6 address (::) may cause NoiseSocket to also
|
|
14
|
+
* listen on the unspecified IPv4 address (0.0.0.0).
|
|
15
|
+
*/
|
|
16
|
+
host?: string;
|
|
17
|
+
|
|
18
|
+
/**
|
|
19
|
+
* Optional value to specify the maximum length of the
|
|
20
|
+
* queue of pending connections. The actual length will be determined by the OS through
|
|
21
|
+
* sysctl settings such as tcp_max_syn_backlog and somaxconn on Linux. The default value
|
|
22
|
+
* of this parameter is 511 (not 512).
|
|
23
|
+
*/
|
|
24
|
+
backlog?: number;
|
|
25
|
+
};
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export type NoiseServerOptions = {
|
|
2
|
+
/**
|
|
3
|
+
* Local private key as a 32-byte private key for elliptic curve
|
|
4
|
+
* secp256k1 used by the server
|
|
5
|
+
*/
|
|
6
|
+
ls: Buffer;
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* Function for creating the ephemeral private key used by each
|
|
10
|
+
* connection
|
|
11
|
+
*/
|
|
12
|
+
esFactory?: () => Buffer;
|
|
13
|
+
};
|
|
@@ -0,0 +1,135 @@
|
|
|
1
|
+
import * as crypto from '@node-dlc/crypto';
|
|
2
|
+
import assert from 'assert';
|
|
3
|
+
import { EventEmitter } from 'events';
|
|
4
|
+
import { AddressInfo, Server, Socket } from 'net';
|
|
5
|
+
|
|
6
|
+
import { NoiseError } from './noise-error';
|
|
7
|
+
import { NoiseServerListenOptions } from './noise-server-listen-options';
|
|
8
|
+
import { NoiseServerOptions } from './noise-server-options';
|
|
9
|
+
import { NoiseSocket } from './noise-socket';
|
|
10
|
+
import { NoiseState } from './noise-state';
|
|
11
|
+
|
|
12
|
+
export class NoiseServer extends EventEmitter {
|
|
13
|
+
/**
|
|
14
|
+
* Local private key as a 32-byte private key for elliptic curve
|
|
15
|
+
* secp256k1 used by the server
|
|
16
|
+
*/
|
|
17
|
+
public ls: Buffer;
|
|
18
|
+
|
|
19
|
+
/**
|
|
20
|
+
* Function for creating the ephemeral private key used by each
|
|
21
|
+
* connection
|
|
22
|
+
*/
|
|
23
|
+
public esFactory: () => Buffer;
|
|
24
|
+
|
|
25
|
+
/**
|
|
26
|
+
* Socket server that is created
|
|
27
|
+
*/
|
|
28
|
+
private _server: Server;
|
|
29
|
+
|
|
30
|
+
/**
|
|
31
|
+
* NoiseServer is a TCP server that wraps socket instances
|
|
32
|
+
* with the NoiseSocket class. This class is an event emitter
|
|
33
|
+
* with the same interface as net.Server.
|
|
34
|
+
*
|
|
35
|
+
* The constructor take arguments that will be used by the
|
|
36
|
+
* NoiseState.
|
|
37
|
+
*/
|
|
38
|
+
constructor(
|
|
39
|
+
opts: NoiseServerOptions,
|
|
40
|
+
connListener?: (socket: NoiseSocket) => void,
|
|
41
|
+
) {
|
|
42
|
+
super();
|
|
43
|
+
|
|
44
|
+
// localSecret assertions
|
|
45
|
+
assert.ok(Buffer.isBuffer(opts.ls), new NoiseError('ls must be a buffer'));
|
|
46
|
+
assert.ok(
|
|
47
|
+
crypto.validPrivateKey(opts.ls),
|
|
48
|
+
new NoiseError('ls must be valid public key'),
|
|
49
|
+
);
|
|
50
|
+
this.ls = opts.ls;
|
|
51
|
+
|
|
52
|
+
// ephemeral secret factory
|
|
53
|
+
assert.ok(
|
|
54
|
+
!opts.esFactory || typeof opts.esFactory === 'function',
|
|
55
|
+
new NoiseError('esFactory must be a function'),
|
|
56
|
+
);
|
|
57
|
+
this.esFactory = opts.esFactory || crypto.createPrivateKey;
|
|
58
|
+
|
|
59
|
+
// construct and bind the server
|
|
60
|
+
this._server = new Server();
|
|
61
|
+
this._server.on('connection', this._onConnection.bind(this));
|
|
62
|
+
this._server.on('error', (err) => this.emit('error', err));
|
|
63
|
+
this._server.on('close', () => this.emit('close'));
|
|
64
|
+
this._server.on('listening', () => this.emit('listening'));
|
|
65
|
+
|
|
66
|
+
if (connListener) this.on('connection', connListener);
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
/**
|
|
70
|
+
* Called when the socket receives a new socket connection.
|
|
71
|
+
* Emits the `connection` event.
|
|
72
|
+
*/
|
|
73
|
+
public _onConnection(socket: Socket): void {
|
|
74
|
+
const ls = this.ls;
|
|
75
|
+
const es = this.esFactory();
|
|
76
|
+
const noiseState = new NoiseState({ ls, es });
|
|
77
|
+
const noiseSocket = new NoiseSocket({ socket, noiseState });
|
|
78
|
+
this.emit('connection', noiseSocket);
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
/**
|
|
82
|
+
* Returns the address the server is listeening on. If the server is
|
|
83
|
+
* not listening, it will return undefined.
|
|
84
|
+
*/
|
|
85
|
+
public address(): string | AddressInfo {
|
|
86
|
+
return this._server.address();
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
/**
|
|
90
|
+
* Stops the server from accepting new connections and keeps existing connections open.
|
|
91
|
+
* This function is asynchronous, the server is fully closed when all connections are
|
|
92
|
+
* ended and the server emits a `close` event. The optional `cb` event will be called
|
|
93
|
+
* once the `close` event occurs.
|
|
94
|
+
*/
|
|
95
|
+
public close(cb?: (err?: Error) => void): void {
|
|
96
|
+
this._server.close(cb);
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
/**
|
|
100
|
+
* Asynchronously get the number of concurrent connections on the server. Works when sockets were sent to forks.
|
|
101
|
+
*/
|
|
102
|
+
public getConnections(cb: (error: Error, count: number) => void): void {
|
|
103
|
+
this._server.getConnections(cb);
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
/**
|
|
107
|
+
* Start a server listening for connections. This method is asyncrhonous,
|
|
108
|
+
* once the server has started listening, the `listening` event will be
|
|
109
|
+
* emitted.
|
|
110
|
+
* @param callback Called when the server is listening. Automatically binds
|
|
111
|
+
* the function to the `listening` event.
|
|
112
|
+
*/
|
|
113
|
+
public listen(opts: NoiseServerListenOptions, callback?: () => void): this {
|
|
114
|
+
this._server.listen(opts, callback);
|
|
115
|
+
return this;
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
/**
|
|
119
|
+
* Indicates whether or not the server is listening for connections.
|
|
120
|
+
*/
|
|
121
|
+
public get listening(): boolean {
|
|
122
|
+
return this._server.listening;
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
/**
|
|
126
|
+
* Set this property to reject connections when the server's connection count gets high.
|
|
127
|
+
*/
|
|
128
|
+
public get maxConnections(): number {
|
|
129
|
+
return this._server.maxConnections;
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
public set maxConnections(val: number) {
|
|
133
|
+
this._server.maxConnections = val;
|
|
134
|
+
}
|
|
135
|
+
}
|