@bitgo-beta/sdk-coin-ada 2.3.14-beta.9 → 2.3.14-beta.900
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/CHANGELOG.md +948 -0
- package/dist/src/ada.d.ts +37 -19
- package/dist/src/ada.d.ts.map +1 -1
- package/dist/src/ada.js +306 -96
- package/dist/src/adaToken.d.ts +1 -1
- package/dist/src/adaToken.d.ts.map +1 -1
- package/dist/src/adaToken.js +3 -3
- package/dist/src/index.js +6 -2
- package/dist/src/lib/index.d.ts +4 -1
- package/dist/src/lib/index.d.ts.map +1 -1
- package/dist/src/lib/index.js +32 -12
- package/dist/src/lib/keyPair.js +29 -16
- package/dist/src/lib/stakingActivateBuilder.d.ts +1 -1
- package/dist/src/lib/stakingActivateBuilder.d.ts.map +1 -1
- package/dist/src/lib/stakingActivateBuilder.js +30 -10
- package/dist/src/lib/{stakingWithdrawRewardsBuilder.d.ts → stakingBaseClaimBuilder.d.ts} +6 -7
- package/dist/src/lib/stakingBaseClaimBuilder.d.ts.map +1 -0
- package/dist/src/lib/stakingBaseClaimBuilder.js +35 -0
- package/dist/src/lib/stakingClaimRewardsBuilder.d.ts +10 -0
- package/dist/src/lib/stakingClaimRewardsBuilder.d.ts.map +1 -0
- package/dist/src/lib/stakingClaimRewardsBuilder.js +22 -0
- package/dist/src/lib/stakingDeactivateBuilder.js +24 -10
- package/dist/src/lib/stakingPledgeBuilder.d.ts +23 -0
- package/dist/src/lib/stakingPledgeBuilder.d.ts.map +1 -0
- package/dist/src/lib/stakingPledgeBuilder.js +43 -0
- package/dist/src/lib/stakingWithdrawBuilder.d.ts +12 -0
- package/dist/src/lib/stakingWithdrawBuilder.d.ts.map +1 -0
- package/dist/src/lib/stakingWithdrawBuilder.js +22 -0
- package/dist/src/lib/transaction.d.ts +35 -5
- package/dist/src/lib/transaction.d.ts.map +1 -1
- package/dist/src/lib/transaction.js +144 -21
- package/dist/src/lib/transactionBuilder.d.ts +5 -2
- package/dist/src/lib/transactionBuilder.d.ts.map +1 -1
- package/dist/src/lib/transactionBuilder.js +173 -24
- package/dist/src/lib/transactionBuilderFactory.d.ts +8 -2
- package/dist/src/lib/transactionBuilderFactory.d.ts.map +1 -1
- package/dist/src/lib/transactionBuilderFactory.js +21 -3
- package/dist/src/lib/utils.d.ts +29 -0
- package/dist/src/lib/utils.d.ts.map +1 -1
- package/dist/src/lib/utils.js +170 -17
- package/dist/src/lib/voteDelegationBuilder.d.ts +24 -0
- package/dist/src/lib/voteDelegationBuilder.d.ts.map +1 -0
- package/dist/src/lib/voteDelegationBuilder.js +84 -0
- package/package.json +13 -10
- package/dist/src/lib/stakingWithdrawRewardsBuilder.d.ts.map +0 -1
- package/dist/src/lib/stakingWithdrawRewardsBuilder.js +0 -43
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"transactionBuilder.d.ts","sourceRoot":"","sources":["../../../src/lib/transactionBuilder.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"transactionBuilder.d.ts","sourceRoot":"","sources":["../../../src/lib/transactionBuilder.ts"],"names":[],"mappings":"AAAA,OAAO,SAAS,MAAM,cAAc,CAAC;AACrC,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EACL,WAAW,EACX,OAAO,EACP,sBAAsB,EAEtB,SAAS,IAAI,aAAa,EAC1B,SAAS,EACT,eAAe,EAEhB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,KAAK,EAAE,WAAW,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AACpG,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEpC,OAAO,KAAK,WAAW,MAAM,0CAA0C,CAAC;AAGxE,8BAAsB,kBAAmB,SAAQ,sBAAsB;IACrE,SAAS,CAAC,YAAY,EAAG,WAAW,CAAC;IACrC,SAAS,CAAC,QAAQ,EAAE,OAAO,EAAE,CAAM;IACnC,SAAS,CAAC,kBAAkB,EAAE,gBAAgB,EAAE,CAAM;IACtD,SAAS,CAAC,mBAAmB,EAAE,iBAAiB,EAAE,CAAM;IACxD,SAAS,CAAC,eAAe,EAAE,SAAS,EAAE,CAAM;IAC5C,SAAS,CAAC,WAAW,EAAE,SAAS,EAAE,CAAM;IACxC,SAAS,CAAC,cAAc,EAAE,MAAM,CAAC;IACjC,SAAS,CAAC,cAAc,EAAE,MAAM,CAAC;IACjC,SAAS,CAAC,IAAI,SAAK;IACnB,SAAS,CAAC,MAAM,EAAE,WAAW,CAAC,WAAW,EAAE,CAAM;IACjD,SAAS,CAAC,YAAY,EAAE,UAAU,EAAE,CAAM;IAC1C,SAAS,CAAC,KAAK,EAAE,eAAe,CAAC;IACjC,SAAS,CAAC,YAAY,EAAE,KAAK,EAAE,CAAM;IACrC,OAAO,CAAC,IAAI,CAAS;gBAET,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IAM7C,KAAK,CAAC,CAAC,EAAE,gBAAgB,GAAG,IAAI;IAKhC,MAAM,CAAC,CAAC,EAAE,iBAAiB,GAAG,IAAI;IAKlC,MAAM,CAAC,CAAC,EAAE,KAAK,GAAG,IAAI;IAKtB,GAAG,CAAC,CAAC,EAAE,MAAM,GAAG,IAAI;IAKpB,aAAa,CAAC,IAAI,EAAE,MAAM,EAAE,iBAAiB,EAAE,MAAM,GAAG,IAAI;IAM5D,GAAG,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI;IAKtB;;;;OAIG;IACH,WAAW,CAAC,EAAE,EAAE,WAAW,GAAG,IAAI;IAmDlC,kBAAkB;IAClB,SAAS,CAAC,kBAAkB,CAAC,cAAc,EAAE,MAAM,GAAG,WAAW;IAMjE,kBAAkB;cACF,mBAAmB,IAAI,OAAO,CAAC,WAAW,CAAC;IAiT3D,kBAAkB;IAClB,SAAS,CAAC,kBAAkB,CAAC,GAAG,EAAE,OAAO,GAAG,WAAW;IAKvD,kBAAkB;IAClB,SAAS,KAAK,WAAW,IAAI,WAAW,CAEvC;IAED,kBAAkB;IAClB,SAAS,KAAK,WAAW,CAAC,WAAW,EAAE,WAAW,EAEjD;IAED,kBAAkB;IAClB,eAAe,CAAC,OAAO,EAAE,WAAW,EAAE,aAAa,CAAC,EAAE,MAAM,GAAG,IAAI;IAMnE,kBAAkB;IAClB,WAAW,CAAC,GAAG,EAAE,OAAO,GAAG,IAAI;IAQ/B,kBAAkB;IAClB,sBAAsB,CAAC,cAAc,EAAE,GAAG,GAAG,IAAI;IAQjD,kBAAkB;IAClB,mBAAmB,CAAC,WAAW,EAAE,WAAW,GAAG,IAAI;IAMnD,kBAAkB;IAClB,aAAa,CAAC,KAAK,EAAE,SAAS,GAAG,IAAI;IAOrC,kBAAkB;IAClB,YAAY,CAAC,SAAS,EAAE,aAAa,EAAE,SAAS,EAAE,MAAM,GAAG,IAAI;IAI/D,OAAO,CAAC,gBAAgB;CAGzB"}
|
|
@@ -1,7 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
3
|
if (k2 === undefined) k2 = k;
|
|
4
|
-
Object.
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
5
9
|
}) : (function(o, m, k, k2) {
|
|
6
10
|
if (k2 === undefined) k2 = k;
|
|
7
11
|
o[k2] = m[k];
|
|
@@ -11,22 +15,29 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (
|
|
|
11
15
|
}) : function(o, v) {
|
|
12
16
|
o["default"] = v;
|
|
13
17
|
});
|
|
14
|
-
var __importStar = (this && this.__importStar) || function (
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
};
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
24
35
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
25
36
|
exports.TransactionBuilder = void 0;
|
|
26
37
|
const sdk_core_1 = require("@bitgo-beta/sdk-core");
|
|
27
38
|
const transaction_1 = require("./transaction");
|
|
28
39
|
const keyPair_1 = require("./keyPair");
|
|
29
|
-
const utils_1 =
|
|
40
|
+
const utils_1 = __importStar(require("./utils"));
|
|
30
41
|
const CardanoWasm = __importStar(require("@emurgo/cardano-serialization-lib-nodejs"));
|
|
31
42
|
const cardano_serialization_lib_nodejs_1 = require("@emurgo/cardano-serialization-lib-nodejs");
|
|
32
43
|
class TransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
|
|
@@ -35,10 +46,12 @@ class TransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
|
|
|
35
46
|
this._signers = [];
|
|
36
47
|
this._transactionInputs = [];
|
|
37
48
|
this._transactionOutputs = [];
|
|
49
|
+
this._initSignatures = [];
|
|
38
50
|
this._signatures = [];
|
|
39
51
|
this._ttl = 0;
|
|
40
52
|
this._certs = [];
|
|
41
53
|
this._withdrawals = [];
|
|
54
|
+
this._multiAssets = [];
|
|
42
55
|
this.transaction = new transaction_1.Transaction(_coinConfig);
|
|
43
56
|
this._fee = cardano_serialization_lib_nodejs_1.BigNum.zero();
|
|
44
57
|
}
|
|
@@ -50,6 +63,10 @@ class TransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
|
|
|
50
63
|
this._transactionOutputs.push(o);
|
|
51
64
|
return this;
|
|
52
65
|
}
|
|
66
|
+
assets(a) {
|
|
67
|
+
this._multiAssets.push(a);
|
|
68
|
+
return this;
|
|
69
|
+
}
|
|
53
70
|
ttl(t) {
|
|
54
71
|
this._ttl = t;
|
|
55
72
|
return this;
|
|
@@ -83,6 +100,7 @@ class TransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
|
|
|
83
100
|
this.output({
|
|
84
101
|
address: output.address().to_bech32(),
|
|
85
102
|
amount: output.amount().coin().to_str(),
|
|
103
|
+
multiAssets: output.amount().multiasset() || undefined,
|
|
86
104
|
});
|
|
87
105
|
}
|
|
88
106
|
if (txnBody.certs() !== undefined) {
|
|
@@ -102,6 +120,16 @@ class TransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
|
|
|
102
120
|
}
|
|
103
121
|
this._ttl = tx.transaction.body().ttl();
|
|
104
122
|
this._fee = tx.transaction.body().fee();
|
|
123
|
+
if (tx.transaction.witness_set().vkeys()) {
|
|
124
|
+
const vkeys = tx.transaction.witness_set().vkeys();
|
|
125
|
+
for (let i = 0; i < vkeys.len(); i++) {
|
|
126
|
+
const vkey = vkeys.get(i);
|
|
127
|
+
this._initSignatures.push({
|
|
128
|
+
publicKey: { pub: vkey.vkey().public_key().to_hex() },
|
|
129
|
+
signature: Buffer.from(vkey.signature().to_hex(), 'hex'),
|
|
130
|
+
});
|
|
131
|
+
}
|
|
132
|
+
}
|
|
105
133
|
}
|
|
106
134
|
/** @inheritdoc */
|
|
107
135
|
fromImplementation(rawTransaction) {
|
|
@@ -119,16 +147,69 @@ class TransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
|
|
|
119
147
|
let totalAmountToSend = CardanoWasm.BigNum.zero();
|
|
120
148
|
this._transactionOutputs.forEach((output) => {
|
|
121
149
|
const amount = CardanoWasm.BigNum.from_str(output.amount);
|
|
122
|
-
outputs.add(CardanoWasm.TransactionOutput.new(
|
|
150
|
+
outputs.add(CardanoWasm.TransactionOutput.new(utils_1.default.getWalletAddress(output.address), CardanoWasm.Value.new(amount)));
|
|
123
151
|
totalAmountToSend = totalAmountToSend.checked_add(amount);
|
|
124
152
|
});
|
|
125
153
|
if (this._fee.is_zero()) {
|
|
126
154
|
// estimate fee
|
|
127
155
|
// add extra output for the change
|
|
128
156
|
if (this._changeAddress && this._senderBalance) {
|
|
129
|
-
const changeAddress =
|
|
130
|
-
const
|
|
131
|
-
|
|
157
|
+
const changeAddress = utils_1.default.getWalletAddress(this._changeAddress);
|
|
158
|
+
const utxoBalance = CardanoWasm.BigNum.from_str(this._senderBalance);
|
|
159
|
+
const adjustment = cardano_serialization_lib_nodejs_1.BigNum.from_str('2000000');
|
|
160
|
+
let change = utxoBalance.checked_sub(this._fee).checked_sub(totalAmountToSend);
|
|
161
|
+
if (this._type === sdk_core_1.TransactionType.StakingActivate) {
|
|
162
|
+
change = change.checked_sub(adjustment);
|
|
163
|
+
}
|
|
164
|
+
else if (this._type === sdk_core_1.TransactionType.StakingDeactivate) {
|
|
165
|
+
change = change.checked_add(adjustment);
|
|
166
|
+
}
|
|
167
|
+
else if (this._type === sdk_core_1.TransactionType.StakingWithdraw || this._type === sdk_core_1.TransactionType.StakingClaim) {
|
|
168
|
+
this._withdrawals.forEach((withdrawal) => {
|
|
169
|
+
change = change.checked_add(CardanoWasm.BigNum.from_str(withdrawal.value));
|
|
170
|
+
});
|
|
171
|
+
}
|
|
172
|
+
// If totalAmountToSend is 0, its consolidation
|
|
173
|
+
if (totalAmountToSend.to_str() == '0') {
|
|
174
|
+
// support for multi-asset consolidation
|
|
175
|
+
if (this._multiAssets !== undefined) {
|
|
176
|
+
const totalNumberOfAssets = CardanoWasm.BigNum.from_str(this._multiAssets.length.toString());
|
|
177
|
+
const minAmountNeededForOneAssetOutput = CardanoWasm.BigNum.from_str(utils_1.MIN_ADA_FOR_ONE_ASSET);
|
|
178
|
+
const minAmountNeededForTotalAssetOutputs = minAmountNeededForOneAssetOutput.checked_mul(totalNumberOfAssets);
|
|
179
|
+
if (!change.less_than(minAmountNeededForTotalAssetOutputs)) {
|
|
180
|
+
this._multiAssets.forEach((asset) => {
|
|
181
|
+
let txOutputBuilder = CardanoWasm.TransactionOutputBuilder.new();
|
|
182
|
+
// changeAddress is the root address, which is where we want the tokens assets to be sent to
|
|
183
|
+
const toAddress = utils_1.default.getWalletAddress(this._changeAddress);
|
|
184
|
+
txOutputBuilder = txOutputBuilder.with_address(toAddress);
|
|
185
|
+
let txOutputAmountBuilder = txOutputBuilder.next();
|
|
186
|
+
const assetName = CardanoWasm.AssetName.new(Buffer.from(asset.asset_name, 'hex'));
|
|
187
|
+
const policyId = CardanoWasm.ScriptHash.from_bytes(Buffer.from(asset.policy_id, 'hex'));
|
|
188
|
+
const multiAsset = CardanoWasm.MultiAsset.new();
|
|
189
|
+
const assets = CardanoWasm.Assets.new();
|
|
190
|
+
assets.insert(assetName, CardanoWasm.BigNum.from_str(asset.quantity));
|
|
191
|
+
multiAsset.insert(policyId, assets);
|
|
192
|
+
txOutputAmountBuilder = txOutputAmountBuilder.with_coin_and_asset(minAmountNeededForOneAssetOutput, multiAsset);
|
|
193
|
+
const txOutput = txOutputAmountBuilder.build();
|
|
194
|
+
outputs.add(txOutput);
|
|
195
|
+
});
|
|
196
|
+
// finally send the remaining ADA in its own output
|
|
197
|
+
const remainingOutputAmount = change.checked_sub(minAmountNeededForTotalAssetOutputs);
|
|
198
|
+
const changeOutput = CardanoWasm.TransactionOutput.new(changeAddress, CardanoWasm.Value.new(remainingOutputAmount));
|
|
199
|
+
outputs.add(changeOutput);
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
else {
|
|
203
|
+
// If there are no tokens to consolidate, you only have 1 output which is ADA alone
|
|
204
|
+
const changeOutput = CardanoWasm.TransactionOutput.new(changeAddress, CardanoWasm.Value.new(change));
|
|
205
|
+
outputs.add(changeOutput);
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
else {
|
|
209
|
+
// If this isn't a consolidate request, whatever change that needs to be sent back to the rootaddress is added as a separate output here
|
|
210
|
+
const changeOutput = CardanoWasm.TransactionOutput.new(changeAddress, CardanoWasm.Value.new(change));
|
|
211
|
+
outputs.add(changeOutput);
|
|
212
|
+
}
|
|
132
213
|
}
|
|
133
214
|
const txBody = CardanoWasm.TransactionBody.new_tx_body(inputs, outputs, this._fee);
|
|
134
215
|
txBody.set_ttl(CardanoWasm.BigNum.from_str(this._ttl.toString()));
|
|
@@ -141,7 +222,7 @@ class TransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
|
|
|
141
222
|
const vkeyWitness = CardanoWasm.make_vkey_witness(txHash, CardanoWasm.PrivateKey.from_normal_bytes(Buffer.from(prv, 'hex')));
|
|
142
223
|
vkeyWitnesses.add(vkeyWitness);
|
|
143
224
|
});
|
|
144
|
-
this.
|
|
225
|
+
this.getAllSignatures().forEach((signature) => {
|
|
145
226
|
const vkey = CardanoWasm.Vkey.new(CardanoWasm.PublicKey.from_bytes(Buffer.from(signature.publicKey.pub, 'hex')));
|
|
146
227
|
const ed255Sig = CardanoWasm.Ed25519Signature.from_bytes(signature.signature);
|
|
147
228
|
vkeyWitnesses.add(CardanoWasm.Vkeywitness.new(vkey, ed255Sig));
|
|
@@ -181,10 +262,30 @@ class TransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
|
|
|
181
262
|
// reset the outputs collection because now our last output has changed
|
|
182
263
|
outputs = CardanoWasm.TransactionOutputs.new();
|
|
183
264
|
this._transactionOutputs.forEach((output) => {
|
|
184
|
-
|
|
265
|
+
if (output.multiAssets) {
|
|
266
|
+
const policyId = output.multiAssets.keys().get(0);
|
|
267
|
+
const assets = output.multiAssets.get(policyId);
|
|
268
|
+
const assetName = assets.keys().get(0);
|
|
269
|
+
const quantity = assets.get(assetName);
|
|
270
|
+
let txOutputBuilder = CardanoWasm.TransactionOutputBuilder.new();
|
|
271
|
+
const outputAmount = CardanoWasm.BigNum.from_str(output.amount);
|
|
272
|
+
const toAddress = utils_1.default.getWalletAddress(output.address);
|
|
273
|
+
txOutputBuilder = txOutputBuilder.with_address(toAddress);
|
|
274
|
+
let txOutputAmountBuilder = txOutputBuilder.next();
|
|
275
|
+
const multiAsset = CardanoWasm.MultiAsset.new();
|
|
276
|
+
const asset = CardanoWasm.Assets.new();
|
|
277
|
+
asset.insert(assetName, quantity);
|
|
278
|
+
multiAsset.insert(policyId, asset);
|
|
279
|
+
txOutputAmountBuilder = txOutputAmountBuilder.with_coin_and_asset(outputAmount, multiAsset);
|
|
280
|
+
const txOutput = txOutputAmountBuilder.build();
|
|
281
|
+
outputs.add(txOutput);
|
|
282
|
+
}
|
|
283
|
+
else {
|
|
284
|
+
outputs.add(CardanoWasm.TransactionOutput.new(utils_1.default.getWalletAddress(output.address), CardanoWasm.Value.new(CardanoWasm.BigNum.from_str(output.amount))));
|
|
285
|
+
}
|
|
185
286
|
});
|
|
186
287
|
if (this._changeAddress && this._senderBalance) {
|
|
187
|
-
const changeAddress =
|
|
288
|
+
const changeAddress = utils_1.default.getWalletAddress(this._changeAddress);
|
|
188
289
|
const utxoBalance = CardanoWasm.BigNum.from_str(this._senderBalance);
|
|
189
290
|
const adjustment = cardano_serialization_lib_nodejs_1.BigNum.from_str('2000000');
|
|
190
291
|
let change = utxoBalance.checked_sub(this._fee).checked_sub(totalAmountToSend);
|
|
@@ -194,13 +295,55 @@ class TransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
|
|
|
194
295
|
else if (this._type === sdk_core_1.TransactionType.StakingDeactivate) {
|
|
195
296
|
change = change.checked_add(adjustment);
|
|
196
297
|
}
|
|
197
|
-
else if (this._type
|
|
298
|
+
else if (this._type === sdk_core_1.TransactionType.StakingWithdraw || this._type === sdk_core_1.TransactionType.StakingClaim) {
|
|
198
299
|
this._withdrawals.forEach((withdrawal) => {
|
|
199
300
|
change = change.checked_add(CardanoWasm.BigNum.from_str(withdrawal.value));
|
|
200
301
|
});
|
|
201
302
|
}
|
|
202
|
-
|
|
203
|
-
|
|
303
|
+
// If totalAmountToSend is 0, its consolidation
|
|
304
|
+
if (totalAmountToSend.to_str() == '0') {
|
|
305
|
+
// support for multi-asset consolidation
|
|
306
|
+
if (this._multiAssets !== undefined) {
|
|
307
|
+
const totalNumberOfAssets = CardanoWasm.BigNum.from_str(this._multiAssets.length.toString());
|
|
308
|
+
const minAmountNeededForOneAssetOutput = CardanoWasm.BigNum.from_str('1500000');
|
|
309
|
+
const minAmountNeededForTotalAssetOutputs = minAmountNeededForOneAssetOutput.checked_mul(totalNumberOfAssets);
|
|
310
|
+
if (!change.less_than(minAmountNeededForTotalAssetOutputs)) {
|
|
311
|
+
this._multiAssets.forEach((asset) => {
|
|
312
|
+
let txOutputBuilder = CardanoWasm.TransactionOutputBuilder.new();
|
|
313
|
+
// changeAddress is the root address, which is where we want the tokens assets to be sent to
|
|
314
|
+
const toAddress = utils_1.default.getWalletAddress(this._changeAddress);
|
|
315
|
+
txOutputBuilder = txOutputBuilder.with_address(toAddress);
|
|
316
|
+
let txOutputAmountBuilder = txOutputBuilder.next();
|
|
317
|
+
const assetName = CardanoWasm.AssetName.new(Buffer.from(asset.asset_name, 'hex'));
|
|
318
|
+
const policyId = CardanoWasm.ScriptHash.from_bytes(Buffer.from(asset.policy_id, 'hex'));
|
|
319
|
+
const multiAsset = CardanoWasm.MultiAsset.new();
|
|
320
|
+
const assets = CardanoWasm.Assets.new();
|
|
321
|
+
assets.insert(assetName, CardanoWasm.BigNum.from_str(asset.quantity));
|
|
322
|
+
multiAsset.insert(policyId, assets);
|
|
323
|
+
txOutputAmountBuilder = txOutputAmountBuilder.with_coin_and_asset(minAmountNeededForOneAssetOutput, multiAsset);
|
|
324
|
+
const txOutput = txOutputAmountBuilder.build();
|
|
325
|
+
outputs.add(txOutput);
|
|
326
|
+
});
|
|
327
|
+
// finally send the remaining ADA in its own output
|
|
328
|
+
const remainingOutputAmount = change.checked_sub(minAmountNeededForTotalAssetOutputs);
|
|
329
|
+
const changeOutput = CardanoWasm.TransactionOutput.new(changeAddress, CardanoWasm.Value.new(remainingOutputAmount));
|
|
330
|
+
outputs.add(changeOutput);
|
|
331
|
+
}
|
|
332
|
+
else {
|
|
333
|
+
throw new sdk_core_1.BuildTransactionError('Insufficient funds: need a minimum of 1.5 ADA per output to construct token consolidation');
|
|
334
|
+
}
|
|
335
|
+
}
|
|
336
|
+
else {
|
|
337
|
+
// If there are no tokens to consolidate, you only have 1 output which is ADA alone
|
|
338
|
+
const changeOutput = CardanoWasm.TransactionOutput.new(changeAddress, CardanoWasm.Value.new(change));
|
|
339
|
+
outputs.add(changeOutput);
|
|
340
|
+
}
|
|
341
|
+
}
|
|
342
|
+
else {
|
|
343
|
+
// If this isn't a consolidate request, whatever change that needs to be sent back to the rootaddress is added as a separate output here
|
|
344
|
+
const changeOutput = CardanoWasm.TransactionOutput.new(changeAddress, CardanoWasm.Value.new(change));
|
|
345
|
+
outputs.add(changeOutput);
|
|
346
|
+
}
|
|
204
347
|
}
|
|
205
348
|
const txRaw = CardanoWasm.TransactionBody.new_tx_body(inputs, outputs, this._fee);
|
|
206
349
|
const certs = CardanoWasm.Certificates.new();
|
|
@@ -228,10 +371,13 @@ class TransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
|
|
|
228
371
|
const vkeyWitness = CardanoWasm.make_vkey_witness(txRawHash, CardanoWasm.PrivateKey.from_normal_bytes(Buffer.from(prv, 'hex')));
|
|
229
372
|
vkeyWitnesses.add(vkeyWitness);
|
|
230
373
|
});
|
|
231
|
-
|
|
374
|
+
// Clear the cosmetic signature array in native txn wrapper to prevent duplicate when builder is inited from a partially witnessed txn
|
|
375
|
+
this._transaction.signature.length = 0;
|
|
376
|
+
this.getAllSignatures().forEach((signature) => {
|
|
232
377
|
const vkey = CardanoWasm.Vkey.new(CardanoWasm.PublicKey.from_bytes(Buffer.from(signature.publicKey.pub, 'hex')));
|
|
233
378
|
const ed255Sig = CardanoWasm.Ed25519Signature.from_bytes(signature.signature);
|
|
234
379
|
vkeyWitnesses.add(CardanoWasm.Vkeywitness.new(vkey, ed255Sig));
|
|
380
|
+
this._transaction.signature.push(signature.signature.toString('hex'));
|
|
235
381
|
});
|
|
236
382
|
witnessSet.set_vkeys(vkeyWitnesses);
|
|
237
383
|
this._transaction.transaction = CardanoWasm.Transaction.new(txRaw, witnessSet);
|
|
@@ -291,6 +437,9 @@ class TransactionBuilder extends sdk_core_1.BaseTransactionBuilder {
|
|
|
291
437
|
addSignature(publicKey, signature) {
|
|
292
438
|
this._signatures.push({ publicKey, signature });
|
|
293
439
|
}
|
|
440
|
+
getAllSignatures() {
|
|
441
|
+
return this._initSignatures.concat(this._signatures);
|
|
442
|
+
}
|
|
294
443
|
}
|
|
295
444
|
exports.TransactionBuilder = TransactionBuilder;
|
|
296
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transactionBuilder.js","sourceRoot":"","sources":["../../../src/lib/transactionBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import BigNumber from 'bignumber.js';\nimport { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport {\n  BaseAddress,\n  BaseKey,\n  BaseTransactionBuilder,\n  BuildTransactionError,\n  PublicKey as BasePublicKey,\n  Signature,\n  TransactionType,\n  UtilsError,\n} from '@bitgo-beta/sdk-core';\nimport { Transaction, TransactionInput, TransactionOutput, Withdrawal } from './transaction';\nimport { KeyPair } from './keyPair';\nimport util from './utils';\nimport * as CardanoWasm from '@emurgo/cardano-serialization-lib-nodejs';\nimport { BigNum } from '@emurgo/cardano-serialization-lib-nodejs';\n\nexport abstract class TransactionBuilder extends BaseTransactionBuilder {\n  protected _transaction!: Transaction;\n  protected _signers: KeyPair[] = [];\n  protected _transactionInputs: TransactionInput[] = [];\n  protected _transactionOutputs: TransactionOutput[] = [];\n  protected _signatures: Signature[] = [];\n  protected _changeAddress: string;\n  protected _senderBalance: string;\n  protected _ttl = 0;\n  protected _certs: CardanoWasm.Certificate[] = [];\n  protected _withdrawals: Withdrawal[] = [];\n  protected _type: TransactionType;\n  private _fee: BigNum;\n\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n    this.transaction = new Transaction(_coinConfig);\n    this._fee = BigNum.zero();\n  }\n\n  input(i: TransactionInput): this {\n    this._transactionInputs.push(i);\n    return this;\n  }\n\n  output(o: TransactionOutput): this {\n    this._transactionOutputs.push(o);\n    return this;\n  }\n\n  ttl(t: number): this {\n    this._ttl = t;\n    return this;\n  }\n\n  changeAddress(addr: string, totalInputBalance: string): this {\n    this._changeAddress = addr;\n    this._senderBalance = totalInputBalance;\n    return this;\n  }\n\n  fee(fee: string): this {\n    this._fee = BigNum.from_str(fee);\n    return this;\n  }\n\n  /**\n   * Initialize the transaction builder fields using the decoded transaction data\n   *\n   * @param {Transaction} tx the transaction data\n   */\n  initBuilder(tx: Transaction): void {\n    this._transaction = tx;\n    const txnBody = tx.transaction.body();\n    for (let i = 0; i < txnBody.inputs().len(); i++) {\n      const input = txnBody.inputs().get(i);\n      this.input({\n        transaction_id: Buffer.from(input.transaction_id().to_bytes()).toString('hex'),\n        transaction_index: input.index(),\n      });\n    }\n    for (let i = 0; i < txnBody.outputs().len(); i++) {\n      const output = txnBody.outputs().get(i);\n      this.output({\n        address: output.address().to_bech32(),\n        amount: output.amount().coin().to_str(),\n      });\n    }\n\n    if (txnBody.certs() !== undefined) {\n      const certs = txnBody.certs() as CardanoWasm.Certificates;\n      for (let i = 0; i < certs.len(); i++) {\n        this._certs.push(certs.get(i));\n      }\n    }\n\n    if (txnBody.withdrawals() !== undefined) {\n      const withdrawals = txnBody.withdrawals() as CardanoWasm.Withdrawals;\n      const keys = withdrawals.keys();\n      for (let i = 0; i < keys.len(); i++) {\n        const rewardAddress = keys.get(i) as CardanoWasm.RewardAddress;\n        const reward = withdrawals.get(rewardAddress) as CardanoWasm.BigNum;\n        this._withdrawals.push({ stakeAddress: rewardAddress.to_address().to_bech32(), value: reward.to_str() });\n      }\n    }\n\n    this._ttl = tx.transaction.body().ttl() as number;\n    this._fee = tx.transaction.body().fee();\n  }\n\n  /** @inheritdoc */\n  protected fromImplementation(rawTransaction: string): Transaction {\n    this.validateRawTransaction(rawTransaction);\n    this.buildImplementation();\n    return this.transaction;\n  }\n\n  /** @inheritdoc */\n  protected async buildImplementation(): Promise<Transaction> {\n    const inputs = CardanoWasm.TransactionInputs.new();\n    this._transactionInputs.forEach((input) => {\n      inputs.add(\n        CardanoWasm.TransactionInput.new(\n          CardanoWasm.TransactionHash.from_bytes(Buffer.from(input.transaction_id, 'hex')),\n          input.transaction_index\n        )\n      );\n    });\n    let outputs = CardanoWasm.TransactionOutputs.new();\n    let totalAmountToSend = CardanoWasm.BigNum.zero();\n    this._transactionOutputs.forEach((output) => {\n      const amount = CardanoWasm.BigNum.from_str(output.amount);\n      outputs.add(\n        CardanoWasm.TransactionOutput.new(\n          CardanoWasm.Address.from_bech32(output.address),\n          CardanoWasm.Value.new(amount)\n        )\n      );\n      totalAmountToSend = totalAmountToSend.checked_add(amount);\n    });\n\n    if (this._fee.is_zero()) {\n      // estimate fee\n      // add extra output for the change\n      if (this._changeAddress && this._senderBalance) {\n        const changeAddress = CardanoWasm.Address.from_bech32(this._changeAddress);\n        const mockChange = CardanoWasm.TransactionOutput.new(\n          changeAddress,\n          CardanoWasm.Value.new(CardanoWasm.BigNum.from_str(this._senderBalance))\n        );\n        outputs.add(mockChange);\n      }\n\n      const txBody = CardanoWasm.TransactionBody.new_tx_body(inputs, outputs, this._fee);\n      txBody.set_ttl(CardanoWasm.BigNum.from_str(this._ttl.toString()));\n      const txHash = CardanoWasm.hash_transaction(txBody);\n\n      // we add witnesses once so that we can get the appropriate amount of signers for calculating the fee\n      const witnessSet = CardanoWasm.TransactionWitnessSet.new();\n      const vkeyWitnesses = CardanoWasm.Vkeywitnesses.new();\n      this._signers.forEach((keyPair) => {\n        const prv = keyPair.getKeys().prv as string;\n        const vkeyWitness = CardanoWasm.make_vkey_witness(\n          txHash,\n          CardanoWasm.PrivateKey.from_normal_bytes(Buffer.from(prv, 'hex'))\n        );\n        vkeyWitnesses.add(vkeyWitness);\n      });\n      this._signatures.forEach((signature) => {\n        const vkey = CardanoWasm.Vkey.new(\n          CardanoWasm.PublicKey.from_bytes(Buffer.from(signature.publicKey.pub, 'hex'))\n        );\n        const ed255Sig = CardanoWasm.Ed25519Signature.from_bytes(signature.signature);\n        vkeyWitnesses.add(CardanoWasm.Vkeywitness.new(vkey, ed255Sig));\n      });\n      if (vkeyWitnesses.len() === 0) {\n        const prv = CardanoWasm.PrivateKey.generate_ed25519();\n        const vkeyWitness = CardanoWasm.make_vkey_witness(txHash, prv);\n        vkeyWitnesses.add(vkeyWitness);\n        if (this._type !== TransactionType.Send) {\n          vkeyWitnesses.add(vkeyWitness);\n        }\n      }\n      witnessSet.set_vkeys(vkeyWitnesses);\n\n      // add in withdrawal if this is a withdrawal tx\n      if (this._withdrawals.length > 0) {\n        const withdrawals = CardanoWasm.Withdrawals.new();\n        this._withdrawals.forEach((withdrawal: Withdrawal) => {\n          const rewardAddress = CardanoWasm.RewardAddress.from_address(\n            CardanoWasm.Address.from_bech32(withdrawal.stakeAddress)\n          );\n          withdrawals.insert(rewardAddress!, CardanoWasm.BigNum.from_str(withdrawal.value));\n        });\n\n        txBody.set_withdrawals(withdrawals);\n      }\n\n      // add in certificates to get mock size\n      const draftCerts = CardanoWasm.Certificates.new();\n      for (const cert of this._certs) {\n        draftCerts.add(cert);\n      }\n      txBody.set_certs(draftCerts);\n\n      const txDraft = CardanoWasm.Transaction.new(txBody, witnessSet);\n      const linearFee = CardanoWasm.LinearFee.new(\n        CardanoWasm.BigNum.from_str('44'),\n        CardanoWasm.BigNum.from_str('155381')\n      );\n\n      // calculate the fee based off our dummy transaction\n      const fee = CardanoWasm.min_fee(txDraft, linearFee).checked_add(BigNum.from_str('440'));\n      this._fee = fee;\n    }\n    this._transaction.fee(this._fee.to_str());\n    // now calculate the change based off of <utxoBalance> - <fee> - <amountToSend>\n    // reset the outputs collection because now our last output has changed\n    outputs = CardanoWasm.TransactionOutputs.new();\n    this._transactionOutputs.forEach((output) => {\n      outputs.add(\n        CardanoWasm.TransactionOutput.new(\n          CardanoWasm.Address.from_bech32(output.address),\n          CardanoWasm.Value.new(CardanoWasm.BigNum.from_str(output.amount))\n        )\n      );\n    });\n    if (this._changeAddress && this._senderBalance) {\n      const changeAddress = CardanoWasm.Address.from_bech32(this._changeAddress);\n      const utxoBalance = CardanoWasm.BigNum.from_str(this._senderBalance);\n\n      const adjustment = BigNum.from_str('2000000');\n      let change = utxoBalance.checked_sub(this._fee).checked_sub(totalAmountToSend);\n      if (this._type === TransactionType.StakingActivate) {\n        change = change.checked_sub(adjustment);\n      } else if (this._type === TransactionType.StakingDeactivate) {\n        change = change.checked_add(adjustment);\n      } else if (this._type == TransactionType.StakingWithdraw) {\n        this._withdrawals.forEach((withdrawal: Withdrawal) => {\n          change = change.checked_add(CardanoWasm.BigNum.from_str(withdrawal.value));\n        });\n      }\n\n      const changeOutput = CardanoWasm.TransactionOutput.new(changeAddress, CardanoWasm.Value.new(change));\n      outputs.add(changeOutput);\n    }\n\n    const txRaw = CardanoWasm.TransactionBody.new_tx_body(inputs, outputs, this._fee);\n\n    const certs = CardanoWasm.Certificates.new();\n    for (const cert of this._certs) {\n      certs.add(cert);\n    }\n    txRaw.set_certs(certs);\n\n    // add in withdrawal if this is a withdrawal tx\n    if (this._withdrawals.length > 0) {\n      const withdrawals = CardanoWasm.Withdrawals.new();\n      this._withdrawals.forEach((withdrawal: Withdrawal) => {\n        const rewardAddress = CardanoWasm.RewardAddress.from_address(\n          CardanoWasm.Address.from_bech32(withdrawal.stakeAddress)\n        );\n        withdrawals.insert(rewardAddress!, CardanoWasm.BigNum.from_str(withdrawal.value));\n      });\n\n      txRaw.set_withdrawals(withdrawals);\n    }\n\n    txRaw.set_ttl(CardanoWasm.BigNum.from_str(this._ttl.toString()));\n    const txRawHash = CardanoWasm.hash_transaction(txRaw);\n\n    // now add the witnesses again this time for real. We need to do this again\n    // because now that we've added our real fee and change output, we have a difference transaction hash\n    const witnessSet = CardanoWasm.TransactionWitnessSet.new();\n    const vkeyWitnesses = CardanoWasm.Vkeywitnesses.new();\n    this._signers.forEach((keyPair) => {\n      const prv = keyPair.getKeys().prv as string;\n      const vkeyWitness = CardanoWasm.make_vkey_witness(\n        txRawHash,\n        CardanoWasm.PrivateKey.from_normal_bytes(Buffer.from(prv, 'hex'))\n      );\n      vkeyWitnesses.add(vkeyWitness);\n    });\n    this._signatures.forEach((signature) => {\n      const vkey = CardanoWasm.Vkey.new(CardanoWasm.PublicKey.from_bytes(Buffer.from(signature.publicKey.pub, 'hex')));\n      const ed255Sig = CardanoWasm.Ed25519Signature.from_bytes(signature.signature);\n      vkeyWitnesses.add(CardanoWasm.Vkeywitness.new(vkey, ed255Sig));\n    });\n    witnessSet.set_vkeys(vkeyWitnesses);\n\n    this._transaction.transaction = CardanoWasm.Transaction.new(txRaw, witnessSet);\n    return this.transaction;\n  }\n\n  /** @inheritdoc */\n  protected signImplementation(key: BaseKey): Transaction {\n    this._signers.push(new KeyPair({ prv: key.key }));\n    return this._transaction;\n  }\n\n  /** @inheritdoc */\n  protected get transaction(): Transaction {\n    return this._transaction;\n  }\n\n  /** @inheritdoc */\n  protected set transaction(transaction: Transaction) {\n    this._transaction = transaction;\n  }\n\n  /** @inheritdoc */\n  validateAddress(address: BaseAddress, addressFormat?: string): void {\n    if (!util.isValidAddress(address.address)) {\n      throw new UtilsError('invalid address ' + address.address);\n    }\n  }\n\n  /** @inheritdoc */\n  validateKey(key: BaseKey): void {\n    try {\n      new KeyPair({ prv: key.key });\n    } catch {\n      throw new BuildTransactionError(`Key validation failed`);\n    }\n  }\n\n  /** @inheritdoc */\n  validateRawTransaction(rawTransaction: any): void {\n    try {\n      CardanoWasm.Transaction.from_bytes(rawTransaction);\n    } catch {\n      throw new BuildTransactionError('invalid raw transaction');\n    }\n  }\n\n  /** @inheritdoc */\n  validateTransaction(transaction: Transaction): void {\n    if (!transaction.transaction) {\n      return;\n    }\n  }\n\n  /** @inheritdoc */\n  validateValue(value: BigNumber): void {\n    if (value.isLessThan(0)) {\n      throw new BuildTransactionError('Value cannot be less than zero');\n    }\n  }\n  // endregion\n\n  /** @inheritDoc */\n  addSignature(publicKey: BasePublicKey, signature: Buffer): void {\n    this._signatures.push({ publicKey, signature });\n  }\n}\n"]}
|
|
445
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transactionBuilder.js","sourceRoot":"","sources":["../../../src/lib/transactionBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import BigNumber from 'bignumber.js';\nimport { BaseCoin as CoinConfig } from '@bitgo-beta/statics';\nimport {\n  BaseAddress,\n  BaseKey,\n  BaseTransactionBuilder,\n  BuildTransactionError,\n  PublicKey as BasePublicKey,\n  Signature,\n  TransactionType,\n  UtilsError,\n} from '@bitgo-beta/sdk-core';\nimport { Asset, Transaction, TransactionInput, TransactionOutput, Withdrawal } from './transaction';\nimport { KeyPair } from './keyPair';\nimport util, { MIN_ADA_FOR_ONE_ASSET } from './utils';\nimport * as CardanoWasm from '@emurgo/cardano-serialization-lib-nodejs';\nimport { BigNum } from '@emurgo/cardano-serialization-lib-nodejs';\n\nexport abstract class TransactionBuilder extends BaseTransactionBuilder {\n  protected _transaction!: Transaction;\n  protected _signers: KeyPair[] = [];\n  protected _transactionInputs: TransactionInput[] = [];\n  protected _transactionOutputs: TransactionOutput[] = [];\n  protected _initSignatures: Signature[] = [];\n  protected _signatures: Signature[] = [];\n  protected _changeAddress: string;\n  protected _senderBalance: string;\n  protected _ttl = 0;\n  protected _certs: CardanoWasm.Certificate[] = [];\n  protected _withdrawals: Withdrawal[] = [];\n  protected _type: TransactionType;\n  protected _multiAssets: Asset[] = [];\n  private _fee: BigNum;\n\n  constructor(_coinConfig: Readonly<CoinConfig>) {\n    super(_coinConfig);\n    this.transaction = new Transaction(_coinConfig);\n    this._fee = BigNum.zero();\n  }\n\n  input(i: TransactionInput): this {\n    this._transactionInputs.push(i);\n    return this;\n  }\n\n  output(o: TransactionOutput): this {\n    this._transactionOutputs.push(o);\n    return this;\n  }\n\n  assets(a: Asset): this {\n    this._multiAssets.push(a);\n    return this;\n  }\n\n  ttl(t: number): this {\n    this._ttl = t;\n    return this;\n  }\n\n  changeAddress(addr: string, totalInputBalance: string): this {\n    this._changeAddress = addr;\n    this._senderBalance = totalInputBalance;\n    return this;\n  }\n\n  fee(fee: string): this {\n    this._fee = BigNum.from_str(fee);\n    return this;\n  }\n\n  /**\n   * Initialize the transaction builder fields using the decoded transaction data\n   *\n   * @param {Transaction} tx the transaction data\n   */\n  initBuilder(tx: Transaction): void {\n    this._transaction = tx;\n    const txnBody = tx.transaction.body();\n    for (let i = 0; i < txnBody.inputs().len(); i++) {\n      const input = txnBody.inputs().get(i);\n      this.input({\n        transaction_id: Buffer.from(input.transaction_id().to_bytes()).toString('hex'),\n        transaction_index: input.index(),\n      });\n    }\n    for (let i = 0; i < txnBody.outputs().len(); i++) {\n      const output = txnBody.outputs().get(i);\n      this.output({\n        address: output.address().to_bech32(),\n        amount: output.amount().coin().to_str(),\n        multiAssets: output.amount().multiasset() || undefined,\n      });\n    }\n\n    if (txnBody.certs() !== undefined) {\n      const certs = txnBody.certs() as CardanoWasm.Certificates;\n      for (let i = 0; i < certs.len(); i++) {\n        this._certs.push(certs.get(i));\n      }\n    }\n\n    if (txnBody.withdrawals() !== undefined) {\n      const withdrawals = txnBody.withdrawals() as CardanoWasm.Withdrawals;\n      const keys = withdrawals.keys();\n      for (let i = 0; i < keys.len(); i++) {\n        const rewardAddress = keys.get(i) as CardanoWasm.RewardAddress;\n        const reward = withdrawals.get(rewardAddress) as CardanoWasm.BigNum;\n        this._withdrawals.push({ stakeAddress: rewardAddress.to_address().to_bech32(), value: reward.to_str() });\n      }\n    }\n\n    this._ttl = tx.transaction.body().ttl() as number;\n    this._fee = tx.transaction.body().fee();\n\n    if (tx.transaction.witness_set().vkeys()) {\n      const vkeys = tx.transaction.witness_set().vkeys()! as CardanoWasm.Vkeywitnesses;\n      for (let i = 0; i < vkeys.len(); i++) {\n        const vkey = vkeys.get(i);\n        this._initSignatures.push({\n          publicKey: { pub: vkey.vkey().public_key().to_hex() },\n          signature: Buffer.from(vkey.signature().to_hex(), 'hex'),\n        });\n      }\n    }\n  }\n\n  /** @inheritdoc */\n  protected fromImplementation(rawTransaction: string): Transaction {\n    this.validateRawTransaction(rawTransaction);\n    this.buildImplementation();\n    return this.transaction;\n  }\n\n  /** @inheritdoc */\n  protected async buildImplementation(): Promise<Transaction> {\n    const inputs = CardanoWasm.TransactionInputs.new();\n    this._transactionInputs.forEach((input) => {\n      inputs.add(\n        CardanoWasm.TransactionInput.new(\n          CardanoWasm.TransactionHash.from_bytes(Buffer.from(input.transaction_id, 'hex')),\n          input.transaction_index\n        )\n      );\n    });\n    let outputs = CardanoWasm.TransactionOutputs.new();\n    let totalAmountToSend = CardanoWasm.BigNum.zero();\n    this._transactionOutputs.forEach((output) => {\n      const amount = CardanoWasm.BigNum.from_str(output.amount);\n      outputs.add(\n        CardanoWasm.TransactionOutput.new(util.getWalletAddress(output.address), CardanoWasm.Value.new(amount))\n      );\n      totalAmountToSend = totalAmountToSend.checked_add(amount);\n    });\n\n    if (this._fee.is_zero()) {\n      // estimate fee\n      // add extra output for the change\n      if (this._changeAddress && this._senderBalance) {\n        const changeAddress = util.getWalletAddress(this._changeAddress);\n        const utxoBalance = CardanoWasm.BigNum.from_str(this._senderBalance);\n\n        const adjustment = BigNum.from_str('2000000');\n        let change = utxoBalance.checked_sub(this._fee).checked_sub(totalAmountToSend);\n        if (this._type === TransactionType.StakingActivate) {\n          change = change.checked_sub(adjustment);\n        } else if (this._type === TransactionType.StakingDeactivate) {\n          change = change.checked_add(adjustment);\n        } else if (this._type === TransactionType.StakingWithdraw || this._type === TransactionType.StakingClaim) {\n          this._withdrawals.forEach((withdrawal: Withdrawal) => {\n            change = change.checked_add(CardanoWasm.BigNum.from_str(withdrawal.value));\n          });\n        }\n\n        // If totalAmountToSend is 0, its consolidation\n        if (totalAmountToSend.to_str() == '0') {\n          // support for multi-asset consolidation\n          if (this._multiAssets !== undefined) {\n            const totalNumberOfAssets = CardanoWasm.BigNum.from_str(this._multiAssets.length.toString());\n            const minAmountNeededForOneAssetOutput = CardanoWasm.BigNum.from_str(MIN_ADA_FOR_ONE_ASSET);\n            const minAmountNeededForTotalAssetOutputs =\n              minAmountNeededForOneAssetOutput.checked_mul(totalNumberOfAssets);\n\n            if (!change.less_than(minAmountNeededForTotalAssetOutputs)) {\n              this._multiAssets.forEach((asset) => {\n                let txOutputBuilder = CardanoWasm.TransactionOutputBuilder.new();\n                // changeAddress is the root address, which is where we want the tokens assets to be sent to\n                const toAddress = util.getWalletAddress(this._changeAddress);\n                txOutputBuilder = txOutputBuilder.with_address(toAddress);\n                let txOutputAmountBuilder = txOutputBuilder.next();\n                const assetName = CardanoWasm.AssetName.new(Buffer.from(asset.asset_name, 'hex'));\n                const policyId = CardanoWasm.ScriptHash.from_bytes(Buffer.from(asset.policy_id, 'hex'));\n                const multiAsset = CardanoWasm.MultiAsset.new();\n                const assets = CardanoWasm.Assets.new();\n                assets.insert(assetName, CardanoWasm.BigNum.from_str(asset.quantity));\n                multiAsset.insert(policyId, assets);\n\n                txOutputAmountBuilder = txOutputAmountBuilder.with_coin_and_asset(\n                  minAmountNeededForOneAssetOutput,\n                  multiAsset\n                );\n\n                const txOutput = txOutputAmountBuilder.build();\n                outputs.add(txOutput);\n              });\n\n              // finally send the remaining ADA in its own output\n              const remainingOutputAmount = change.checked_sub(minAmountNeededForTotalAssetOutputs);\n              const changeOutput = CardanoWasm.TransactionOutput.new(\n                changeAddress,\n                CardanoWasm.Value.new(remainingOutputAmount)\n              );\n              outputs.add(changeOutput);\n            }\n          } else {\n            // If there are no tokens to consolidate, you only have 1 output which is ADA alone\n            const changeOutput = CardanoWasm.TransactionOutput.new(changeAddress, CardanoWasm.Value.new(change));\n            outputs.add(changeOutput);\n          }\n        } else {\n          // If this isn't a consolidate request, whatever change that needs to be sent back to the rootaddress is added as a separate output here\n          const changeOutput = CardanoWasm.TransactionOutput.new(changeAddress, CardanoWasm.Value.new(change));\n          outputs.add(changeOutput);\n        }\n      }\n\n      const txBody = CardanoWasm.TransactionBody.new_tx_body(inputs, outputs, this._fee);\n      txBody.set_ttl(CardanoWasm.BigNum.from_str(this._ttl.toString()));\n      const txHash = CardanoWasm.hash_transaction(txBody);\n\n      // we add witnesses once so that we can get the appropriate amount of signers for calculating the fee\n      const witnessSet = CardanoWasm.TransactionWitnessSet.new();\n      const vkeyWitnesses = CardanoWasm.Vkeywitnesses.new();\n      this._signers.forEach((keyPair) => {\n        const prv = keyPair.getKeys().prv as string;\n        const vkeyWitness = CardanoWasm.make_vkey_witness(\n          txHash,\n          CardanoWasm.PrivateKey.from_normal_bytes(Buffer.from(prv, 'hex'))\n        );\n        vkeyWitnesses.add(vkeyWitness);\n      });\n      this.getAllSignatures().forEach((signature) => {\n        const vkey = CardanoWasm.Vkey.new(\n          CardanoWasm.PublicKey.from_bytes(Buffer.from(signature.publicKey.pub, 'hex'))\n        );\n        const ed255Sig = CardanoWasm.Ed25519Signature.from_bytes(signature.signature);\n        vkeyWitnesses.add(CardanoWasm.Vkeywitness.new(vkey, ed255Sig));\n      });\n      if (vkeyWitnesses.len() === 0) {\n        const prv = CardanoWasm.PrivateKey.generate_ed25519();\n        const vkeyWitness = CardanoWasm.make_vkey_witness(txHash, prv);\n        vkeyWitnesses.add(vkeyWitness);\n        if (this._type !== TransactionType.Send) {\n          vkeyWitnesses.add(vkeyWitness);\n        }\n      }\n      witnessSet.set_vkeys(vkeyWitnesses);\n\n      // add in withdrawal if this is a withdrawal tx\n      if (this._withdrawals.length > 0) {\n        const withdrawals = CardanoWasm.Withdrawals.new();\n        this._withdrawals.forEach((withdrawal: Withdrawal) => {\n          const rewardAddress = CardanoWasm.RewardAddress.from_address(\n            CardanoWasm.Address.from_bech32(withdrawal.stakeAddress)\n          );\n          withdrawals.insert(rewardAddress!, CardanoWasm.BigNum.from_str(withdrawal.value));\n        });\n\n        txBody.set_withdrawals(withdrawals);\n      }\n\n      // add in certificates to get mock size\n      const draftCerts = CardanoWasm.Certificates.new();\n      for (const cert of this._certs) {\n        draftCerts.add(cert);\n      }\n      txBody.set_certs(draftCerts);\n\n      const txDraft = CardanoWasm.Transaction.new(txBody, witnessSet);\n      const linearFee = CardanoWasm.LinearFee.new(\n        CardanoWasm.BigNum.from_str('44'),\n        CardanoWasm.BigNum.from_str('155381')\n      );\n\n      // calculate the fee based off our dummy transaction\n      const fee = CardanoWasm.min_fee(txDraft, linearFee).checked_add(BigNum.from_str('440'));\n      this._fee = fee;\n    }\n    this._transaction.fee(this._fee.to_str());\n    // now calculate the change based off of <utxoBalance> - <fee> - <amountToSend>\n    // reset the outputs collection because now our last output has changed\n    outputs = CardanoWasm.TransactionOutputs.new();\n    this._transactionOutputs.forEach((output) => {\n      if (output.multiAssets) {\n        const policyId = output.multiAssets.keys().get(0);\n        const assets = output.multiAssets.get(policyId);\n        const assetName = assets!.keys().get(0);\n        const quantity = assets!.get(assetName);\n        let txOutputBuilder = CardanoWasm.TransactionOutputBuilder.new();\n        const outputAmount = CardanoWasm.BigNum.from_str(output.amount);\n        const toAddress = util.getWalletAddress(output.address);\n        txOutputBuilder = txOutputBuilder.with_address(toAddress);\n        let txOutputAmountBuilder = txOutputBuilder.next();\n        const multiAsset = CardanoWasm.MultiAsset.new();\n        const asset = CardanoWasm.Assets.new();\n        asset.insert(assetName, quantity!);\n        multiAsset.insert(policyId, asset);\n        txOutputAmountBuilder = txOutputAmountBuilder.with_coin_and_asset(outputAmount, multiAsset);\n        const txOutput = txOutputAmountBuilder.build();\n        outputs.add(txOutput);\n      } else {\n        outputs.add(\n          CardanoWasm.TransactionOutput.new(\n            util.getWalletAddress(output.address),\n            CardanoWasm.Value.new(CardanoWasm.BigNum.from_str(output.amount))\n          )\n        );\n      }\n    });\n    if (this._changeAddress && this._senderBalance) {\n      const changeAddress = util.getWalletAddress(this._changeAddress);\n      const utxoBalance = CardanoWasm.BigNum.from_str(this._senderBalance);\n\n      const adjustment = BigNum.from_str('2000000');\n      let change = utxoBalance.checked_sub(this._fee).checked_sub(totalAmountToSend);\n      if (this._type === TransactionType.StakingActivate) {\n        change = change.checked_sub(adjustment);\n      } else if (this._type === TransactionType.StakingDeactivate) {\n        change = change.checked_add(adjustment);\n      } else if (this._type === TransactionType.StakingWithdraw || this._type === TransactionType.StakingClaim) {\n        this._withdrawals.forEach((withdrawal: Withdrawal) => {\n          change = change.checked_add(CardanoWasm.BigNum.from_str(withdrawal.value));\n        });\n      }\n\n      // If totalAmountToSend is 0, its consolidation\n      if (totalAmountToSend.to_str() == '0') {\n        // support for multi-asset consolidation\n        if (this._multiAssets !== undefined) {\n          const totalNumberOfAssets = CardanoWasm.BigNum.from_str(this._multiAssets.length.toString());\n          const minAmountNeededForOneAssetOutput = CardanoWasm.BigNum.from_str('1500000');\n          const minAmountNeededForTotalAssetOutputs = minAmountNeededForOneAssetOutput.checked_mul(totalNumberOfAssets);\n\n          if (!change.less_than(minAmountNeededForTotalAssetOutputs)) {\n            this._multiAssets.forEach((asset) => {\n              let txOutputBuilder = CardanoWasm.TransactionOutputBuilder.new();\n              // changeAddress is the root address, which is where we want the tokens assets to be sent to\n              const toAddress = util.getWalletAddress(this._changeAddress);\n              txOutputBuilder = txOutputBuilder.with_address(toAddress);\n              let txOutputAmountBuilder = txOutputBuilder.next();\n              const assetName = CardanoWasm.AssetName.new(Buffer.from(asset.asset_name, 'hex'));\n              const policyId = CardanoWasm.ScriptHash.from_bytes(Buffer.from(asset.policy_id, 'hex'));\n              const multiAsset = CardanoWasm.MultiAsset.new();\n              const assets = CardanoWasm.Assets.new();\n              assets.insert(assetName, CardanoWasm.BigNum.from_str(asset.quantity));\n              multiAsset.insert(policyId, assets);\n\n              txOutputAmountBuilder = txOutputAmountBuilder.with_coin_and_asset(\n                minAmountNeededForOneAssetOutput,\n                multiAsset\n              );\n\n              const txOutput = txOutputAmountBuilder.build();\n              outputs.add(txOutput);\n            });\n\n            // finally send the remaining ADA in its own output\n            const remainingOutputAmount = change.checked_sub(minAmountNeededForTotalAssetOutputs);\n            const changeOutput = CardanoWasm.TransactionOutput.new(\n              changeAddress,\n              CardanoWasm.Value.new(remainingOutputAmount)\n            );\n            outputs.add(changeOutput);\n          } else {\n            throw new BuildTransactionError(\n              'Insufficient funds: need a minimum of 1.5 ADA per output to construct token consolidation'\n            );\n          }\n        } else {\n          // If there are no tokens to consolidate, you only have 1 output which is ADA alone\n          const changeOutput = CardanoWasm.TransactionOutput.new(changeAddress, CardanoWasm.Value.new(change));\n          outputs.add(changeOutput);\n        }\n      } else {\n        // If this isn't a consolidate request, whatever change that needs to be sent back to the rootaddress is added as a separate output here\n        const changeOutput = CardanoWasm.TransactionOutput.new(changeAddress, CardanoWasm.Value.new(change));\n        outputs.add(changeOutput);\n      }\n    }\n\n    const txRaw = CardanoWasm.TransactionBody.new_tx_body(inputs, outputs, this._fee);\n\n    const certs = CardanoWasm.Certificates.new();\n    for (const cert of this._certs) {\n      certs.add(cert);\n    }\n    txRaw.set_certs(certs);\n\n    // add in withdrawal if this is a withdrawal tx\n    if (this._withdrawals.length > 0) {\n      const withdrawals = CardanoWasm.Withdrawals.new();\n      this._withdrawals.forEach((withdrawal: Withdrawal) => {\n        const rewardAddress = CardanoWasm.RewardAddress.from_address(\n          CardanoWasm.Address.from_bech32(withdrawal.stakeAddress)\n        );\n        withdrawals.insert(rewardAddress!, CardanoWasm.BigNum.from_str(withdrawal.value));\n      });\n\n      txRaw.set_withdrawals(withdrawals);\n    }\n\n    txRaw.set_ttl(CardanoWasm.BigNum.from_str(this._ttl.toString()));\n    const txRawHash = CardanoWasm.hash_transaction(txRaw);\n\n    // now add the witnesses again this time for real. We need to do this again\n    // because now that we've added our real fee and change output, we have a difference transaction hash\n    const witnessSet = CardanoWasm.TransactionWitnessSet.new();\n    const vkeyWitnesses = CardanoWasm.Vkeywitnesses.new();\n    this._signers.forEach((keyPair) => {\n      const prv = keyPair.getKeys().prv as string;\n      const vkeyWitness = CardanoWasm.make_vkey_witness(\n        txRawHash,\n        CardanoWasm.PrivateKey.from_normal_bytes(Buffer.from(prv, 'hex'))\n      );\n      vkeyWitnesses.add(vkeyWitness);\n    });\n\n    // Clear the cosmetic signature array in native txn wrapper to prevent duplicate when builder is inited from a partially witnessed txn\n    this._transaction.signature.length = 0;\n    this.getAllSignatures().forEach((signature) => {\n      const vkey = CardanoWasm.Vkey.new(CardanoWasm.PublicKey.from_bytes(Buffer.from(signature.publicKey.pub, 'hex')));\n      const ed255Sig = CardanoWasm.Ed25519Signature.from_bytes(signature.signature);\n      vkeyWitnesses.add(CardanoWasm.Vkeywitness.new(vkey, ed255Sig));\n      this._transaction.signature.push(signature.signature.toString('hex'));\n    });\n    witnessSet.set_vkeys(vkeyWitnesses);\n    this._transaction.transaction = CardanoWasm.Transaction.new(txRaw, witnessSet);\n    return this.transaction;\n  }\n\n  /** @inheritdoc */\n  protected signImplementation(key: BaseKey): Transaction {\n    this._signers.push(new KeyPair({ prv: key.key }));\n    return this._transaction;\n  }\n\n  /** @inheritdoc */\n  protected get transaction(): Transaction {\n    return this._transaction;\n  }\n\n  /** @inheritdoc */\n  protected set transaction(transaction: Transaction) {\n    this._transaction = transaction;\n  }\n\n  /** @inheritdoc */\n  validateAddress(address: BaseAddress, addressFormat?: string): void {\n    if (!util.isValidAddress(address.address)) {\n      throw new UtilsError('invalid address ' + address.address);\n    }\n  }\n\n  /** @inheritdoc */\n  validateKey(key: BaseKey): void {\n    try {\n      new KeyPair({ prv: key.key });\n    } catch {\n      throw new BuildTransactionError(`Key validation failed`);\n    }\n  }\n\n  /** @inheritdoc */\n  validateRawTransaction(rawTransaction: any): void {\n    try {\n      CardanoWasm.Transaction.from_bytes(rawTransaction);\n    } catch {\n      throw new BuildTransactionError('invalid raw transaction');\n    }\n  }\n\n  /** @inheritdoc */\n  validateTransaction(transaction: Transaction): void {\n    if (!transaction.transaction) {\n      return;\n    }\n  }\n\n  /** @inheritdoc */\n  validateValue(value: BigNumber): void {\n    if (value.isLessThan(0)) {\n      throw new BuildTransactionError('Value cannot be less than zero');\n    }\n  }\n  // endregion\n\n  /** @inheritDoc */\n  addSignature(publicKey: BasePublicKey, signature: Buffer): void {\n    this._signatures.push({ publicKey, signature });\n  }\n\n  private getAllSignatures(): Signature[] {\n    return this._initSignatures.concat(this._signatures);\n  }\n}\n"]}
|
|
@@ -6,7 +6,10 @@ import { TransactionBuilder } from './transactionBuilder';
|
|
|
6
6
|
import { Transaction } from './transaction';
|
|
7
7
|
import { StakingActivateBuilder } from './stakingActivateBuilder';
|
|
8
8
|
import { StakingDeactivateBuilder } from './stakingDeactivateBuilder';
|
|
9
|
-
import {
|
|
9
|
+
import { StakingWithdrawBuilder } from './stakingWithdrawBuilder';
|
|
10
|
+
import { StakingPledgeBuilder } from './stakingPledgeBuilder';
|
|
11
|
+
import { StakingClaimRewardsBuilder } from './stakingClaimRewardsBuilder';
|
|
12
|
+
import { VoteDelegationBuilder } from './voteDelegationBuilder';
|
|
10
13
|
export declare class TransactionBuilderFactory extends BaseTransactionBuilderFactory {
|
|
11
14
|
constructor(_coinConfig: Readonly<CoinConfig>);
|
|
12
15
|
/** @inheritdoc */
|
|
@@ -16,8 +19,11 @@ export declare class TransactionBuilderFactory extends BaseTransactionBuilderFac
|
|
|
16
19
|
/** @inheritdoc */
|
|
17
20
|
getTransferBuilder(tx?: Transaction): TransferBuilder;
|
|
18
21
|
getStakingActivateBuilder(tx?: Transaction): StakingActivateBuilder;
|
|
22
|
+
getVoteDelegationBuilder(tx?: Transaction): VoteDelegationBuilder;
|
|
23
|
+
getStakingClaimRewardsBuilder(tx?: Transaction): StakingClaimRewardsBuilder;
|
|
19
24
|
getStakingDeactivateBuilder(tx?: Transaction): StakingDeactivateBuilder;
|
|
20
|
-
getStakingWithdrawBuilder(tx?: Transaction):
|
|
25
|
+
getStakingWithdrawBuilder(tx?: Transaction): StakingWithdrawBuilder;
|
|
26
|
+
getStakingPledgeBuilder(tx?: Transaction): StakingPledgeBuilder;
|
|
21
27
|
/**
|
|
22
28
|
* Initialize the builder with the given transaction
|
|
23
29
|
*
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"transactionBuilderFactory.d.ts","sourceRoot":"","sources":["../../../src/lib/transactionBuilderFactory.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,6BAA6B,EAA4C,MAAM,sBAAsB,CAAC;AAC/G,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAE,2BAA2B,EAAE,MAAM,+BAA+B,CAAC;AAC5E,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,sBAAsB,EAAE,MAAM,0BAA0B,CAAC;AAClE,OAAO,EAAE,wBAAwB,EAAE,MAAM,4BAA4B,CAAC;AACtE,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"transactionBuilderFactory.d.ts","sourceRoot":"","sources":["../../../src/lib/transactionBuilderFactory.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,IAAI,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,6BAA6B,EAA4C,MAAM,sBAAsB,CAAC;AAC/G,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAE,2BAA2B,EAAE,MAAM,+BAA+B,CAAC;AAC5E,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,sBAAsB,EAAE,MAAM,0BAA0B,CAAC;AAClE,OAAO,EAAE,wBAAwB,EAAE,MAAM,4BAA4B,CAAC;AACtE,OAAO,EAAE,sBAAsB,EAAE,MAAM,0BAA0B,CAAC;AAClE,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AAC9D,OAAO,EAAE,0BAA0B,EAAE,MAAM,8BAA8B,CAAC;AAC1E,OAAO,EAAE,qBAAqB,EAAE,MAAM,yBAAyB,CAAC;AAEhE,qBAAa,yBAA0B,SAAQ,6BAA6B;gBAC9D,WAAW,EAAE,QAAQ,CAAC,UAAU,CAAC;IAI7C,kBAAkB;IAClB,IAAI,CAAC,GAAG,EAAE,UAAU,GAAG,MAAM,GAAG,kBAAkB;IAgClD,kBAAkB;IAClB,8BAA8B,CAAC,EAAE,CAAC,EAAE,WAAW,GAAG,2BAA2B;IAI7E,kBAAkB;IAClB,kBAAkB,CAAC,EAAE,CAAC,EAAE,WAAW,GAAG,eAAe;IAIrD,yBAAyB,CAAC,EAAE,CAAC,EAAE,WAAW,GAAG,sBAAsB;IAInE,wBAAwB,CAAC,EAAE,CAAC,EAAE,WAAW,GAAG,qBAAqB;IAIjE,6BAA6B,CAAC,EAAE,CAAC,EAAE,WAAW,GAAG,0BAA0B;IAI3E,2BAA2B,CAAC,EAAE,CAAC,EAAE,WAAW,GAAG,wBAAwB;IAIvE,yBAAyB,CAAC,EAAE,CAAC,EAAE,WAAW,GAAG,sBAAsB;IAInE,uBAAuB,CAAC,EAAE,CAAC,EAAE,WAAW,GAAG,oBAAoB;IAI/D;;;;;;OAMG;IACH,OAAO,CAAC,MAAM,CAAC,iBAAiB;CAMjC"}
|