@bsv/templates 1.4.1 → 1.6.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/dist/cjs/mod.js +5 -1
- package/dist/cjs/mod.js.map +1 -1
- package/dist/cjs/package.json +14 -7
- package/dist/cjs/src/MandalaAdmin.js +84 -0
- package/dist/cjs/src/MandalaAdmin.js.map +1 -0
- package/dist/cjs/src/MandalaToken.js +84 -0
- package/dist/cjs/src/MandalaToken.js.map +1 -0
- package/dist/cjs/src/MultiPushDrop.js +4 -21
- package/dist/cjs/src/MultiPushDrop.js.map +1 -1
- package/dist/cjs/src/mandala-encoding.js +82 -0
- package/dist/cjs/src/mandala-encoding.js.map +1 -0
- package/dist/cjs/src/mandala-signing.js +43 -0
- package/dist/cjs/src/mandala-signing.js.map +1 -0
- package/dist/cjs/tsconfig.cjs.tsbuildinfo +1 -1
- package/dist/esm/mod.js +2 -0
- package/dist/esm/mod.js.map +1 -1
- package/dist/esm/src/MandalaAdmin.js +81 -0
- package/dist/esm/src/MandalaAdmin.js.map +1 -0
- package/dist/esm/src/MandalaToken.js +81 -0
- package/dist/esm/src/MandalaToken.js.map +1 -0
- package/dist/esm/src/MultiPushDrop.js +1 -18
- package/dist/esm/src/MultiPushDrop.js.map +1 -1
- package/dist/esm/src/mandala-encoding.js +72 -0
- package/dist/esm/src/mandala-encoding.js.map +1 -0
- package/dist/esm/src/mandala-signing.js +39 -0
- package/dist/esm/src/mandala-signing.js.map +1 -0
- package/dist/esm/tsconfig.esm.tsbuildinfo +1 -1
- package/dist/types/mod.d.ts +4 -0
- package/dist/types/mod.d.ts.map +1 -1
- package/dist/types/src/MandalaAdmin.d.ts +27 -0
- package/dist/types/src/MandalaAdmin.d.ts.map +1 -0
- package/dist/types/src/MandalaToken.d.ts +16 -0
- package/dist/types/src/MandalaToken.d.ts.map +1 -0
- package/dist/types/src/MultiPushDrop.d.ts.map +1 -1
- package/dist/types/src/mandala-encoding.d.ts +10 -0
- package/dist/types/src/mandala-encoding.d.ts.map +1 -0
- package/dist/types/src/mandala-signing.d.ts +10 -0
- package/dist/types/src/mandala-signing.d.ts.map +1 -0
- package/dist/types/tsconfig.types.tsbuildinfo +1 -1
- package/mod.ts +4 -0
- package/package.json +14 -7
- package/src/MandalaAdmin.ts +107 -0
- package/src/MandalaToken.ts +102 -0
- package/src/MultiPushDrop.ts +1 -14
- package/src/__tests/MandalaAdmin.derive.test.ts +34 -0
- package/src/__tests/MandalaAdmin.script.test.ts +26 -0
- package/src/__tests/MandalaToken.test.ts +43 -0
- package/src/__tests/MandalaToken.unlock.test.ts +31 -0
- package/src/__tests/exports.test.ts +9 -0
- package/src/__tests/mandala-encoding.test.ts +32 -0
- package/src/mandala-encoding.ts +64 -0
- package/src/mandala-signing.ts +41 -0
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
import { Hash, Utils, LockingScript, UnlockingScript, OP, TransactionSignature, Signature } from '@bsv/sdk';
|
|
2
|
+
import { createMinimallyEncodedScriptChunk, MARKER } from './mandala-encoding.js';
|
|
3
|
+
import { buildSighashPreimage } from './mandala-signing.js';
|
|
4
|
+
const canon = (value) => {
|
|
5
|
+
if (value === null || typeof value !== 'object')
|
|
6
|
+
return JSON.stringify(value);
|
|
7
|
+
if (Array.isArray(value))
|
|
8
|
+
return '[' + value.map(canon).join(',') + ']';
|
|
9
|
+
const keys = Object.keys(value).sort((a, b) => {
|
|
10
|
+
if (a < b)
|
|
11
|
+
return -1;
|
|
12
|
+
if (a > b)
|
|
13
|
+
return 1;
|
|
14
|
+
return 0;
|
|
15
|
+
});
|
|
16
|
+
return '{' + keys.map(k => JSON.stringify(k) + ':' + canon(value[k])).join(',') + '}';
|
|
17
|
+
};
|
|
18
|
+
export class MandalaAdmin {
|
|
19
|
+
wallet;
|
|
20
|
+
originator;
|
|
21
|
+
constructor(wallet, originator) {
|
|
22
|
+
this.wallet = wallet;
|
|
23
|
+
this.originator = originator;
|
|
24
|
+
}
|
|
25
|
+
static canonicalize(actionDetails) {
|
|
26
|
+
return canon(actionDetails);
|
|
27
|
+
}
|
|
28
|
+
static commitment(actionDetails) {
|
|
29
|
+
return Utils.toHex(Hash.sha256(Utils.toArray(MandalaAdmin.canonicalize(actionDetails), 'utf8')));
|
|
30
|
+
}
|
|
31
|
+
async deriveBoundKey(protocolID, actionDetails) {
|
|
32
|
+
const keyID = MandalaAdmin.commitment(actionDetails);
|
|
33
|
+
const { publicKey } = await this.wallet.getPublicKey({ protocolID, keyID, counterparty: 'anyone' }, this.originator);
|
|
34
|
+
return { boundKey: publicKey, keyID };
|
|
35
|
+
}
|
|
36
|
+
lock(boundKey) {
|
|
37
|
+
const keyBytes = Utils.toArray(boundKey, 'hex');
|
|
38
|
+
if (keyBytes.length !== 33)
|
|
39
|
+
throw new Error('boundKey must be a 33-byte compressed public key');
|
|
40
|
+
return new LockingScript([
|
|
41
|
+
createMinimallyEncodedScriptChunk([MARKER]),
|
|
42
|
+
{ op: OP.OP_DROP },
|
|
43
|
+
{ op: keyBytes.length, data: keyBytes },
|
|
44
|
+
{ op: OP.OP_CHECKSIG }
|
|
45
|
+
]);
|
|
46
|
+
}
|
|
47
|
+
static decode(script) {
|
|
48
|
+
const c = script.chunks;
|
|
49
|
+
if (c.length !== 4)
|
|
50
|
+
throw new Error('not a MandalaAdmin script: wrong chunk count');
|
|
51
|
+
const marker = c[0].data ?? [];
|
|
52
|
+
if (c[0].op !== 1 || marker.length !== 1 || marker[0] !== MARKER)
|
|
53
|
+
throw new Error('not a MandalaAdmin script: missing marker');
|
|
54
|
+
if (c[1].op !== OP.OP_DROP || c[3].op !== OP.OP_CHECKSIG)
|
|
55
|
+
throw new Error('not a MandalaAdmin script: bad shape');
|
|
56
|
+
const keyData = c[2].data;
|
|
57
|
+
if (keyData?.length !== 33)
|
|
58
|
+
throw new Error('not a MandalaAdmin script: bad boundKey');
|
|
59
|
+
return { boundKey: Utils.toHex(keyData) };
|
|
60
|
+
}
|
|
61
|
+
unlock(protocolID, actionDetails, signOutputs = 'all', anyoneCanPay = false) {
|
|
62
|
+
return {
|
|
63
|
+
sign: async (tx, inputIndex) => {
|
|
64
|
+
const { preimage, scope } = buildSighashPreimage(tx, inputIndex, signOutputs, anyoneCanPay);
|
|
65
|
+
const keyID = MandalaAdmin.commitment(actionDetails);
|
|
66
|
+
const { signature: bareSignature } = await this.wallet.createSignature({
|
|
67
|
+
hashToDirectlySign: Hash.hash256(preimage),
|
|
68
|
+
protocolID,
|
|
69
|
+
keyID,
|
|
70
|
+
counterparty: 'anyone'
|
|
71
|
+
}, this.originator);
|
|
72
|
+
const signature = Signature.fromDER([...bareSignature]);
|
|
73
|
+
const txSignature = new TransactionSignature(signature.r, signature.s, scope);
|
|
74
|
+
const sigForScript = txSignature.toChecksigFormat();
|
|
75
|
+
return new UnlockingScript([{ op: sigForScript.length, data: sigForScript }]);
|
|
76
|
+
},
|
|
77
|
+
estimateLength: async (_tx, _inputIndex) => 74
|
|
78
|
+
};
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
//# sourceMappingURL=MandalaAdmin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MandalaAdmin.js","sourceRoot":"","sources":["../../../src/MandalaAdmin.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
import { LockingScript, UnlockingScript, OP, Utils, Hash, TransactionSignature } from '@bsv/sdk';
|
|
2
|
+
import { createMinimallyEncodedScriptChunk, encodeScriptNum, decodeScriptNum, encodeAssetId, decodeAssetId, MARKER } from './mandala-encoding.js';
|
|
3
|
+
import { buildSighashPreimage } from './mandala-signing.js';
|
|
4
|
+
// Local helper since Utils.verifyTruthy is not available in @bsv/sdk
|
|
5
|
+
const vt = (v) => {
|
|
6
|
+
if (v == null)
|
|
7
|
+
throw new Error('missing chunk data');
|
|
8
|
+
return v;
|
|
9
|
+
};
|
|
10
|
+
export class MandalaToken {
|
|
11
|
+
wallet;
|
|
12
|
+
originator;
|
|
13
|
+
constructor(wallet, originator) {
|
|
14
|
+
this.wallet = wallet;
|
|
15
|
+
this.originator = originator;
|
|
16
|
+
}
|
|
17
|
+
async lockBRC29(assetId, amount, protocolID, keyID, counterparty) {
|
|
18
|
+
if (this.wallet == null)
|
|
19
|
+
throw new Error('lockBRC29 requires a wallet');
|
|
20
|
+
const { publicKey } = await this.wallet.getPublicKey({ protocolID, keyID, counterparty }, this.originator);
|
|
21
|
+
const pubKeyHash = Hash.hash160(Utils.toArray(publicKey, 'hex'));
|
|
22
|
+
return this.lock(assetId, amount, pubKeyHash);
|
|
23
|
+
}
|
|
24
|
+
lock(assetId, amount, pubKeyHash) {
|
|
25
|
+
if (pubKeyHash.length !== 20)
|
|
26
|
+
throw new Error('pubKeyHash must be 20 bytes');
|
|
27
|
+
if (!Number.isInteger(amount) || amount < 1)
|
|
28
|
+
throw new Error('amount must be a positive integer');
|
|
29
|
+
const assetIdBytes = encodeAssetId(assetId);
|
|
30
|
+
return new LockingScript([
|
|
31
|
+
createMinimallyEncodedScriptChunk([MARKER]),
|
|
32
|
+
createMinimallyEncodedScriptChunk(assetIdBytes),
|
|
33
|
+
createMinimallyEncodedScriptChunk(encodeScriptNum(amount)),
|
|
34
|
+
{ op: OP.OP_2DROP },
|
|
35
|
+
{ op: OP.OP_DROP },
|
|
36
|
+
{ op: OP.OP_DUP },
|
|
37
|
+
{ op: OP.OP_HASH160 },
|
|
38
|
+
{ op: pubKeyHash.length, data: pubKeyHash },
|
|
39
|
+
{ op: OP.OP_EQUALVERIFY },
|
|
40
|
+
{ op: OP.OP_CHECKSIG }
|
|
41
|
+
]);
|
|
42
|
+
}
|
|
43
|
+
unlock(privateKey, signOutputs = 'all', anyoneCanPay = false) {
|
|
44
|
+
return {
|
|
45
|
+
sign: async (tx, inputIndex) => {
|
|
46
|
+
const { preimage, scope } = buildSighashPreimage(tx, inputIndex, signOutputs, anyoneCanPay);
|
|
47
|
+
const rawSignature = privateKey.sign(Hash.sha256(preimage));
|
|
48
|
+
const sig = new TransactionSignature(rawSignature.r, rawSignature.s, scope);
|
|
49
|
+
const sigForScript = sig.toChecksigFormat();
|
|
50
|
+
const pubkeyForScript = privateKey.toPublicKey().encode(true);
|
|
51
|
+
return new UnlockingScript([
|
|
52
|
+
{ op: sigForScript.length, data: sigForScript },
|
|
53
|
+
{ op: pubkeyForScript.length, data: pubkeyForScript }
|
|
54
|
+
]);
|
|
55
|
+
},
|
|
56
|
+
estimateLength: async (tx, inputIndex) => 108
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
static decode(script) {
|
|
60
|
+
const c = script.chunks;
|
|
61
|
+
if (c.length !== 10)
|
|
62
|
+
throw new Error('not a MandalaToken script: wrong chunk count');
|
|
63
|
+
const marker = c[0].data ?? [];
|
|
64
|
+
if (c[0].op !== 1 || marker.length !== 1 || marker[0] !== MARKER)
|
|
65
|
+
throw new Error('not a MandalaToken script: missing marker');
|
|
66
|
+
if (c[3].op !== OP.OP_2DROP || c[4].op !== OP.OP_DROP)
|
|
67
|
+
throw new Error('not a MandalaToken script: bad drops');
|
|
68
|
+
if (c[5].op !== OP.OP_DUP || c[6].op !== OP.OP_HASH160 || c[8].op !== OP.OP_EQUALVERIFY || c[9].op !== OP.OP_CHECKSIG) {
|
|
69
|
+
throw new Error('not a MandalaToken script: bad P2PKH tail');
|
|
70
|
+
}
|
|
71
|
+
const assetId = decodeAssetId(vt(c[1].data));
|
|
72
|
+
const amount = decodeScriptNum(c[2].data ?? []);
|
|
73
|
+
if (!Number.isInteger(amount) || amount < 1)
|
|
74
|
+
throw new Error('not a MandalaToken script: bad amount');
|
|
75
|
+
const pubKeyHash = vt(c[7].data);
|
|
76
|
+
if (pubKeyHash.length !== 20)
|
|
77
|
+
throw new Error('not a MandalaToken script: bad pubKeyHash');
|
|
78
|
+
return { assetId, amount, pubKeyHash };
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
//# sourceMappingURL=MandalaToken.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MandalaToken.js","sourceRoot":"","sources":["../../../src/MandalaToken.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,28 +1,11 @@
|
|
|
1
1
|
import { LockingScript, UnlockingScript, OP, Utils, Hash, TransactionSignature, Signature } from '@bsv/sdk';
|
|
2
|
+
import { createMinimallyEncodedScriptChunk } from './mandala-encoding.js';
|
|
2
3
|
// Helper to ensure a value is not null or undefined
|
|
3
4
|
function verifyTruthy(v, err) {
|
|
4
5
|
if (v === null || v === undefined)
|
|
5
6
|
throw new Error(err || 'Value must not be null or undefined');
|
|
6
7
|
return v;
|
|
7
8
|
}
|
|
8
|
-
// Helper to create minimally encoded script chunks (same as in PushDrop)
|
|
9
|
-
const createMinimallyEncodedScriptChunk = (data) => {
|
|
10
|
-
if (data.length === 0)
|
|
11
|
-
return { op: 0 }; // OP_0
|
|
12
|
-
if (data.length === 1 && data[0] === 0)
|
|
13
|
-
return { op: 0 }; // OP_0
|
|
14
|
-
if (data.length === 1 && data[0] > 0 && data[0] <= 16)
|
|
15
|
-
return { op: 0x50 + data[0] }; // OP_1 to OP_16
|
|
16
|
-
if (data.length === 1 && data[0] === 0x81)
|
|
17
|
-
return { op: 0x4f }; // OP_1NEGATE
|
|
18
|
-
if (data.length <= 75)
|
|
19
|
-
return { op: data.length, data };
|
|
20
|
-
if (data.length <= 255)
|
|
21
|
-
return { op: 0x4c, data }; // OP_PUSHDATA1
|
|
22
|
-
if (data.length <= 65535)
|
|
23
|
-
return { op: 0x4d, data }; // OP_PUSHDATA2
|
|
24
|
-
return { op: 0x4e, data }; // OP_PUSHDATA4
|
|
25
|
-
};
|
|
26
9
|
/**
|
|
27
10
|
* MultiPushDrop Script Template
|
|
28
11
|
*
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MultiPushDrop.js","sourceRoot":"","sources":["../../../src/MultiPushDrop.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,aAAa,EACb,eAAe,EACf,EAAE,EAEF,KAAK,EACL,IAAI,EACJ,oBAAoB,EACpB,SAAS,EAIV,MAAM,UAAU,CAAA;
|
|
1
|
+
{"version":3,"file":"MultiPushDrop.js","sourceRoot":"","sources":["../../../src/MultiPushDrop.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
import { Utils } from '@bsv/sdk';
|
|
2
|
+
export const MARKER = 0x21;
|
|
3
|
+
export const createMinimallyEncodedScriptChunk = (data) => {
|
|
4
|
+
if (data.length === 0)
|
|
5
|
+
return { op: 0 };
|
|
6
|
+
if (data.length === 1 && data[0] === 0)
|
|
7
|
+
return { op: 0 };
|
|
8
|
+
if (data.length === 1 && data[0] > 0 && data[0] <= 16)
|
|
9
|
+
return { op: 0x50 + data[0] };
|
|
10
|
+
if (data.length === 1 && data[0] === 0x81)
|
|
11
|
+
return { op: 0x4f };
|
|
12
|
+
if (data.length <= 75)
|
|
13
|
+
return { op: data.length, data };
|
|
14
|
+
if (data.length <= 255)
|
|
15
|
+
return { op: 0x4c, data };
|
|
16
|
+
if (data.length <= 65535)
|
|
17
|
+
return { op: 0x4d, data };
|
|
18
|
+
return { op: 0x4e, data };
|
|
19
|
+
};
|
|
20
|
+
// Bitcoin script number: minimal little-endian, sign in the high bit of the last byte.
|
|
21
|
+
export const encodeScriptNum = (value) => {
|
|
22
|
+
if (value === 0)
|
|
23
|
+
return [];
|
|
24
|
+
const negative = value < 0;
|
|
25
|
+
let abs = Math.abs(value);
|
|
26
|
+
const result = [];
|
|
27
|
+
while (abs > 0) {
|
|
28
|
+
result.push(abs & 0xff);
|
|
29
|
+
abs = Math.floor(abs / 256);
|
|
30
|
+
}
|
|
31
|
+
if ((((result.at(-1)) ?? 0) & 0x80) !== 0) {
|
|
32
|
+
result.push(negative ? 0x80 : 0x00);
|
|
33
|
+
}
|
|
34
|
+
else if (negative) {
|
|
35
|
+
result[result.length - 1] |= 0x80;
|
|
36
|
+
}
|
|
37
|
+
return result;
|
|
38
|
+
};
|
|
39
|
+
export const decodeScriptNum = (data) => {
|
|
40
|
+
if (data.length === 0)
|
|
41
|
+
return 0;
|
|
42
|
+
let result = 0;
|
|
43
|
+
for (let i = 0; i < data.length; i++) {
|
|
44
|
+
result += (i === data.length - 1 ? (data[i] & 0x7f) : data[i]) * Math.pow(256, i);
|
|
45
|
+
}
|
|
46
|
+
if ((((data.at(-1)) ?? 0) & 0x80) !== 0)
|
|
47
|
+
result = -result;
|
|
48
|
+
return result;
|
|
49
|
+
};
|
|
50
|
+
export const encodeAssetId = (assetId) => {
|
|
51
|
+
const dot = assetId.lastIndexOf('.');
|
|
52
|
+
if (dot === -1)
|
|
53
|
+
throw new Error('assetId must be "<txid>.<vout>"');
|
|
54
|
+
const txid = assetId.slice(0, dot);
|
|
55
|
+
const vout = Number(assetId.slice(dot + 1));
|
|
56
|
+
if (txid.length !== 64)
|
|
57
|
+
throw new Error('assetId txid must be 32 bytes (64 hex chars)');
|
|
58
|
+
if (!Number.isInteger(vout) || vout < 0)
|
|
59
|
+
throw new Error('assetId vout must be a non-negative integer');
|
|
60
|
+
const txidBytes = Utils.toArray(txid, 'hex');
|
|
61
|
+
const voutBytes = [vout & 0xff, (vout >> 8) & 0xff, (vout >> 16) & 0xff, (vout >> 24) & 0xff];
|
|
62
|
+
return [...txidBytes, ...voutBytes];
|
|
63
|
+
};
|
|
64
|
+
export const decodeAssetId = (bytes) => {
|
|
65
|
+
if (bytes.length !== 36)
|
|
66
|
+
throw new Error('assetId bytes must be exactly 36 bytes');
|
|
67
|
+
const txid = Utils.toHex(bytes.slice(0, 32));
|
|
68
|
+
const v = bytes.slice(32);
|
|
69
|
+
const vout = (v[0] + (v[1] << 8) + (v[2] << 16) + (v[3] << 24)) >>> 0;
|
|
70
|
+
return `${txid}.${vout}`;
|
|
71
|
+
};
|
|
72
|
+
//# sourceMappingURL=mandala-encoding.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mandala-encoding.js","sourceRoot":"","sources":["../../../src/mandala-encoding.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { TransactionSignature } from '@bsv/sdk';
|
|
2
|
+
/**
|
|
3
|
+
* Builds the BIP143 sighash preimage and scope shared by the Mandala unlock templates.
|
|
4
|
+
*/
|
|
5
|
+
export function buildSighashPreimage(tx, inputIndex, signOutputs, anyoneCanPay) {
|
|
6
|
+
let scope = TransactionSignature.SIGHASH_FORKID;
|
|
7
|
+
if (signOutputs === 'all')
|
|
8
|
+
scope |= TransactionSignature.SIGHASH_ALL;
|
|
9
|
+
else if (signOutputs === 'none')
|
|
10
|
+
scope |= TransactionSignature.SIGHASH_NONE;
|
|
11
|
+
else if (signOutputs === 'single')
|
|
12
|
+
scope |= TransactionSignature.SIGHASH_SINGLE;
|
|
13
|
+
if (anyoneCanPay)
|
|
14
|
+
scope |= TransactionSignature.SIGHASH_ANYONECANPAY;
|
|
15
|
+
const input = tx.inputs[inputIndex];
|
|
16
|
+
const sourceTXID = input.sourceTXID ?? input.sourceTransaction?.id('hex');
|
|
17
|
+
const sourceOutput = input.sourceTransaction?.outputs[input.sourceOutputIndex];
|
|
18
|
+
if (sourceTXID == null)
|
|
19
|
+
throw new Error('sourceTXID or sourceTransaction required');
|
|
20
|
+
if (sourceOutput?.satoshis == null)
|
|
21
|
+
throw new Error('source satoshis required');
|
|
22
|
+
if (sourceOutput.lockingScript == null)
|
|
23
|
+
throw new Error('source lockingScript required');
|
|
24
|
+
const preimage = TransactionSignature.format({
|
|
25
|
+
sourceTXID,
|
|
26
|
+
sourceOutputIndex: input.sourceOutputIndex,
|
|
27
|
+
sourceSatoshis: sourceOutput.satoshis,
|
|
28
|
+
transactionVersion: tx.version,
|
|
29
|
+
otherInputs: tx.inputs.filter((_, i) => i !== inputIndex),
|
|
30
|
+
inputIndex,
|
|
31
|
+
outputs: tx.outputs,
|
|
32
|
+
inputSequence: input.sequence ?? 0xffffffff,
|
|
33
|
+
subscript: sourceOutput.lockingScript,
|
|
34
|
+
lockTime: tx.lockTime,
|
|
35
|
+
scope
|
|
36
|
+
});
|
|
37
|
+
return { preimage, scope };
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=mandala-signing.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mandala-signing.js","sourceRoot":"","sources":["../../../src/mandala-signing.ts"],"names":[],"mappings":"AAAA,OAAO,EAAe,oBAAoB,EAAE,MAAM,UAAU,CAAA;AAI5D;;GAEG;AACH,MAAM,UAAU,oBAAoB,CAClC,EAAe,EACf,UAAkB,EAClB,WAAwB,EACxB,YAAqB;IAErB,IAAI,KAAK,GAAG,oBAAoB,CAAC,cAAc,CAAA;IAC/C,IAAI,WAAW,KAAK,KAAK;QAAE,KAAK,IAAI,oBAAoB,CAAC,WAAW,CAAA;SAC/D,IAAI,WAAW,KAAK,MAAM;QAAE,KAAK,IAAI,oBAAoB,CAAC,YAAY,CAAA;SACtE,IAAI,WAAW,KAAK,QAAQ;QAAE,KAAK,IAAI,oBAAoB,CAAC,cAAc,CAAA;IAC/E,IAAI,YAAY;QAAE,KAAK,IAAI,oBAAoB,CAAC,oBAAoB,CAAA;IAEpE,MAAM,KAAK,GAAG,EAAE,CAAC,MAAM,CAAC,UAAU,CAAC,CAAA;IACnC,MAAM,UAAU,GAAG,KAAK,CAAC,UAAU,IAAI,KAAK,CAAC,iBAAiB,EAAE,EAAE,CAAC,KAAK,CAAC,CAAA;IACzE,MAAM,YAAY,GAAG,KAAK,CAAC,iBAAiB,EAAE,OAAO,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAA;IAC9E,IAAI,UAAU,IAAI,IAAI;QAAE,MAAM,IAAI,KAAK,CAAC,0CAA0C,CAAC,CAAA;IACnF,IAAI,YAAY,EAAE,QAAQ,IAAI,IAAI;QAAE,MAAM,IAAI,KAAK,CAAC,0BAA0B,CAAC,CAAA;IAC/E,IAAI,YAAY,CAAC,aAAa,IAAI,IAAI;QAAE,MAAM,IAAI,KAAK,CAAC,+BAA+B,CAAC,CAAA;IAExF,MAAM,QAAQ,GAAG,oBAAoB,CAAC,MAAM,CAAC;QAC3C,UAAU;QACV,iBAAiB,EAAE,KAAK,CAAC,iBAAiB;QAC1C,cAAc,EAAE,YAAY,CAAC,QAAQ;QACrC,kBAAkB,EAAE,EAAE,CAAC,OAAO;QAC9B,WAAW,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,UAAU,CAAC;QACzD,UAAU;QACV,OAAO,EAAE,EAAE,CAAC,OAAO;QACnB,aAAa,EAAE,KAAK,CAAC,QAAQ,IAAI,UAAU;QAC3C,SAAS,EAAE,YAAY,CAAC,aAAa;QACrC,QAAQ,EAAE,EAAE,CAAC,QAAQ;QACrB,KAAK;KACN,CAAC,CAAA;IACF,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAA;AAC5B,CAAC"}
|