@bsv/templates 1.4.1 → 1.5.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 +6 -6
- 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 +6 -6
- 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
package/dist/cjs/mod.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.P2MSKH = exports.MultiPushDrop = exports.OpReturn = void 0;
|
|
3
|
+
exports.MandalaAdmin = exports.MandalaToken = exports.P2MSKH = exports.MultiPushDrop = exports.OpReturn = void 0;
|
|
4
4
|
// Script Templates
|
|
5
5
|
var OpReturn_js_1 = require("./src/OpReturn.js");
|
|
6
6
|
Object.defineProperty(exports, "OpReturn", { enumerable: true, get: function () { return OpReturn_js_1.OpReturn; } });
|
|
@@ -8,4 +8,8 @@ var MultiPushDrop_js_1 = require("./src/MultiPushDrop.js");
|
|
|
8
8
|
Object.defineProperty(exports, "MultiPushDrop", { enumerable: true, get: function () { return MultiPushDrop_js_1.MultiPushDrop; } });
|
|
9
9
|
var P2MSKH_js_1 = require("./src/P2MSKH.js");
|
|
10
10
|
Object.defineProperty(exports, "P2MSKH", { enumerable: true, get: function () { return P2MSKH_js_1.P2MSKH; } });
|
|
11
|
+
var MandalaToken_js_1 = require("./src/MandalaToken.js");
|
|
12
|
+
Object.defineProperty(exports, "MandalaToken", { enumerable: true, get: function () { return MandalaToken_js_1.MandalaToken; } });
|
|
13
|
+
var MandalaAdmin_js_1 = require("./src/MandalaAdmin.js");
|
|
14
|
+
Object.defineProperty(exports, "MandalaAdmin", { enumerable: true, get: function () { return MandalaAdmin_js_1.MandalaAdmin; } });
|
|
11
15
|
//# sourceMappingURL=mod.js.map
|
package/dist/cjs/mod.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mod.js","sourceRoot":"","sources":["../../mod.ts"],"names":[],"mappings":";;;AAAA,mBAAmB;AACnB,iDAA4C;AAAnC,uGAAA,QAAQ,OAAA;AACjB,2DAAsD;AAA7C,iHAAA,aAAa,OAAA;AACtB,6CAAwC;AAA/B,mGAAA,MAAM,OAAA"}
|
|
1
|
+
{"version":3,"file":"mod.js","sourceRoot":"","sources":["../../mod.ts"],"names":[],"mappings":";;;AAAA,mBAAmB;AACnB,iDAA4C;AAAnC,uGAAA,QAAQ,OAAA;AACjB,2DAAsD;AAA7C,iHAAA,aAAa,OAAA;AACtB,6CAAwC;AAA/B,mGAAA,MAAM,OAAA;AACf,yDAAoD;AAA3C,+GAAA,YAAY,OAAA;AAErB,yDAAoD;AAA3C,+GAAA,YAAY,OAAA"}
|
package/dist/cjs/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@bsv/templates",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.5.0",
|
|
4
4
|
"type": "commonjs",
|
|
5
5
|
"description": "BSV Blockchain Script Templates",
|
|
6
6
|
"files": [
|
|
@@ -38,15 +38,15 @@
|
|
|
38
38
|
},
|
|
39
39
|
"homepage": "https://github.com/bsv-blockchain/ts-stack/tree/main/packages/helpers/ts-templates#readme",
|
|
40
40
|
"devDependencies": {
|
|
41
|
-
"@bsv/wallet-toolbox": "^2.1.
|
|
41
|
+
"@bsv/wallet-toolbox": "^2.1.28",
|
|
42
42
|
"@types/jest": "^30.0.0",
|
|
43
|
-
"jest": "^30.
|
|
44
|
-
"ts-jest": "^29.4.
|
|
43
|
+
"jest": "^30.4.2",
|
|
44
|
+
"ts-jest": "^29.4.11",
|
|
45
45
|
"ts-standard": "^12.0.2",
|
|
46
46
|
"tsconfig-to-dual-package": "^1.2.0",
|
|
47
|
-
"typescript": "^
|
|
47
|
+
"typescript": "^6.0.3"
|
|
48
48
|
},
|
|
49
49
|
"dependencies": {
|
|
50
|
-
"@bsv/sdk": "^2.1.
|
|
50
|
+
"@bsv/sdk": "^2.1.4"
|
|
51
51
|
}
|
|
52
52
|
}
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.MandalaAdmin = void 0;
|
|
4
|
+
const sdk_1 = require("@bsv/sdk");
|
|
5
|
+
const mandala_encoding_js_1 = require("./mandala-encoding.js");
|
|
6
|
+
const mandala_signing_js_1 = require("./mandala-signing.js");
|
|
7
|
+
const canon = (value) => {
|
|
8
|
+
if (value === null || typeof value !== 'object')
|
|
9
|
+
return JSON.stringify(value);
|
|
10
|
+
if (Array.isArray(value))
|
|
11
|
+
return '[' + value.map(canon).join(',') + ']';
|
|
12
|
+
const keys = Object.keys(value).sort((a, b) => {
|
|
13
|
+
if (a < b)
|
|
14
|
+
return -1;
|
|
15
|
+
if (a > b)
|
|
16
|
+
return 1;
|
|
17
|
+
return 0;
|
|
18
|
+
});
|
|
19
|
+
return '{' + keys.map(k => JSON.stringify(k) + ':' + canon(value[k])).join(',') + '}';
|
|
20
|
+
};
|
|
21
|
+
class MandalaAdmin {
|
|
22
|
+
constructor(wallet, originator) {
|
|
23
|
+
this.wallet = wallet;
|
|
24
|
+
this.originator = originator;
|
|
25
|
+
}
|
|
26
|
+
static canonicalize(actionDetails) {
|
|
27
|
+
return canon(actionDetails);
|
|
28
|
+
}
|
|
29
|
+
static commitment(actionDetails) {
|
|
30
|
+
return sdk_1.Utils.toHex(sdk_1.Hash.sha256(sdk_1.Utils.toArray(MandalaAdmin.canonicalize(actionDetails), 'utf8')));
|
|
31
|
+
}
|
|
32
|
+
async deriveBoundKey(protocolID, actionDetails) {
|
|
33
|
+
const keyID = MandalaAdmin.commitment(actionDetails);
|
|
34
|
+
const { publicKey } = await this.wallet.getPublicKey({ protocolID, keyID, counterparty: 'anyone' }, this.originator);
|
|
35
|
+
return { boundKey: publicKey, keyID };
|
|
36
|
+
}
|
|
37
|
+
lock(boundKey) {
|
|
38
|
+
const keyBytes = sdk_1.Utils.toArray(boundKey, 'hex');
|
|
39
|
+
if (keyBytes.length !== 33)
|
|
40
|
+
throw new Error('boundKey must be a 33-byte compressed public key');
|
|
41
|
+
return new sdk_1.LockingScript([
|
|
42
|
+
(0, mandala_encoding_js_1.createMinimallyEncodedScriptChunk)([mandala_encoding_js_1.MARKER]),
|
|
43
|
+
{ op: sdk_1.OP.OP_DROP },
|
|
44
|
+
{ op: keyBytes.length, data: keyBytes },
|
|
45
|
+
{ op: sdk_1.OP.OP_CHECKSIG }
|
|
46
|
+
]);
|
|
47
|
+
}
|
|
48
|
+
static decode(script) {
|
|
49
|
+
var _a;
|
|
50
|
+
const c = script.chunks;
|
|
51
|
+
if (c.length !== 4)
|
|
52
|
+
throw new Error('not a MandalaAdmin script: wrong chunk count');
|
|
53
|
+
const marker = (_a = c[0].data) !== null && _a !== void 0 ? _a : [];
|
|
54
|
+
if (c[0].op !== 1 || marker.length !== 1 || marker[0] !== mandala_encoding_js_1.MARKER)
|
|
55
|
+
throw new Error('not a MandalaAdmin script: missing marker');
|
|
56
|
+
if (c[1].op !== sdk_1.OP.OP_DROP || c[3].op !== sdk_1.OP.OP_CHECKSIG)
|
|
57
|
+
throw new Error('not a MandalaAdmin script: bad shape');
|
|
58
|
+
const keyData = c[2].data;
|
|
59
|
+
if ((keyData === null || keyData === void 0 ? void 0 : keyData.length) !== 33)
|
|
60
|
+
throw new Error('not a MandalaAdmin script: bad boundKey');
|
|
61
|
+
return { boundKey: sdk_1.Utils.toHex(keyData) };
|
|
62
|
+
}
|
|
63
|
+
unlock(protocolID, actionDetails, signOutputs = 'all', anyoneCanPay = false) {
|
|
64
|
+
return {
|
|
65
|
+
sign: async (tx, inputIndex) => {
|
|
66
|
+
const { preimage, scope } = (0, mandala_signing_js_1.buildSighashPreimage)(tx, inputIndex, signOutputs, anyoneCanPay);
|
|
67
|
+
const keyID = MandalaAdmin.commitment(actionDetails);
|
|
68
|
+
const { signature: bareSignature } = await this.wallet.createSignature({
|
|
69
|
+
hashToDirectlySign: sdk_1.Hash.hash256(preimage),
|
|
70
|
+
protocolID,
|
|
71
|
+
keyID,
|
|
72
|
+
counterparty: 'anyone'
|
|
73
|
+
}, this.originator);
|
|
74
|
+
const signature = sdk_1.Signature.fromDER([...bareSignature]);
|
|
75
|
+
const txSignature = new sdk_1.TransactionSignature(signature.r, signature.s, scope);
|
|
76
|
+
const sigForScript = txSignature.toChecksigFormat();
|
|
77
|
+
return new sdk_1.UnlockingScript([{ op: sigForScript.length, data: sigForScript }]);
|
|
78
|
+
},
|
|
79
|
+
estimateLength: async (_tx, _inputIndex) => 74
|
|
80
|
+
};
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
exports.MandalaAdmin = MandalaAdmin;
|
|
84
|
+
//# 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,84 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.MandalaToken = void 0;
|
|
4
|
+
const sdk_1 = require("@bsv/sdk");
|
|
5
|
+
const mandala_encoding_js_1 = require("./mandala-encoding.js");
|
|
6
|
+
const mandala_signing_js_1 = require("./mandala-signing.js");
|
|
7
|
+
// Local helper since Utils.verifyTruthy is not available in @bsv/sdk
|
|
8
|
+
const vt = (v) => {
|
|
9
|
+
if (v == null)
|
|
10
|
+
throw new Error('missing chunk data');
|
|
11
|
+
return v;
|
|
12
|
+
};
|
|
13
|
+
class MandalaToken {
|
|
14
|
+
constructor(wallet, originator) {
|
|
15
|
+
this.wallet = wallet;
|
|
16
|
+
this.originator = originator;
|
|
17
|
+
}
|
|
18
|
+
async lockBRC29(assetId, amount, protocolID, keyID, counterparty) {
|
|
19
|
+
if (this.wallet == null)
|
|
20
|
+
throw new Error('lockBRC29 requires a wallet');
|
|
21
|
+
const { publicKey } = await this.wallet.getPublicKey({ protocolID, keyID, counterparty }, this.originator);
|
|
22
|
+
const pubKeyHash = sdk_1.Hash.hash160(sdk_1.Utils.toArray(publicKey, 'hex'));
|
|
23
|
+
return this.lock(assetId, amount, pubKeyHash);
|
|
24
|
+
}
|
|
25
|
+
lock(assetId, amount, pubKeyHash) {
|
|
26
|
+
if (pubKeyHash.length !== 20)
|
|
27
|
+
throw new Error('pubKeyHash must be 20 bytes');
|
|
28
|
+
if (!Number.isInteger(amount) || amount < 1)
|
|
29
|
+
throw new Error('amount must be a positive integer');
|
|
30
|
+
const assetIdBytes = (0, mandala_encoding_js_1.encodeAssetId)(assetId);
|
|
31
|
+
return new sdk_1.LockingScript([
|
|
32
|
+
(0, mandala_encoding_js_1.createMinimallyEncodedScriptChunk)([mandala_encoding_js_1.MARKER]),
|
|
33
|
+
(0, mandala_encoding_js_1.createMinimallyEncodedScriptChunk)(assetIdBytes),
|
|
34
|
+
(0, mandala_encoding_js_1.createMinimallyEncodedScriptChunk)((0, mandala_encoding_js_1.encodeScriptNum)(amount)),
|
|
35
|
+
{ op: sdk_1.OP.OP_2DROP },
|
|
36
|
+
{ op: sdk_1.OP.OP_DROP },
|
|
37
|
+
{ op: sdk_1.OP.OP_DUP },
|
|
38
|
+
{ op: sdk_1.OP.OP_HASH160 },
|
|
39
|
+
{ op: pubKeyHash.length, data: pubKeyHash },
|
|
40
|
+
{ op: sdk_1.OP.OP_EQUALVERIFY },
|
|
41
|
+
{ op: sdk_1.OP.OP_CHECKSIG }
|
|
42
|
+
]);
|
|
43
|
+
}
|
|
44
|
+
unlock(privateKey, signOutputs = 'all', anyoneCanPay = false) {
|
|
45
|
+
return {
|
|
46
|
+
sign: async (tx, inputIndex) => {
|
|
47
|
+
const { preimage, scope } = (0, mandala_signing_js_1.buildSighashPreimage)(tx, inputIndex, signOutputs, anyoneCanPay);
|
|
48
|
+
const rawSignature = privateKey.sign(sdk_1.Hash.sha256(preimage));
|
|
49
|
+
const sig = new sdk_1.TransactionSignature(rawSignature.r, rawSignature.s, scope);
|
|
50
|
+
const sigForScript = sig.toChecksigFormat();
|
|
51
|
+
const pubkeyForScript = privateKey.toPublicKey().encode(true);
|
|
52
|
+
return new sdk_1.UnlockingScript([
|
|
53
|
+
{ op: sigForScript.length, data: sigForScript },
|
|
54
|
+
{ op: pubkeyForScript.length, data: pubkeyForScript }
|
|
55
|
+
]);
|
|
56
|
+
},
|
|
57
|
+
estimateLength: async (tx, inputIndex) => 108
|
|
58
|
+
};
|
|
59
|
+
}
|
|
60
|
+
static decode(script) {
|
|
61
|
+
var _a, _b;
|
|
62
|
+
const c = script.chunks;
|
|
63
|
+
if (c.length !== 10)
|
|
64
|
+
throw new Error('not a MandalaToken script: wrong chunk count');
|
|
65
|
+
const marker = (_a = c[0].data) !== null && _a !== void 0 ? _a : [];
|
|
66
|
+
if (c[0].op !== 1 || marker.length !== 1 || marker[0] !== mandala_encoding_js_1.MARKER)
|
|
67
|
+
throw new Error('not a MandalaToken script: missing marker');
|
|
68
|
+
if (c[3].op !== sdk_1.OP.OP_2DROP || c[4].op !== sdk_1.OP.OP_DROP)
|
|
69
|
+
throw new Error('not a MandalaToken script: bad drops');
|
|
70
|
+
if (c[5].op !== sdk_1.OP.OP_DUP || c[6].op !== sdk_1.OP.OP_HASH160 || c[8].op !== sdk_1.OP.OP_EQUALVERIFY || c[9].op !== sdk_1.OP.OP_CHECKSIG) {
|
|
71
|
+
throw new Error('not a MandalaToken script: bad P2PKH tail');
|
|
72
|
+
}
|
|
73
|
+
const assetId = (0, mandala_encoding_js_1.decodeAssetId)(vt(c[1].data));
|
|
74
|
+
const amount = (0, mandala_encoding_js_1.decodeScriptNum)((_b = c[2].data) !== null && _b !== void 0 ? _b : []);
|
|
75
|
+
if (!Number.isInteger(amount) || amount < 1)
|
|
76
|
+
throw new Error('not a MandalaToken script: bad amount');
|
|
77
|
+
const pubKeyHash = vt(c[7].data);
|
|
78
|
+
if (pubKeyHash.length !== 20)
|
|
79
|
+
throw new Error('not a MandalaToken script: bad pubKeyHash');
|
|
80
|
+
return { assetId, amount, pubKeyHash };
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
exports.MandalaToken = MandalaToken;
|
|
84
|
+
//# sourceMappingURL=MandalaToken.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MandalaToken.js","sourceRoot":"","sources":["../../../src/MandalaToken.ts"],"names":[],"mappings":"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"}
|
|
@@ -2,30 +2,13 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.MultiPushDrop = void 0;
|
|
4
4
|
const sdk_1 = require("@bsv/sdk");
|
|
5
|
+
const mandala_encoding_js_1 = require("./mandala-encoding.js");
|
|
5
6
|
// Helper to ensure a value is not null or undefined
|
|
6
7
|
function verifyTruthy(v, err) {
|
|
7
8
|
if (v === null || v === undefined)
|
|
8
9
|
throw new Error(err || 'Value must not be null or undefined');
|
|
9
10
|
return v;
|
|
10
11
|
}
|
|
11
|
-
// Helper to create minimally encoded script chunks (same as in PushDrop)
|
|
12
|
-
const createMinimallyEncodedScriptChunk = (data) => {
|
|
13
|
-
if (data.length === 0)
|
|
14
|
-
return { op: 0 }; // OP_0
|
|
15
|
-
if (data.length === 1 && data[0] === 0)
|
|
16
|
-
return { op: 0 }; // OP_0
|
|
17
|
-
if (data.length === 1 && data[0] > 0 && data[0] <= 16)
|
|
18
|
-
return { op: 0x50 + data[0] }; // OP_1 to OP_16
|
|
19
|
-
if (data.length === 1 && data[0] === 0x81)
|
|
20
|
-
return { op: 0x4f }; // OP_1NEGATE
|
|
21
|
-
if (data.length <= 75)
|
|
22
|
-
return { op: data.length, data };
|
|
23
|
-
if (data.length <= 255)
|
|
24
|
-
return { op: 0x4c, data }; // OP_PUSHDATA1
|
|
25
|
-
if (data.length <= 65535)
|
|
26
|
-
return { op: 0x4d, data }; // OP_PUSHDATA2
|
|
27
|
-
return { op: 0x4e, data }; // OP_PUSHDATA4
|
|
28
|
-
};
|
|
29
12
|
/**
|
|
30
13
|
* MultiPushDrop Script Template
|
|
31
14
|
*
|
|
@@ -145,7 +128,7 @@ class MultiPushDrop {
|
|
|
145
128
|
}
|
|
146
129
|
// Pick the value on the stack that's right before the locking script.
|
|
147
130
|
// This should be the index of the key to use in the unlock.
|
|
148
|
-
lockPart.push(createMinimallyEncodedScriptChunk([nPublicKeys]), { op: sdk_1.OP.OP_PICK });
|
|
131
|
+
lockPart.push((0, mandala_encoding_js_1.createMinimallyEncodedScriptChunk)([nPublicKeys]), { op: sdk_1.OP.OP_PICK });
|
|
149
132
|
// Now we use the index to get the actual key.
|
|
150
133
|
lockPart.push({ op: sdk_1.OP.OP_PICK });
|
|
151
134
|
// We pull the signature from the bottom of the stack, no matter the number of keys.
|
|
@@ -155,7 +138,7 @@ class MultiPushDrop {
|
|
|
155
138
|
// Construct PushDrop Part for fields
|
|
156
139
|
const pushDropPart = [];
|
|
157
140
|
for (const field of fields) {
|
|
158
|
-
pushDropPart.push(createMinimallyEncodedScriptChunk(field));
|
|
141
|
+
pushDropPart.push((0, mandala_encoding_js_1.createMinimallyEncodedScriptChunk)(field));
|
|
159
142
|
}
|
|
160
143
|
// Add Drop Opcodes
|
|
161
144
|
// We need to drop N keys, the number N itself, and M fields after verification succeeds.
|
|
@@ -258,7 +241,7 @@ class MultiPushDrop {
|
|
|
258
241
|
const sigForScript = txSignature.toChecksigFormat();
|
|
259
242
|
// Create Unlocking Script Chunks: <Signature> <Index>
|
|
260
243
|
const unlockingChunks = [];
|
|
261
|
-
unlockingChunks.push({ op: sigForScript.length, data: sigForScript }, createMinimallyEncodedScriptChunk([unlockerIndex]));
|
|
244
|
+
unlockingChunks.push({ op: sigForScript.length, data: sigForScript }, (0, mandala_encoding_js_1.createMinimallyEncodedScriptChunk)([unlockerIndex]));
|
|
262
245
|
return new sdk_1.UnlockingScript(unlockingChunks);
|
|
263
246
|
},
|
|
264
247
|
// Estimate length: Signature (~71-73 bytes) + Index push (1 byte for 0-15, potentially more)
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MultiPushDrop.js","sourceRoot":"","sources":["../../../src/MultiPushDrop.ts"],"names":[],"mappings":";;;AAAA,kCAaiB;
|
|
1
|
+
{"version":3,"file":"MultiPushDrop.js","sourceRoot":"","sources":["../../../src/MultiPushDrop.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.decodeAssetId = exports.encodeAssetId = exports.decodeScriptNum = exports.encodeScriptNum = exports.createMinimallyEncodedScriptChunk = exports.MARKER = void 0;
|
|
4
|
+
const sdk_1 = require("@bsv/sdk");
|
|
5
|
+
exports.MARKER = 0x21;
|
|
6
|
+
const createMinimallyEncodedScriptChunk = (data) => {
|
|
7
|
+
if (data.length === 0)
|
|
8
|
+
return { op: 0 };
|
|
9
|
+
if (data.length === 1 && data[0] === 0)
|
|
10
|
+
return { op: 0 };
|
|
11
|
+
if (data.length === 1 && data[0] > 0 && data[0] <= 16)
|
|
12
|
+
return { op: 0x50 + data[0] };
|
|
13
|
+
if (data.length === 1 && data[0] === 0x81)
|
|
14
|
+
return { op: 0x4f };
|
|
15
|
+
if (data.length <= 75)
|
|
16
|
+
return { op: data.length, data };
|
|
17
|
+
if (data.length <= 255)
|
|
18
|
+
return { op: 0x4c, data };
|
|
19
|
+
if (data.length <= 65535)
|
|
20
|
+
return { op: 0x4d, data };
|
|
21
|
+
return { op: 0x4e, data };
|
|
22
|
+
};
|
|
23
|
+
exports.createMinimallyEncodedScriptChunk = createMinimallyEncodedScriptChunk;
|
|
24
|
+
// Bitcoin script number: minimal little-endian, sign in the high bit of the last byte.
|
|
25
|
+
const encodeScriptNum = (value) => {
|
|
26
|
+
var _a;
|
|
27
|
+
if (value === 0)
|
|
28
|
+
return [];
|
|
29
|
+
const negative = value < 0;
|
|
30
|
+
let abs = Math.abs(value);
|
|
31
|
+
const result = [];
|
|
32
|
+
while (abs > 0) {
|
|
33
|
+
result.push(abs & 0xff);
|
|
34
|
+
abs = Math.floor(abs / 256);
|
|
35
|
+
}
|
|
36
|
+
if ((((_a = (result.at(-1))) !== null && _a !== void 0 ? _a : 0) & 0x80) !== 0) {
|
|
37
|
+
result.push(negative ? 0x80 : 0x00);
|
|
38
|
+
}
|
|
39
|
+
else if (negative) {
|
|
40
|
+
result[result.length - 1] |= 0x80;
|
|
41
|
+
}
|
|
42
|
+
return result;
|
|
43
|
+
};
|
|
44
|
+
exports.encodeScriptNum = encodeScriptNum;
|
|
45
|
+
const decodeScriptNum = (data) => {
|
|
46
|
+
var _a;
|
|
47
|
+
if (data.length === 0)
|
|
48
|
+
return 0;
|
|
49
|
+
let result = 0;
|
|
50
|
+
for (let i = 0; i < data.length; i++) {
|
|
51
|
+
result += (i === data.length - 1 ? (data[i] & 0x7f) : data[i]) * Math.pow(256, i);
|
|
52
|
+
}
|
|
53
|
+
if ((((_a = (data.at(-1))) !== null && _a !== void 0 ? _a : 0) & 0x80) !== 0)
|
|
54
|
+
result = -result;
|
|
55
|
+
return result;
|
|
56
|
+
};
|
|
57
|
+
exports.decodeScriptNum = decodeScriptNum;
|
|
58
|
+
const encodeAssetId = (assetId) => {
|
|
59
|
+
const dot = assetId.lastIndexOf('.');
|
|
60
|
+
if (dot === -1)
|
|
61
|
+
throw new Error('assetId must be "<txid>.<vout>"');
|
|
62
|
+
const txid = assetId.slice(0, dot);
|
|
63
|
+
const vout = Number(assetId.slice(dot + 1));
|
|
64
|
+
if (txid.length !== 64)
|
|
65
|
+
throw new Error('assetId txid must be 32 bytes (64 hex chars)');
|
|
66
|
+
if (!Number.isInteger(vout) || vout < 0)
|
|
67
|
+
throw new Error('assetId vout must be a non-negative integer');
|
|
68
|
+
const txidBytes = sdk_1.Utils.toArray(txid, 'hex');
|
|
69
|
+
const voutBytes = [vout & 0xff, (vout >> 8) & 0xff, (vout >> 16) & 0xff, (vout >> 24) & 0xff];
|
|
70
|
+
return [...txidBytes, ...voutBytes];
|
|
71
|
+
};
|
|
72
|
+
exports.encodeAssetId = encodeAssetId;
|
|
73
|
+
const decodeAssetId = (bytes) => {
|
|
74
|
+
if (bytes.length !== 36)
|
|
75
|
+
throw new Error('assetId bytes must be exactly 36 bytes');
|
|
76
|
+
const txid = sdk_1.Utils.toHex(bytes.slice(0, 32));
|
|
77
|
+
const v = bytes.slice(32);
|
|
78
|
+
const vout = (v[0] + (v[1] << 8) + (v[2] << 16) + (v[3] << 24)) >>> 0;
|
|
79
|
+
return `${txid}.${vout}`;
|
|
80
|
+
};
|
|
81
|
+
exports.decodeAssetId = decodeAssetId;
|
|
82
|
+
//# 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,43 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.buildSighashPreimage = buildSighashPreimage;
|
|
4
|
+
const sdk_1 = require("@bsv/sdk");
|
|
5
|
+
/**
|
|
6
|
+
* Builds the BIP143 sighash preimage and scope shared by the Mandala unlock templates.
|
|
7
|
+
*/
|
|
8
|
+
function buildSighashPreimage(tx, inputIndex, signOutputs, anyoneCanPay) {
|
|
9
|
+
var _a, _b, _c, _d;
|
|
10
|
+
let scope = sdk_1.TransactionSignature.SIGHASH_FORKID;
|
|
11
|
+
if (signOutputs === 'all')
|
|
12
|
+
scope |= sdk_1.TransactionSignature.SIGHASH_ALL;
|
|
13
|
+
else if (signOutputs === 'none')
|
|
14
|
+
scope |= sdk_1.TransactionSignature.SIGHASH_NONE;
|
|
15
|
+
else if (signOutputs === 'single')
|
|
16
|
+
scope |= sdk_1.TransactionSignature.SIGHASH_SINGLE;
|
|
17
|
+
if (anyoneCanPay)
|
|
18
|
+
scope |= sdk_1.TransactionSignature.SIGHASH_ANYONECANPAY;
|
|
19
|
+
const input = tx.inputs[inputIndex];
|
|
20
|
+
const sourceTXID = (_a = input.sourceTXID) !== null && _a !== void 0 ? _a : (_b = input.sourceTransaction) === null || _b === void 0 ? void 0 : _b.id('hex');
|
|
21
|
+
const sourceOutput = (_c = input.sourceTransaction) === null || _c === void 0 ? void 0 : _c.outputs[input.sourceOutputIndex];
|
|
22
|
+
if (sourceTXID == null)
|
|
23
|
+
throw new Error('sourceTXID or sourceTransaction required');
|
|
24
|
+
if ((sourceOutput === null || sourceOutput === void 0 ? void 0 : sourceOutput.satoshis) == null)
|
|
25
|
+
throw new Error('source satoshis required');
|
|
26
|
+
if (sourceOutput.lockingScript == null)
|
|
27
|
+
throw new Error('source lockingScript required');
|
|
28
|
+
const preimage = sdk_1.TransactionSignature.format({
|
|
29
|
+
sourceTXID,
|
|
30
|
+
sourceOutputIndex: input.sourceOutputIndex,
|
|
31
|
+
sourceSatoshis: sourceOutput.satoshis,
|
|
32
|
+
transactionVersion: tx.version,
|
|
33
|
+
otherInputs: tx.inputs.filter((_, i) => i !== inputIndex),
|
|
34
|
+
inputIndex,
|
|
35
|
+
outputs: tx.outputs,
|
|
36
|
+
inputSequence: (_d = input.sequence) !== null && _d !== void 0 ? _d : 0xffffffff,
|
|
37
|
+
subscript: sourceOutput.lockingScript,
|
|
38
|
+
lockTime: tx.lockTime,
|
|
39
|
+
scope
|
|
40
|
+
});
|
|
41
|
+
return { preimage, scope };
|
|
42
|
+
}
|
|
43
|
+
//# sourceMappingURL=mandala-signing.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mandala-signing.js","sourceRoot":"","sources":["../../../src/mandala-signing.ts"],"names":[],"mappings":";;AAOA,oDAiCC;AAxCD,kCAA4D;AAI5D;;GAEG;AACH,SAAgB,oBAAoB,CAClC,EAAe,EACf,UAAkB,EAClB,WAAwB,EACxB,YAAqB;;IAErB,IAAI,KAAK,GAAG,0BAAoB,CAAC,cAAc,CAAA;IAC/C,IAAI,WAAW,KAAK,KAAK;QAAE,KAAK,IAAI,0BAAoB,CAAC,WAAW,CAAA;SAC/D,IAAI,WAAW,KAAK,MAAM;QAAE,KAAK,IAAI,0BAAoB,CAAC,YAAY,CAAA;SACtE,IAAI,WAAW,KAAK,QAAQ;QAAE,KAAK,IAAI,0BAAoB,CAAC,cAAc,CAAA;IAC/E,IAAI,YAAY;QAAE,KAAK,IAAI,0BAAoB,CAAC,oBAAoB,CAAA;IAEpE,MAAM,KAAK,GAAG,EAAE,CAAC,MAAM,CAAC,UAAU,CAAC,CAAA;IACnC,MAAM,UAAU,GAAG,MAAA,KAAK,CAAC,UAAU,mCAAI,MAAA,KAAK,CAAC,iBAAiB,0CAAE,EAAE,CAAC,KAAK,CAAC,CAAA;IACzE,MAAM,YAAY,GAAG,MAAA,KAAK,CAAC,iBAAiB,0CAAE,OAAO,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAA;IAC9E,IAAI,UAAU,IAAI,IAAI;QAAE,MAAM,IAAI,KAAK,CAAC,0CAA0C,CAAC,CAAA;IACnF,IAAI,CAAA,YAAY,aAAZ,YAAY,uBAAZ,YAAY,CAAE,QAAQ,KAAI,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,0BAAoB,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,MAAA,KAAK,CAAC,QAAQ,mCAAI,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"}
|