@nockchain/rose-ts 0.1.1-alpha
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +373 -0
- package/dist/constants.d.ts +2 -0
- package/dist/constants.d.ts.map +1 -0
- package/dist/constants.js +2 -0
- package/dist/constants.js.map +1 -0
- package/dist/core/belt.d.ts +16 -0
- package/dist/core/belt.d.ts.map +1 -0
- package/dist/core/belt.js +120 -0
- package/dist/core/belt.js.map +1 -0
- package/dist/core/digest.d.ts +9 -0
- package/dist/core/digest.d.ts.map +1 -0
- package/dist/core/digest.js +76 -0
- package/dist/core/digest.js.map +1 -0
- package/dist/core/hashable.d.ts +21 -0
- package/dist/core/hashable.d.ts.map +1 -0
- package/dist/core/hashable.js +128 -0
- package/dist/core/hashable.js.map +1 -0
- package/dist/core/lock.d.ts +8 -0
- package/dist/core/lock.d.ts.map +1 -0
- package/dist/core/lock.js +95 -0
- package/dist/core/lock.js.map +1 -0
- package/dist/core/merkle.d.ts +7 -0
- package/dist/core/merkle.d.ts.map +1 -0
- package/dist/core/merkle.js +57 -0
- package/dist/core/merkle.js.map +1 -0
- package/dist/core/must.d.ts +3 -0
- package/dist/core/must.d.ts.map +1 -0
- package/dist/core/must.js +14 -0
- package/dist/core/must.js.map +1 -0
- package/dist/core/tip5/constants.d.ts +10 -0
- package/dist/core/tip5/constants.d.ts.map +1 -0
- package/dist/core/tip5/constants.js +70 -0
- package/dist/core/tip5/constants.js.map +1 -0
- package/dist/core/tip5/index.d.ts +5 -0
- package/dist/core/tip5/index.d.ts.map +1 -0
- package/dist/core/tip5/index.js +100 -0
- package/dist/core/tip5/index.js.map +1 -0
- package/dist/core/u256.d.ts +21 -0
- package/dist/core/u256.d.ts.map +1 -0
- package/dist/core/u256.js +96 -0
- package/dist/core/u256.js.map +1 -0
- package/dist/core/ubig.d.ts +20 -0
- package/dist/core/ubig.d.ts.map +1 -0
- package/dist/core/ubig.js +81 -0
- package/dist/core/ubig.js.map +1 -0
- package/dist/core/zbase.d.ts +11 -0
- package/dist/core/zbase.d.ts.map +1 -0
- package/dist/core/zbase.js +82 -0
- package/dist/core/zbase.js.map +1 -0
- package/dist/crypto/bpoly.d.ts +3 -0
- package/dist/crypto/bpoly.d.ts.map +1 -0
- package/dist/crypto/bpoly.js +121 -0
- package/dist/crypto/bpoly.js.map +1 -0
- package/dist/crypto/cheetah.d.ts +25 -0
- package/dist/crypto/cheetah.d.ts.map +1 -0
- package/dist/crypto/cheetah.js +250 -0
- package/dist/crypto/cheetah.js.map +1 -0
- package/dist/crypto/index.d.ts +7 -0
- package/dist/crypto/index.d.ts.map +1 -0
- package/dist/crypto/index.js +24 -0
- package/dist/crypto/index.js.map +1 -0
- package/dist/crypto/privateKey.d.ts +11 -0
- package/dist/crypto/privateKey.d.ts.map +1 -0
- package/dist/crypto/privateKey.js +88 -0
- package/dist/crypto/privateKey.js.map +1 -0
- package/dist/crypto/publicKey.d.ts +18 -0
- package/dist/crypto/publicKey.d.ts.map +1 -0
- package/dist/crypto/publicKey.js +79 -0
- package/dist/crypto/publicKey.js.map +1 -0
- package/dist/crypto/slip10.d.ts +10 -0
- package/dist/crypto/slip10.d.ts.map +1 -0
- package/dist/crypto/slip10.js +104 -0
- package/dist/crypto/slip10.js.map +1 -0
- package/dist/grpc/index.d.ts +12 -0
- package/dist/grpc/index.d.ts.map +1 -0
- package/dist/grpc/index.js +13 -0
- package/dist/grpc/index.js.map +1 -0
- package/dist/grpc/proto.d.ts +26 -0
- package/dist/grpc/proto.d.ts.map +1 -0
- package/dist/grpc/proto.js +219 -0
- package/dist/grpc/proto.js.map +1 -0
- package/dist/hash/index.d.ts +32 -0
- package/dist/hash/index.d.ts.map +1 -0
- package/dist/hash/index.js +138 -0
- package/dist/hash/index.js.map +1 -0
- package/dist/hash/note.d.ts +13 -0
- package/dist/hash/note.d.ts.map +1 -0
- package/dist/hash/note.js +78 -0
- package/dist/hash/note.js.map +1 -0
- package/dist/hash/noteData.d.ts +12 -0
- package/dist/hash/noteData.d.ts.map +1 -0
- package/dist/hash/noteData.js +115 -0
- package/dist/hash/noteData.js.map +1 -0
- package/dist/hash/noun.d.ts +4 -0
- package/dist/hash/noun.d.ts.map +1 -0
- package/dist/hash/noun.js +15 -0
- package/dist/hash/noun.js.map +1 -0
- package/dist/hash/structural.d.ts +5 -0
- package/dist/hash/structural.d.ts.map +1 -0
- package/dist/hash/structural.js +41 -0
- package/dist/hash/structural.js.map +1 -0
- package/dist/hash/tx.d.ts +15 -0
- package/dist/hash/tx.d.ts.map +1 -0
- package/dist/hash/tx.js +146 -0
- package/dist/hash/tx.js.map +1 -0
- package/dist/index.d.ts +14 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +10 -0
- package/dist/index.js.map +1 -0
- package/dist/noun/belts.d.ts +9 -0
- package/dist/noun/belts.d.ts.map +1 -0
- package/dist/noun/belts.js +73 -0
- package/dist/noun/belts.js.map +1 -0
- package/dist/noun/bitwriter.d.ts +14 -0
- package/dist/noun/bitwriter.d.ts.map +1 -0
- package/dist/noun/bitwriter.js +100 -0
- package/dist/noun/bitwriter.js.map +1 -0
- package/dist/noun/codec.d.ts +9 -0
- package/dist/noun/codec.d.ts.map +1 -0
- package/dist/noun/codec.js +144 -0
- package/dist/noun/codec.js.map +1 -0
- package/dist/noun/cue.d.ts +3 -0
- package/dist/noun/cue.d.ts.map +1 -0
- package/dist/noun/cue.js +152 -0
- package/dist/noun/cue.js.map +1 -0
- package/dist/noun/encode.d.ts +12 -0
- package/dist/noun/encode.d.ts.map +1 -0
- package/dist/noun/encode.js +37 -0
- package/dist/noun/encode.js.map +1 -0
- package/dist/noun/index.d.ts +10 -0
- package/dist/noun/index.d.ts.map +1 -0
- package/dist/noun/index.js +29 -0
- package/dist/noun/index.js.map +1 -0
- package/dist/noun/jam.d.ts +3 -0
- package/dist/noun/jam.d.ts.map +1 -0
- package/dist/noun/jam.js +107 -0
- package/dist/noun/jam.js.map +1 -0
- package/dist/noun/types.d.ts +21 -0
- package/dist/noun/types.d.ts.map +1 -0
- package/dist/noun/types.js +66 -0
- package/dist/noun/types.js.map +1 -0
- package/dist/noun/words.d.ts +3 -0
- package/dist/noun/words.d.ts.map +1 -0
- package/dist/noun/words.js +6 -0
- package/dist/noun/words.js.map +1 -0
- package/dist/proto/decode.d.ts +10 -0
- package/dist/proto/decode.d.ts.map +1 -0
- package/dist/proto/decode.js +44 -0
- package/dist/proto/decode.js.map +1 -0
- package/dist/proto/digest.d.ts +21 -0
- package/dist/proto/digest.d.ts.map +1 -0
- package/dist/proto/digest.js +29 -0
- package/dist/proto/digest.js.map +1 -0
- package/dist/proto/index.d.ts +9 -0
- package/dist/proto/index.d.ts.map +1 -0
- package/dist/proto/index.js +140 -0
- package/dist/proto/index.js.map +1 -0
- package/dist/proto/note.d.ts +4 -0
- package/dist/proto/note.d.ts.map +1 -0
- package/dist/proto/note.js +99 -0
- package/dist/proto/note.js.map +1 -0
- package/dist/proto/rawTx.d.ts +3 -0
- package/dist/proto/rawTx.d.ts.map +1 -0
- package/dist/proto/rawTx.js +186 -0
- package/dist/proto/rawTx.js.map +1 -0
- package/dist/rpc/client.d.ts +13 -0
- package/dist/rpc/client.d.ts.map +1 -0
- package/dist/rpc/client.js +75 -0
- package/dist/rpc/client.js.map +1 -0
- package/dist/rpc/types.d.ts +18 -0
- package/dist/rpc/types.d.ts.map +1 -0
- package/dist/rpc/types.js +2 -0
- package/dist/rpc/types.js.map +1 -0
- package/dist/rpc/wire/encode.d.ts +4 -0
- package/dist/rpc/wire/encode.d.ts.map +1 -0
- package/dist/rpc/wire/encode.js +168 -0
- package/dist/rpc/wire/encode.js.map +1 -0
- package/dist/rpc/wire/protobuf.d.ts +10 -0
- package/dist/rpc/wire/protobuf.d.ts.map +1 -0
- package/dist/rpc/wire/protobuf.js +50 -0
- package/dist/rpc/wire/protobuf.js.map +1 -0
- package/dist/stubs.d.ts +6 -0
- package/dist/stubs.d.ts.map +1 -0
- package/dist/stubs.js +12 -0
- package/dist/stubs.js.map +1 -0
- package/dist/tx/accessors.d.ts +13 -0
- package/dist/tx/accessors.d.ts.map +1 -0
- package/dist/tx/accessors.js +65 -0
- package/dist/tx/accessors.js.map +1 -0
- package/dist/tx/builder.d.ts +63 -0
- package/dist/tx/builder.d.ts.map +1 -0
- package/dist/tx/builder.js +601 -0
- package/dist/tx/builder.js.map +1 -0
- package/dist/tx/display.d.ts +7 -0
- package/dist/tx/display.d.ts.map +1 -0
- package/dist/tx/display.js +34 -0
- package/dist/tx/display.js.map +1 -0
- package/dist/tx/fee.d.ts +8 -0
- package/dist/tx/fee.d.ts.map +1 -0
- package/dist/tx/fee.js +81 -0
- package/dist/tx/fee.js.map +1 -0
- package/dist/tx/htlc.d.ts +21 -0
- package/dist/tx/htlc.d.ts.map +1 -0
- package/dist/tx/htlc.js +65 -0
- package/dist/tx/htlc.js.map +1 -0
- package/dist/tx/index.d.ts +19 -0
- package/dist/tx/index.d.ts.map +1 -0
- package/dist/tx/index.js +64 -0
- package/dist/tx/index.js.map +1 -0
- package/dist/tx/multisig.d.ts +3 -0
- package/dist/tx/multisig.d.ts.map +1 -0
- package/dist/tx/multisig.js +8 -0
- package/dist/tx/multisig.js.map +1 -0
- package/dist/tx/outputs.d.ts +3 -0
- package/dist/tx/outputs.d.ts.map +1 -0
- package/dist/tx/outputs.js +57 -0
- package/dist/tx/outputs.js.map +1 -0
- package/dist/tx/spend.d.ts +10 -0
- package/dist/tx/spend.d.ts.map +1 -0
- package/dist/tx/spend.js +17 -0
- package/dist/tx/spend.js.map +1 -0
- package/dist/tx/spends.d.ts +8 -0
- package/dist/tx/spends.d.ts.map +1 -0
- package/dist/tx/spends.js +48 -0
- package/dist/tx/spends.js.map +1 -0
- package/dist/tx/types.d.ts +5 -0
- package/dist/tx/types.d.ts.map +1 -0
- package/dist/tx/types.js +2 -0
- package/dist/tx/types.js.map +1 -0
- package/dist/tx/unlocks.d.ts +4 -0
- package/dist/tx/unlocks.d.ts.map +1 -0
- package/dist/tx/unlocks.js +49 -0
- package/dist/tx/unlocks.js.map +1 -0
- package/dist/tx/witness.d.ts +14 -0
- package/dist/tx/witness.d.ts.map +1 -0
- package/dist/tx/witness.js +81 -0
- package/dist/tx/witness.js.map +1 -0
- package/dist/types.d.ts +311 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +2 -0
- package/dist/types.js.map +1 -0
- package/package.json +45 -0
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { nameKey } from "./spends.js";
|
|
2
|
+
function findInZMap(inputs, name) {
|
|
3
|
+
const key = nameKey(name);
|
|
4
|
+
for (const [n, v] of inputs) {
|
|
5
|
+
if (nameKey(n) === key)
|
|
6
|
+
return v;
|
|
7
|
+
}
|
|
8
|
+
return undefined;
|
|
9
|
+
}
|
|
10
|
+
export function getDisplayInput(display, name) {
|
|
11
|
+
if ("tag" in display && display.tag === 1) {
|
|
12
|
+
const sc = findInZMap(display.inputs, name);
|
|
13
|
+
return sc;
|
|
14
|
+
}
|
|
15
|
+
if ("tag" in display && display.tag === 0) {
|
|
16
|
+
const sig = findInZMap(display.inputs, name);
|
|
17
|
+
if (sig !== undefined)
|
|
18
|
+
return { tag: "v0", sig };
|
|
19
|
+
}
|
|
20
|
+
if ("inputs" in display && !("tag" in display)) {
|
|
21
|
+
const entry = findInZMap(display.inputs, name);
|
|
22
|
+
if (entry === undefined)
|
|
23
|
+
return undefined;
|
|
24
|
+
if (Array.isArray(entry) || (typeof entry === "object" && entry !== null && "tag" in entry)) {
|
|
25
|
+
return entry;
|
|
26
|
+
}
|
|
27
|
+
return { tag: "v0", sig: entry };
|
|
28
|
+
}
|
|
29
|
+
return undefined;
|
|
30
|
+
}
|
|
31
|
+
export function isV1DisplayInput(input) {
|
|
32
|
+
return input !== undefined && !(typeof input === "object" && "tag" in input && input.tag === "v0");
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=display.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"display.js","sourceRoot":"","sources":["../../src/tx/display.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAEtC,SAAS,UAAU,CACjB,MAAmB,EACnB,IAAU;IAEV,MAAM,GAAG,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAC1B,KAAK,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,MAAM,EAAE,CAAC;QAC5B,IAAI,OAAO,CAAC,CAAC,CAAC,KAAK,GAAG;YAAE,OAAO,CAAC,CAAC;IACnC,CAAC;IACD,OAAO,SAAS,CAAC;AACnB,CAAC;AAGD,MAAM,UAAU,eAAe,CAC7B,OAAqB,EACrB,IAAU;IAEV,IAAI,KAAK,IAAI,OAAO,IAAI,OAAO,CAAC,GAAG,KAAK,CAAC,EAAE,CAAC;QAC1C,MAAM,EAAE,GAAG,UAAU,CAAC,OAAO,CAAC,MAAkC,EAAE,IAAI,CAAC,CAAC;QACxE,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,IAAI,KAAK,IAAI,OAAO,IAAI,OAAO,CAAC,GAAG,KAAK,CAAC,EAAE,CAAC;QAC1C,MAAM,GAAG,GAAG,UAAU,CAAC,OAAO,CAAC,MAA2B,EAAE,IAAI,CAAC,CAAC;QAClE,IAAI,GAAG,KAAK,SAAS;YAAE,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,CAAC;IACnD,CAAC;IACD,IAAI,QAAQ,IAAI,OAAO,IAAI,CAAC,CAAC,KAAK,IAAI,OAAO,CAAC,EAAE,CAAC;QAC/C,MAAM,KAAK,GAAG,UAAU,CACtB,OAAO,CAAC,MAA0E,EAClF,IAAI,CACL,CAAC;QACF,IAAI,KAAK,KAAK,SAAS;YAAE,OAAO,SAAS,CAAC;QAC1C,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,IAAI,KAAK,CAAC,EAAE,CAAC;YAC5F,OAAO,KAAuB,CAAC;QACjC,CAAC;QACD,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC;IACnC,CAAC;IACD,OAAO,SAAS,CAAC;AACnB,CAAC;AAED,MAAM,UAAU,gBAAgB,CAC9B,KAAyC;IAEzC,OAAO,KAAK,KAAK,SAAS,IAAI,CAAC,CAAC,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,IAAI,KAAK,IAAI,KAAK,CAAC,GAAG,KAAK,IAAI,CAAC,CAAC;AACrG,CAAC"}
|
package/dist/tx/fee.d.ts
ADDED
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { LockRoot, Name, SpendV1, TxEngineSettings } from "../types.js";
|
|
2
|
+
export declare function spendCalcWords(spend: SpendV1): [bigint, bigint];
|
|
3
|
+
export declare function wordsForOrderedSpends(spends: Iterable<SpendV1>, settings: TxEngineSettings): [bigint, bigint];
|
|
4
|
+
export declare function wordsForUnorderedSpends(spends: Iterable<[Name, SpendV1]>, settings: TxEngineSettings): [bigint, bigint];
|
|
5
|
+
export declare function calcFeeFromSpends(spends: Iterable<SpendV1>, settings: TxEngineSettings): bigint;
|
|
6
|
+
export declare function missingUnlocksFee(spend: SpendV1, settings: TxEngineSettings): bigint;
|
|
7
|
+
export declare function lockRootKey(root: LockRoot): string;
|
|
8
|
+
//# sourceMappingURL=fee.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fee.d.ts","sourceRoot":"","sources":["../../src/tx/fee.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EACV,QAAQ,EACR,IAAI,EAIJ,OAAO,EACP,gBAAgB,EACjB,MAAM,aAAa,CAAC;AAQrB,wBAAgB,cAAc,CAAC,KAAK,EAAE,OAAO,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAW/D;AAqBD,wBAAgB,qBAAqB,CACnC,MAAM,EAAE,QAAQ,CAAC,OAAO,CAAC,EACzB,QAAQ,EAAE,gBAAgB,GACzB,CAAC,MAAM,EAAE,MAAM,CAAC,CAuBlB;AAED,wBAAgB,uBAAuB,CACrC,MAAM,EAAE,QAAQ,CAAC,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC,EACjC,QAAQ,EAAE,gBAAgB,GACzB,CAAC,MAAM,EAAE,MAAM,CAAC,CAKlB;AAED,wBAAgB,iBAAiB,CAC/B,MAAM,EAAE,QAAQ,CAAC,OAAO,CAAC,EACzB,QAAQ,EAAE,gBAAgB,GACzB,MAAM,CAOR;AAED,wBAAgB,iBAAiB,CAAC,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,gBAAgB,GAAG,MAAM,CAEpF;AAED,wBAAgB,WAAW,CAAC,IAAI,EAAE,QAAQ,GAAG,MAAM,CAElD"}
|
package/dist/tx/fee.js
ADDED
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
import { encodeWitness } from "../noun/codec.js";
|
|
2
|
+
import { nounWords } from "../noun/words.js";
|
|
3
|
+
import { noteDataFeeWords } from "../hash/note.js";
|
|
4
|
+
import { lockRootHash } from "../hash/index.js";
|
|
5
|
+
import { missingUnlocksFee as missingUnlocksFeeImpl } from "./unlocks.js";
|
|
6
|
+
function seedNoteDataWords(seed) {
|
|
7
|
+
return noteDataFeeWords(seed.note_data);
|
|
8
|
+
}
|
|
9
|
+
export function spendCalcWords(spend) {
|
|
10
|
+
if (spend.tag !== 1) {
|
|
11
|
+
const seeds = Array.isArray(spend.seeds) ? spend.seeds : [];
|
|
12
|
+
const seedWords = seeds.reduce((acc, s) => acc + seedNoteDataWords(s), 0n);
|
|
13
|
+
return [seedWords, 0n];
|
|
14
|
+
}
|
|
15
|
+
const s = spend;
|
|
16
|
+
const seeds = Array.isArray(s.seeds) ? s.seeds : [];
|
|
17
|
+
const seedWords = seeds.reduce((acc, sd) => acc + seedNoteDataWords(sd), 0n);
|
|
18
|
+
const witnessWords = nounWords(encodeWitness(s.witness));
|
|
19
|
+
return [seedWords, witnessWords];
|
|
20
|
+
}
|
|
21
|
+
function mergeNoteDataByLockRoot(spends) {
|
|
22
|
+
const merged = new Map();
|
|
23
|
+
for (const spend of spends) {
|
|
24
|
+
const seeds = spend.tag === 1 ? spend.seeds : spend.seeds;
|
|
25
|
+
for (const seed of seeds) {
|
|
26
|
+
const key = lockRootHash(seed.lock_root);
|
|
27
|
+
const prev = merged.get(key);
|
|
28
|
+
if (!prev) {
|
|
29
|
+
merged.set(key, [...seed.note_data]);
|
|
30
|
+
continue;
|
|
31
|
+
}
|
|
32
|
+
const map = new Map(prev);
|
|
33
|
+
for (const [k, v] of seed.note_data)
|
|
34
|
+
map.set(k, v);
|
|
35
|
+
merged.set(key, [...map.entries()]);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
return merged;
|
|
39
|
+
}
|
|
40
|
+
export function wordsForOrderedSpends(spends, settings) {
|
|
41
|
+
if (settings.tx_engine_version === 0) {
|
|
42
|
+
throw new Error("fee() called on v0 settings");
|
|
43
|
+
}
|
|
44
|
+
const list = [...spends];
|
|
45
|
+
let sw = 0n;
|
|
46
|
+
let ww = 0n;
|
|
47
|
+
if (settings.tx_engine_patch === 0) {
|
|
48
|
+
for (const spend of list) {
|
|
49
|
+
const [s, w] = spendCalcWords(spend);
|
|
50
|
+
sw += s;
|
|
51
|
+
ww += w;
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
else {
|
|
55
|
+
for (const spend of list) {
|
|
56
|
+
const [, w] = spendCalcWords(spend);
|
|
57
|
+
ww += w;
|
|
58
|
+
}
|
|
59
|
+
for (const noteData of mergeNoteDataByLockRoot(list).values()) {
|
|
60
|
+
sw += noteDataFeeWords(noteData);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
return [sw, ww];
|
|
64
|
+
}
|
|
65
|
+
export function wordsForUnorderedSpends(spends, settings) {
|
|
66
|
+
return wordsForOrderedSpends([...spends].map(([, s]) => s), settings);
|
|
67
|
+
}
|
|
68
|
+
export function calcFeeFromSpends(spends, settings) {
|
|
69
|
+
const [sw, ww] = wordsForOrderedSpends(spends, settings);
|
|
70
|
+
const fee = BigInt(settings.cost_per_word) * sw +
|
|
71
|
+
(BigInt(settings.cost_per_word) * ww) / BigInt(settings.witness_word_div);
|
|
72
|
+
const minFee = BigInt(settings.min_fee);
|
|
73
|
+
return fee > minFee ? fee : minFee;
|
|
74
|
+
}
|
|
75
|
+
export function missingUnlocksFee(spend, settings) {
|
|
76
|
+
return missingUnlocksFeeImpl(spend, settings);
|
|
77
|
+
}
|
|
78
|
+
export function lockRootKey(root) {
|
|
79
|
+
return lockRootHash(root);
|
|
80
|
+
}
|
|
81
|
+
//# sourceMappingURL=fee.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fee.js","sourceRoot":"","sources":["../../src/tx/fee.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import type { Digest, Lock, Note, TxEngineSettings } from "../types.js";
|
|
2
|
+
export declare function htlcOrLock(hNock: Digest, buyerPkh: Digest, sellerPkh: Digest, refundHeight: bigint): Lock;
|
|
3
|
+
export declare function htlcLockRootDigest(hNock: Digest, buyerPkh: Digest, sellerPkh: Digest, refundHeight: bigint): Digest;
|
|
4
|
+
export declare function giftOutputFirstNameFromLockOutputs(outputs: {
|
|
5
|
+
name: {
|
|
6
|
+
first: string;
|
|
7
|
+
};
|
|
8
|
+
assets: unknown;
|
|
9
|
+
}[], giftNicks: bigint): Digest;
|
|
10
|
+
export declare function htlcGiftOutputFirstName(params: {
|
|
11
|
+
hNock: Digest;
|
|
12
|
+
buyerPkh: Digest;
|
|
13
|
+
sellerPkh: Digest;
|
|
14
|
+
refundHeight: bigint;
|
|
15
|
+
giftNicks: bigint;
|
|
16
|
+
inputNote: Note;
|
|
17
|
+
parentHash?: Digest;
|
|
18
|
+
inputPkh?: Digest;
|
|
19
|
+
settings?: TxEngineSettings;
|
|
20
|
+
}): Digest;
|
|
21
|
+
//# sourceMappingURL=htlc.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"htlc.d.ts","sourceRoot":"","sources":["../../src/tx/htlc.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,IAAI,EAAS,IAAI,EAAwB,gBAAgB,EAAE,MAAM,aAAa,CAAC;AA6BrG,wBAAgB,UAAU,CACxB,KAAK,EAAE,MAAM,EACb,QAAQ,EAAE,MAAM,EAChB,SAAS,EAAE,MAAM,EACjB,YAAY,EAAE,MAAM,GACnB,IAAI,CAcN;AAGD,wBAAgB,kBAAkB,CAChC,KAAK,EAAE,MAAM,EACb,QAAQ,EAAE,MAAM,EAChB,SAAS,EAAE,MAAM,EACjB,YAAY,EAAE,MAAM,GACnB,MAAM,CAER;AAGD,wBAAgB,kCAAkC,CAChD,OAAO,EAAE;IAAE,IAAI,EAAE;QAAE,KAAK,EAAE,MAAM,CAAA;KAAE,CAAC;IAAC,MAAM,EAAE,OAAO,CAAA;CAAE,EAAE,EACvD,SAAS,EAAE,MAAM,GAChB,MAAM,CAOR;AAMD,wBAAgB,uBAAuB,CAAC,MAAM,EAAE;IAC9C,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;IAClB,YAAY,EAAE,MAAM,CAAC;IACrB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,IAAI,CAAC;IAEhB,UAAU,CAAC,EAAE,MAAM,CAAC;IAEpB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,gBAAgB,CAAC;CAC7B,GAAG,MAAM,CA8BT"}
|
package/dist/tx/htlc.js
ADDED
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import { rawTxV1CalcId } from "../hash/tx.js";
|
|
2
|
+
import { lockFromList, lockRootHash, noteDataEmpty, noteHash, pkhSingle, spendConditionNewPkh, } from "../hash/index.js";
|
|
3
|
+
import { SpendBuilder, TxBuilder } from "./builder.js";
|
|
4
|
+
import { rawTxV1Outputs } from "./outputs.js";
|
|
5
|
+
import { applyWitness } from "./spends.js";
|
|
6
|
+
const TX_ENGINE_SETTINGS_V1_BYTHOS_DEFAULT = {
|
|
7
|
+
tx_engine_version: 1,
|
|
8
|
+
tx_engine_patch: 1,
|
|
9
|
+
min_fee: "256",
|
|
10
|
+
cost_per_word: "16384",
|
|
11
|
+
witness_word_div: 4,
|
|
12
|
+
};
|
|
13
|
+
function nockchainTxToRawTx(tx) {
|
|
14
|
+
const spends = applyWitness(tx.spends, tx.witness_data);
|
|
15
|
+
const id = rawTxV1CalcId({ version: 1, id: "", spends });
|
|
16
|
+
return { version: 1, id, spends };
|
|
17
|
+
}
|
|
18
|
+
export function htlcOrLock(hNock, buyerPkh, sellerPkh, refundHeight) {
|
|
19
|
+
const pkhSc = spendConditionNewPkh(pkhSingle(buyerPkh));
|
|
20
|
+
const haxPrim = { tag: "hax", preimages: [hNock] };
|
|
21
|
+
const claimSpendCondition = [...pkhSc, haxPrim];
|
|
22
|
+
const refundPkhSc = spendConditionNewPkh(pkhSingle(sellerPkh));
|
|
23
|
+
const timPrim = {
|
|
24
|
+
tag: "tim",
|
|
25
|
+
rel: { min: null, max: null },
|
|
26
|
+
abs: { min: Number(refundHeight), max: null },
|
|
27
|
+
};
|
|
28
|
+
const refundSpendCondition = [...refundPkhSc, timPrim];
|
|
29
|
+
return lockFromList([claimSpendCondition, refundSpendCondition]);
|
|
30
|
+
}
|
|
31
|
+
export function htlcLockRootDigest(hNock, buyerPkh, sellerPkh, refundHeight) {
|
|
32
|
+
return lockRootHash(htlcOrLock(hNock, buyerPkh, sellerPkh, refundHeight));
|
|
33
|
+
}
|
|
34
|
+
export function giftOutputFirstNameFromLockOutputs(outputs, giftNicks) {
|
|
35
|
+
for (const out of outputs) {
|
|
36
|
+
if (BigInt(out.assets) === giftNicks) {
|
|
37
|
+
return out.name.first;
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
throw new Error("HTLC gift output not found in lock transaction outputs");
|
|
41
|
+
}
|
|
42
|
+
export function htlcGiftOutputFirstName(params) {
|
|
43
|
+
const lockRootDigest = htlcLockRootDigest(params.hNock, params.buyerPkh, params.sellerPkh, params.refundHeight);
|
|
44
|
+
const parentHash = params.parentHash ?? noteHash(params.inputNote);
|
|
45
|
+
const inputLock = lockFromList([
|
|
46
|
+
spendConditionNewPkh(pkhSingle((params.inputPkh ?? params.sellerPkh))),
|
|
47
|
+
]);
|
|
48
|
+
const spend = SpendBuilder.new(params.inputNote, inputLock, 0, inputLock);
|
|
49
|
+
spend.seed({
|
|
50
|
+
lock_root: lockRootDigest,
|
|
51
|
+
note_data: noteDataEmpty(),
|
|
52
|
+
gift: String(params.giftNicks),
|
|
53
|
+
parent_hash: parentHash,
|
|
54
|
+
output_source: null,
|
|
55
|
+
});
|
|
56
|
+
spend.computeRefund(false);
|
|
57
|
+
const settings = params.settings ?? TX_ENGINE_SETTINGS_V1_BYTHOS_DEFAULT;
|
|
58
|
+
const builder = new TxBuilder(settings);
|
|
59
|
+
builder.spend(spend);
|
|
60
|
+
builder.recalcAndSetFee(false);
|
|
61
|
+
const raw = nockchainTxToRawTx(builder.build());
|
|
62
|
+
const outputs = rawTxV1Outputs(raw, 0, settings);
|
|
63
|
+
return giftOutputFirstNameFromLockOutputs(outputs, params.giftNicks);
|
|
64
|
+
}
|
|
65
|
+
//# sourceMappingURL=htlc.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"htlc.js","sourceRoot":"","sources":["../../src/tx/htlc.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import type { Digest, Nicks, NockchainTx, Note, RawTxV1, SpendsV1, TxEngineSettings } from "../types.js";
|
|
2
|
+
export { SpendBuilder, TxBuilder, type SimpleSpendLockOptions } from "./builder.js";
|
|
3
|
+
export { giftOutputFirstNameFromLockOutputs, htlcGiftOutputFirstName, htlcOrLock, htlcLockRootDigest, } from "./htlc.js";
|
|
4
|
+
export { multisigLock } from "./multisig.js";
|
|
5
|
+
export { witnessFromLock, witnessNew, lockMerkleProofFromLock, witnessFromLockMerkleProof, witnessClearSignatures, witnessWithPkhSignature, witnessWithHaxPreimage, spendV1FromLock, spendConditionFromWitness, } from "./witness.js";
|
|
6
|
+
export { applyWitness, splitWitness } from "./spends.js";
|
|
7
|
+
export declare function txEngineSettingsV1Default(): TxEngineSettings;
|
|
8
|
+
export declare function txEngineSettingsV1BythosDefault(): TxEngineSettings;
|
|
9
|
+
export { rawTxV1InputNames, rawTxV1InputSpendConditions, rawTxV1New, rawTxV1Version, spendV1Fee, spendV1TotalGifts, spendV1UnclampedFee, spendsV1Fee, spendsV1TotalFees, spendsV1TotalGifts, spendsV1UnclampedFee, } from "./accessors.js";
|
|
10
|
+
export { spendV1NewWitness, spendV1NewLegacy, spendV1SigHash } from "./spend.js";
|
|
11
|
+
export type { OutputNoteData } from "./types.js";
|
|
12
|
+
export declare function spendsV1ApplyWitness(spends: SpendsV1, witnessData: NockchainTx["witness_data"]): SpendsV1;
|
|
13
|
+
export declare function nockchainTxToRawTx(tx: NockchainTx): RawTxV1;
|
|
14
|
+
export declare function rawTxV1ToNockchainTx(raw: RawTxV1): NockchainTx;
|
|
15
|
+
export declare function rawTxV1Outputs(obj: RawTxV1, originPage: number, settings: TxEngineSettings): Note[];
|
|
16
|
+
export declare function rawTxTotalFees(obj: RawTxV1): Nicks;
|
|
17
|
+
export declare function rawTxV1CalcId(obj: RawTxV1): Digest;
|
|
18
|
+
export declare function nockchainTxOutputs(tx: NockchainTx, originPage: number, settings: TxEngineSettings): Note[];
|
|
19
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/tx/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,MAAM,EACN,KAAK,EACL,WAAW,EACX,IAAI,EACJ,OAAO,EACP,QAAQ,EACR,gBAAgB,EACjB,MAAM,aAAa,CAAC;AAKrB,OAAO,EAAE,YAAY,EAAE,SAAS,EAAE,KAAK,sBAAsB,EAAE,MAAM,cAAc,CAAC;AACpF,OAAO,EACL,kCAAkC,EAClC,uBAAuB,EACvB,UAAU,EACV,kBAAkB,GACnB,MAAM,WAAW,CAAC;AACnB,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAC7C,OAAO,EACL,eAAe,EACf,UAAU,EACV,uBAAuB,EACvB,0BAA0B,EAC1B,sBAAsB,EACtB,uBAAuB,EACvB,sBAAsB,EACtB,eAAe,EACf,yBAAyB,GAC1B,MAAM,cAAc,CAAC;AACtB,OAAO,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAEzD,wBAAgB,yBAAyB,IAAI,gBAAgB,CAQ5D;AAED,wBAAgB,+BAA+B,IAAI,gBAAgB,CAQlE;AAED,OAAO,EACL,iBAAiB,EACjB,2BAA2B,EAC3B,UAAU,EACV,cAAc,EACd,UAAU,EACV,iBAAiB,EACjB,mBAAmB,EACnB,WAAW,EACX,iBAAiB,EACjB,kBAAkB,EAClB,oBAAoB,GACrB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AACjF,YAAY,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAEjD,wBAAgB,oBAAoB,CAClC,MAAM,EAAE,QAAQ,EAChB,WAAW,EAAE,WAAW,CAAC,cAAc,CAAC,GACvC,QAAQ,CAEV;AAED,wBAAgB,kBAAkB,CAAC,EAAE,EAAE,WAAW,GAAG,OAAO,CAI3D;AAGD,wBAAgB,oBAAoB,CAAC,GAAG,EAAE,OAAO,GAAG,WAAW,CAU9D;AAED,wBAAgB,cAAc,CAC5B,GAAG,EAAE,OAAO,EACZ,UAAU,EAAE,MAAM,EAClB,QAAQ,EAAE,gBAAgB,GACzB,IAAI,EAAE,CAER;AAED,wBAAgB,cAAc,CAAC,GAAG,EAAE,OAAO,GAAG,KAAK,CAMlD;AAED,wBAAgB,aAAa,CAAC,GAAG,EAAE,OAAO,GAAG,MAAM,CAElD;AAED,wBAAgB,kBAAkB,CAChC,EAAE,EAAE,WAAW,EACf,UAAU,EAAE,MAAM,EAClB,QAAQ,EAAE,gBAAgB,GACzB,IAAI,EAAE,CAER"}
|
package/dist/tx/index.js
ADDED
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import { rawTxV1Outputs as outputs } from "./outputs.js";
|
|
2
|
+
import { rawTxV1CalcId as calcId } from "../hash/tx.js";
|
|
3
|
+
import { applyWitness, splitWitness } from "./spends.js";
|
|
4
|
+
export { SpendBuilder, TxBuilder } from "./builder.js";
|
|
5
|
+
export { giftOutputFirstNameFromLockOutputs, htlcGiftOutputFirstName, htlcOrLock, htlcLockRootDigest, } from "./htlc.js";
|
|
6
|
+
export { multisigLock } from "./multisig.js";
|
|
7
|
+
export { witnessFromLock, witnessNew, lockMerkleProofFromLock, witnessFromLockMerkleProof, witnessClearSignatures, witnessWithPkhSignature, witnessWithHaxPreimage, spendV1FromLock, spendConditionFromWitness, } from "./witness.js";
|
|
8
|
+
export { applyWitness, splitWitness } from "./spends.js";
|
|
9
|
+
export function txEngineSettingsV1Default() {
|
|
10
|
+
return {
|
|
11
|
+
tx_engine_version: 1,
|
|
12
|
+
tx_engine_patch: 0,
|
|
13
|
+
min_fee: "256",
|
|
14
|
+
cost_per_word: "32768",
|
|
15
|
+
witness_word_div: 1,
|
|
16
|
+
};
|
|
17
|
+
}
|
|
18
|
+
export function txEngineSettingsV1BythosDefault() {
|
|
19
|
+
return {
|
|
20
|
+
tx_engine_version: 1,
|
|
21
|
+
tx_engine_patch: 1,
|
|
22
|
+
min_fee: "256",
|
|
23
|
+
cost_per_word: "16384",
|
|
24
|
+
witness_word_div: 4,
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
export { rawTxV1InputNames, rawTxV1InputSpendConditions, rawTxV1New, rawTxV1Version, spendV1Fee, spendV1TotalGifts, spendV1UnclampedFee, spendsV1Fee, spendsV1TotalFees, spendsV1TotalGifts, spendsV1UnclampedFee, } from "./accessors.js";
|
|
28
|
+
export { spendV1NewWitness, spendV1NewLegacy, spendV1SigHash } from "./spend.js";
|
|
29
|
+
export function spendsV1ApplyWitness(spends, witnessData) {
|
|
30
|
+
return applyWitness(spends, witnessData);
|
|
31
|
+
}
|
|
32
|
+
export function nockchainTxToRawTx(tx) {
|
|
33
|
+
const spends = applyWitness(tx.spends, tx.witness_data);
|
|
34
|
+
const id = calcId({ version: 1, id: "", spends });
|
|
35
|
+
return { version: 1, id, spends };
|
|
36
|
+
}
|
|
37
|
+
export function rawTxV1ToNockchainTx(raw) {
|
|
38
|
+
const { spends, witnessData } = splitWitness(raw.spends);
|
|
39
|
+
const id = calcId({ version: 1, id: "", spends });
|
|
40
|
+
return {
|
|
41
|
+
version: 1,
|
|
42
|
+
id,
|
|
43
|
+
spends,
|
|
44
|
+
display: { inputs: { tag: 0, inputs: [] }, outputs: [] },
|
|
45
|
+
witness_data: witnessData,
|
|
46
|
+
};
|
|
47
|
+
}
|
|
48
|
+
export function rawTxV1Outputs(obj, originPage, settings) {
|
|
49
|
+
return outputs(obj, originPage, settings);
|
|
50
|
+
}
|
|
51
|
+
export function rawTxTotalFees(obj) {
|
|
52
|
+
let total = 0n;
|
|
53
|
+
for (const [, spend] of obj.spends) {
|
|
54
|
+
total += BigInt(spend.fee);
|
|
55
|
+
}
|
|
56
|
+
return String(total);
|
|
57
|
+
}
|
|
58
|
+
export function rawTxV1CalcId(obj) {
|
|
59
|
+
return calcId(obj);
|
|
60
|
+
}
|
|
61
|
+
export function nockchainTxOutputs(tx, originPage, settings) {
|
|
62
|
+
return outputs(nockchainTxToRawTx(tx), originPage, settings);
|
|
63
|
+
}
|
|
64
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/tx/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"multisig.d.ts","sourceRoot":"","sources":["../../src/tx/multisig.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,aAAa,CAAC;AAIhD,wBAAgB,YAAY,CAAC,CAAC,EAAE,MAAM,EAAE,UAAU,EAAE,SAAS,MAAM,EAAE,GAAG,IAAI,CAK3E"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { lockFromList, pkhNew, spendConditionNewPkh } from "../hash/index.js";
|
|
2
|
+
export function multisigLock(m, pkhDigests) {
|
|
3
|
+
if (m < 1 || m > pkhDigests.length) {
|
|
4
|
+
throw new Error(`invalid multisig m=${m} of n=${pkhDigests.length}`);
|
|
5
|
+
}
|
|
6
|
+
return lockFromList([spendConditionNewPkh(pkhNew(m, [...pkhDigests]))]);
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=multisig.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"multisig.js","sourceRoot":"","sources":["../../src/tx/multisig.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAC;AAG9E,MAAM,UAAU,YAAY,CAAC,CAAS,EAAE,UAA6B;IACnE,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC;QACnC,MAAM,IAAI,KAAK,CAAC,sBAAsB,CAAC,SAAS,UAAU,CAAC,MAAM,EAAE,CAAC,CAAC;IACvE,CAAC;IACD,OAAO,YAAY,CAAC,CAAC,oBAAoB,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAC1E,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"outputs.d.ts","sourceRoot":"","sources":["../../src/tx/outputs.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAIV,IAAI,EAGJ,OAAO,EAGP,gBAAgB,EACjB,MAAM,aAAa,CAAC;AAsBrB,wBAAgB,cAAc,CAC5B,GAAG,EAAE,OAAO,EACZ,UAAU,EAAE,MAAM,EAClB,QAAQ,EAAE,gBAAgB,GACzB,IAAI,EAAE,CAuCR"}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import { mustAt } from "../core/must.js";
|
|
2
|
+
import { hashSeedV1, hashSeedsV1Digest } from "../hash/tx.js";
|
|
3
|
+
import { hashToDigest } from "../core/hashable.js";
|
|
4
|
+
import { hashZSetSingleton } from "../core/zbase.js";
|
|
5
|
+
import { lockRootHash } from "../hash/index.js";
|
|
6
|
+
import { nameV1 } from "../hash/note.js";
|
|
7
|
+
function normalizedSeed(seed) {
|
|
8
|
+
return { ...seed, output_source: null };
|
|
9
|
+
}
|
|
10
|
+
function mergeNoteData(entries) {
|
|
11
|
+
const map = new Map();
|
|
12
|
+
for (const data of entries) {
|
|
13
|
+
for (const [k, v] of data)
|
|
14
|
+
map.set(k, v);
|
|
15
|
+
}
|
|
16
|
+
return [...map.entries()];
|
|
17
|
+
}
|
|
18
|
+
function hashNormalizedSeedSet(seeds) {
|
|
19
|
+
const normalized = seeds.map(normalizedSeed);
|
|
20
|
+
if (normalized.length === 1) {
|
|
21
|
+
return hashToDigest(hashZSetSingleton(mustAt(normalized, 0), hashSeedV1));
|
|
22
|
+
}
|
|
23
|
+
return hashSeedsV1Digest(normalized);
|
|
24
|
+
}
|
|
25
|
+
export function rawTxV1Outputs(obj, originPage, settings) {
|
|
26
|
+
const seedsByLock = new Map();
|
|
27
|
+
for (const [, spend] of obj.spends) {
|
|
28
|
+
const seeds = spend.tag === 1 ? spend.seeds : spend.seeds;
|
|
29
|
+
for (const seed of seeds) {
|
|
30
|
+
const key = lockRootHash(seed.lock_root);
|
|
31
|
+
const list = seedsByLock.get(key) ?? [];
|
|
32
|
+
list.push(seed);
|
|
33
|
+
seedsByLock.set(key, list);
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
const outputs = [];
|
|
37
|
+
for (const [lockRootHashKey, seeds] of seedsByLock) {
|
|
38
|
+
if (seeds.length === 0)
|
|
39
|
+
continue;
|
|
40
|
+
const totalAssets = seeds.reduce((acc, s) => acc + BigInt(s.gift), 0n);
|
|
41
|
+
const noteData = settings.tx_engine_patch >= 1
|
|
42
|
+
? mergeNoteData(seeds.map((s) => s.note_data))
|
|
43
|
+
: mustAt(seeds, 0).note_data;
|
|
44
|
+
const srcSetHash = hashNormalizedSeedSet(seeds);
|
|
45
|
+
const src = { hash: srcSetHash, is_coinbase: false };
|
|
46
|
+
const name = nameV1(lockRootHashKey, src);
|
|
47
|
+
outputs.push({
|
|
48
|
+
version: 1,
|
|
49
|
+
origin_page: originPage,
|
|
50
|
+
name,
|
|
51
|
+
note_data: noteData,
|
|
52
|
+
assets: String(totalAssets),
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
return outputs;
|
|
56
|
+
}
|
|
57
|
+
//# sourceMappingURL=outputs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"outputs.js","sourceRoot":"","sources":["../../src/tx/outputs.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { Nicks, SpendV1, SeedsV1, Witness } from "../types.js";
|
|
2
|
+
import type { Digest } from "../types.js";
|
|
3
|
+
export type LegacySignature = [string, {
|
|
4
|
+
c: string;
|
|
5
|
+
s: string;
|
|
6
|
+
}][];
|
|
7
|
+
export declare function spendV1NewWitness(witness: Witness, seeds: SeedsV1, fee: Nicks): SpendV1;
|
|
8
|
+
export declare function spendV1NewLegacy(seeds: SeedsV1, fee: Nicks): SpendV1;
|
|
9
|
+
export declare function spendV1SigHash(spend: SpendV1): Digest;
|
|
10
|
+
//# sourceMappingURL=spend.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"spend.d.ts","sourceRoot":"","sources":["../../src/tx/spend.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAY,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAI9E,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAE1C,MAAM,MAAM,eAAe,GAAG,CAAC,MAAM,EAAE;IAAE,CAAC,EAAE,MAAM,CAAC;IAAC,CAAC,EAAE,MAAM,CAAA;CAAE,CAAC,EAAE,CAAC;AAEnE,wBAAgB,iBAAiB,CAAC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,GAAG,EAAE,KAAK,GAAG,OAAO,CAGvF;AAED,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,OAAO,EAAE,GAAG,EAAE,KAAK,GAAG,OAAO,CAEpE;AAGD,wBAAgB,cAAc,CAAC,KAAK,EAAE,OAAO,GAAG,MAAM,CAOrD"}
|
package/dist/tx/spend.js
ADDED
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { digestFromBase58 } from "../core/digest.js";
|
|
2
|
+
import { hashNicks, hashToDigest, hashTuple } from "../core/hashable.js";
|
|
3
|
+
import { hashSpendV1SigHash, seedsV1SigHash } from "../hash/tx.js";
|
|
4
|
+
export function spendV1NewWitness(witness, seeds, fee) {
|
|
5
|
+
const spend = { witness, seeds, fee };
|
|
6
|
+
return { tag: 1, ...spend };
|
|
7
|
+
}
|
|
8
|
+
export function spendV1NewLegacy(seeds, fee) {
|
|
9
|
+
return { tag: 0, signature: [], seeds, fee };
|
|
10
|
+
}
|
|
11
|
+
export function spendV1SigHash(spend) {
|
|
12
|
+
if (spend.tag === 1) {
|
|
13
|
+
return hashSpendV1SigHash(spend);
|
|
14
|
+
}
|
|
15
|
+
return hashToDigest(hashTuple(digestFromBase58(seedsV1SigHash(spend.seeds)), hashNicks(spend.fee)));
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=spend.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"spend.js","sourceRoot":"","sources":["../../src/tx/spend.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AACrD,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AACzE,OAAO,EAAE,kBAAkB,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAKnE,MAAM,UAAU,iBAAiB,CAAC,OAAgB,EAAE,KAAc,EAAE,GAAU;IAC5E,MAAM,KAAK,GAAa,EAAE,OAAO,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC;IAChD,OAAO,EAAE,GAAG,EAAE,CAAC,EAAE,GAAG,KAAK,EAAE,CAAC;AAC9B,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,KAAc,EAAE,GAAU;IACzD,OAAO,EAAE,GAAG,EAAE,CAAC,EAAE,SAAS,EAAE,EAAqB,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC;AAClE,CAAC;AAGD,MAAM,UAAU,cAAc,CAAC,KAAc;IAC3C,IAAI,KAAK,CAAC,GAAG,KAAK,CAAC,EAAE,CAAC;QACpB,OAAO,kBAAkB,CAAC,KAAK,CAAC,CAAC;IACnC,CAAC;IACD,OAAO,YAAY,CACjB,SAAS,CAAC,gBAAgB,CAAC,cAAc,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAC/E,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { Name, NockchainTx, SpendsV1, WitnessData } from "../types.js";
|
|
2
|
+
export declare function nameKey(name: Name): string;
|
|
3
|
+
export declare function splitWitness(spends: SpendsV1): {
|
|
4
|
+
spends: SpendsV1;
|
|
5
|
+
witnessData: WitnessData;
|
|
6
|
+
};
|
|
7
|
+
export declare function applyWitness(spends: SpendsV1, witnessData: NockchainTx["witness_data"]): SpendsV1;
|
|
8
|
+
//# sourceMappingURL=spends.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"spends.d.ts","sourceRoot":"","sources":["../../src/tx/spends.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,WAAW,EAAW,QAAQ,EAAW,WAAW,EAAE,MAAM,aAAa,CAAC;AAE9F,wBAAgB,OAAO,CAAC,IAAI,EAAE,IAAI,GAAG,MAAM,CAE1C;AAqBD,wBAAgB,YAAY,CAAC,MAAM,EAAE,QAAQ,GAAG;IAAE,MAAM,EAAE,QAAQ,CAAC;IAAC,WAAW,EAAE,WAAW,CAAA;CAAE,CAe7F;AAED,wBAAgB,YAAY,CAC1B,MAAM,EAAE,QAAQ,EAChB,WAAW,EAAE,WAAW,CAAC,cAAc,CAAC,GACvC,QAAQ,CAYV"}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
export function nameKey(name) {
|
|
2
|
+
return `${name.first}:${name.last}:${name._sig ?? 0}`;
|
|
3
|
+
}
|
|
4
|
+
function cloneWitness(w) {
|
|
5
|
+
return {
|
|
6
|
+
lock_merkle_proof: w.lock_merkle_proof,
|
|
7
|
+
pkh_signature: Array.isArray(w.pkh_signature) ? [...w.pkh_signature] : [],
|
|
8
|
+
hax_map: Array.isArray(w.hax_map) ? [...w.hax_map] : [],
|
|
9
|
+
tim: w.tim ?? null,
|
|
10
|
+
};
|
|
11
|
+
}
|
|
12
|
+
function stripWitness(w) {
|
|
13
|
+
return {
|
|
14
|
+
lock_merkle_proof: w.lock_merkle_proof,
|
|
15
|
+
pkh_signature: [],
|
|
16
|
+
hax_map: [],
|
|
17
|
+
tim: null,
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
export function splitWitness(spends) {
|
|
21
|
+
const outSpends = [];
|
|
22
|
+
const data = [];
|
|
23
|
+
for (const [name, spend] of spends) {
|
|
24
|
+
if (spend.tag !== 1) {
|
|
25
|
+
outSpends.push([name, spend]);
|
|
26
|
+
continue;
|
|
27
|
+
}
|
|
28
|
+
const witness = cloneWitness(spend.witness);
|
|
29
|
+
outSpends.push([name, { ...spend, witness: stripWitness(witness) }]);
|
|
30
|
+
data.push([name, witness]);
|
|
31
|
+
}
|
|
32
|
+
return { spends: outSpends, witnessData: { data } };
|
|
33
|
+
}
|
|
34
|
+
export function applyWitness(spends, witnessData) {
|
|
35
|
+
const witnessByName = new Map();
|
|
36
|
+
for (const [name, witness] of witnessData.data) {
|
|
37
|
+
witnessByName.set(nameKey(name), witness);
|
|
38
|
+
}
|
|
39
|
+
return spends.map(([name, spend]) => {
|
|
40
|
+
if (spend.tag !== 1)
|
|
41
|
+
return [name, spend];
|
|
42
|
+
const witness = witnessByName.get(nameKey(name));
|
|
43
|
+
if (!witness)
|
|
44
|
+
return [name, spend];
|
|
45
|
+
return [name, { ...spend, witness: cloneWitness(witness) }];
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
//# sourceMappingURL=spends.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"spends.js","sourceRoot":"","sources":["../../src/tx/spends.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,OAAO,CAAC,IAAU;IAChC,OAAO,GAAG,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,IAAI,CAAC,EAAE,CAAC;AACxD,CAAC;AAED,SAAS,YAAY,CAAC,CAAU;IAC9B,OAAO;QACL,iBAAiB,EAAE,CAAC,CAAC,iBAAiB;QACtC,aAAa,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,EAAE;QACzE,OAAO,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE;QACvD,GAAG,EAAE,CAAC,CAAC,GAAG,IAAI,IAAI;KACnB,CAAC;AACJ,CAAC;AAED,SAAS,YAAY,CAAC,CAAU;IAC9B,OAAO;QACL,iBAAiB,EAAE,CAAC,CAAC,iBAAiB;QACtC,aAAa,EAAE,EAAE;QACjB,OAAO,EAAE,EAAE;QACX,GAAG,EAAE,IAAI;KACV,CAAC;AACJ,CAAC;AAGD,MAAM,UAAU,YAAY,CAAC,MAAgB;IAC3C,MAAM,SAAS,GAAa,EAAE,CAAC;IAC/B,MAAM,IAAI,GAAsB,EAAE,CAAC;IAEnC,KAAK,MAAM,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,MAAM,EAAE,CAAC;QACnC,IAAI,KAAK,CAAC,GAAG,KAAK,CAAC,EAAE,CAAC;YACpB,SAAS,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC;YAC9B,SAAS;QACX,CAAC;QACD,MAAM,OAAO,GAAG,YAAY,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QAC5C,SAAS,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,GAAG,KAAK,EAAE,OAAO,EAAE,YAAY,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC;QACrE,IAAI,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC;IAC7B,CAAC;IAED,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,WAAW,EAAE,EAAE,IAAI,EAAE,EAAE,CAAC;AACtD,CAAC;AAED,MAAM,UAAU,YAAY,CAC1B,MAAgB,EAChB,WAAwC;IAExC,MAAM,aAAa,GAAG,IAAI,GAAG,EAAmB,CAAC;IACjD,KAAK,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,IAAI,WAAW,CAAC,IAAI,EAAE,CAAC;QAC/C,aAAa,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,OAAO,CAAC,CAAC;IAC5C,CAAC;IAED,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,KAAK,CAAC,EAAE,EAAE;QAClC,IAAI,KAAK,CAAC,GAAG,KAAK,CAAC;YAAE,OAAO,CAAC,IAAI,EAAE,KAAK,CAAoB,CAAC;QAC7D,MAAM,OAAO,GAAG,aAAa,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC;QACjD,IAAI,CAAC,OAAO;YAAE,OAAO,CAAC,IAAI,EAAE,KAAK,CAAoB,CAAC;QACtD,OAAO,CAAC,IAAI,EAAE,EAAE,GAAG,KAAK,EAAE,OAAO,EAAE,YAAY,CAAC,OAAO,CAAC,EAAE,CAAoB,CAAC;IACjF,CAAC,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/tx/types.ts"],"names":[],"mappings":"AACA,MAAM,WAAW,cAAc;IAC7B,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;CACf"}
|
package/dist/tx/types.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/tx/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { MissingUnlocks, SpendV1, TxEngineSettings } from "../types.js";
|
|
2
|
+
export declare function computeMissingUnlocks(spend: SpendV1): MissingUnlocks[];
|
|
3
|
+
export declare function missingUnlocksFee(spend: SpendV1, settings: TxEngineSettings): bigint;
|
|
4
|
+
//# sourceMappingURL=unlocks.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"unlocks.d.ts","sourceRoot":"","sources":["../../src/tx/unlocks.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAU,cAAc,EAA4B,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAe/G,wBAAgB,qBAAqB,CAAC,KAAK,EAAE,OAAO,GAAG,cAAc,EAAE,CAkCtE;AAGD,wBAAgB,iBAAiB,CAAC,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,gBAAgB,GAAG,MAAM,CAUpF"}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
function spendConditionPkh(sc) {
|
|
2
|
+
return sc.filter((p) => p.tag === "pkh");
|
|
3
|
+
}
|
|
4
|
+
function spendConditionHax(sc) {
|
|
5
|
+
return sc.filter((p) => p.tag === "hax");
|
|
6
|
+
}
|
|
7
|
+
function spendConditionBrn(sc) {
|
|
8
|
+
return sc.some((p) => p.tag === "brn");
|
|
9
|
+
}
|
|
10
|
+
export function computeMissingUnlocks(spend) {
|
|
11
|
+
if (spend.tag !== 1)
|
|
12
|
+
return [];
|
|
13
|
+
const s = spend;
|
|
14
|
+
const missing = [];
|
|
15
|
+
const presentSigs = new Set((Array.isArray(s.witness.pkh_signature) ? s.witness.pkh_signature : []).map(([pkh]) => pkh));
|
|
16
|
+
const sc = s.witness.lock_merkle_proof.spend_condition;
|
|
17
|
+
for (const p of spendConditionPkh(sc)) {
|
|
18
|
+
const hashes = Array.isArray(p.hashes) ? p.hashes : [];
|
|
19
|
+
const checked = hashes.filter((h) => presentSigs.has(h));
|
|
20
|
+
if (checked.length < p.m) {
|
|
21
|
+
const sigOf = hashes.filter((h) => !presentSigs.has(h));
|
|
22
|
+
missing.push({ Pkh: { num_sigs: p.m - checked.length, sig_of: sigOf } });
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
for (const h of spendConditionHax(sc)) {
|
|
26
|
+
const valid = new Set(Array.isArray(h.preimages) ? h.preimages : []);
|
|
27
|
+
const current = new Set((Array.isArray(s.witness.hax_map) ? s.witness.hax_map : []).map(([digest]) => digest));
|
|
28
|
+
const preimagesFor = [...valid].filter((d) => !current.has(d));
|
|
29
|
+
if (preimagesFor.length > 0) {
|
|
30
|
+
missing.push({ Hax: { preimages_for: preimagesFor } });
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
if (spendConditionBrn(sc)) {
|
|
34
|
+
missing.push("Brn");
|
|
35
|
+
}
|
|
36
|
+
return missing;
|
|
37
|
+
}
|
|
38
|
+
export function missingUnlocksFee(spend, settings) {
|
|
39
|
+
let fee = 0n;
|
|
40
|
+
for (const mu of computeMissingUnlocks(spend)) {
|
|
41
|
+
if (typeof mu === "object" && "Pkh" in mu) {
|
|
42
|
+
fee +=
|
|
43
|
+
(BigInt(settings.cost_per_word) * 35n * BigInt(mu.Pkh.num_sigs)) /
|
|
44
|
+
BigInt(settings.witness_word_div);
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
return fee;
|
|
48
|
+
}
|
|
49
|
+
//# sourceMappingURL=unlocks.js.map
|