@vultisig/core-mpc 1.2.2 → 1.2.3
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 +7 -0
- package/dist/keysign/chainSpecific/resolvers/solana/index.d.ts.map +1 -1
- package/dist/keysign/chainSpecific/resolvers/solana/index.js +20 -11
- package/dist/keysign/chainSpecific/resolvers/solana/index.js.map +1 -1
- package/dist/keysign/fee/resolvers/solana.d.ts.map +1 -1
- package/dist/keysign/fee/resolvers/solana.js +13 -2
- package/dist/keysign/fee/resolvers/solana.js.map +1 -1
- package/dist/keysign/signingInputs/resolvers/solana/send.d.ts.map +1 -1
- package/dist/keysign/signingInputs/resolvers/solana/send.js +7 -2
- package/dist/keysign/signingInputs/resolvers/solana/send.js.map +1 -1
- package/package.json +2 -7
- package/dist/keysign/chainSpecific/resolvers/solana/refine.d.ts +0 -12
- package/dist/keysign/chainSpecific/resolvers/solana/refine.d.ts.map +0 -1
- package/dist/keysign/chainSpecific/resolvers/solana/refine.js +0 -53
- package/dist/keysign/chainSpecific/resolvers/solana/refine.js.map +0 -1
package/CHANGELOG.md
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../../../packages/core/mpc/keysign/chainSpecific/resolvers/solana/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../../../packages/core/mpc/keysign/chainSpecific/resolvers/solana/index.ts"],"names":[],"mappings":"AAYA,OAAO,EAAE,wBAAwB,EAAE,MAAM,gBAAgB,CAAA;AAEzD,eAAO,MAAM,sBAAsB,EAAE,wBAAwB,CAC3D,gBAAgB,CAsDjB,CAAA"}
|
|
@@ -1,24 +1,31 @@
|
|
|
1
1
|
import { create } from '@bufbuild/protobuf';
|
|
2
|
+
import { PublicKey } from '@solana/web3.js';
|
|
2
3
|
import { getSolanaClient } from '@vultisig/core-chain/chains/solana/client';
|
|
4
|
+
import { getDynamicPriorityFeePrice } from '@vultisig/core-chain/chains/solana/getDynamicPriorityFeePrice';
|
|
3
5
|
import { solanaConfig } from '@vultisig/core-chain/chains/solana/solanaConfig';
|
|
4
6
|
import { getSplAssociatedAccount } from '@vultisig/core-chain/chains/solana/spl/getSplAssociatedAccount';
|
|
5
7
|
import { SolanaSpecificSchema } from '@vultisig/core-mpc/types/vultisig/keysign/v1/blockchain_specific_pb';
|
|
6
8
|
import { shouldBePresent } from '@vultisig/lib-utils/assert/shouldBePresent';
|
|
7
9
|
import { attempt, withFallback } from '@vultisig/lib-utils/attempt';
|
|
8
10
|
import { getKeysignCoin } from '../../../utils/getKeysignCoin.js';
|
|
9
|
-
|
|
10
|
-
import { getDynamicPriorityFeePrice } from '@vultisig/core-chain/chains/solana/getDynamicPriorityFeePrice';
|
|
11
|
-
export const getSolanaChainSpecific = async ({ keysignPayload, walletCore }) => {
|
|
11
|
+
export const getSolanaChainSpecific = async ({ keysignPayload }) => {
|
|
12
12
|
const coin = getKeysignCoin(keysignPayload);
|
|
13
13
|
const receiver = shouldBePresent(keysignPayload.toAddress);
|
|
14
14
|
const client = getSolanaClient();
|
|
15
|
-
const priorityFeePrice = await withFallback(attempt(getDynamicPriorityFeePrice()), solanaConfig.priorityFeePrice);
|
|
16
15
|
const recentBlockHash = (await client.getLatestBlockhash()).blockhash;
|
|
17
16
|
const chainSpecific = create(SolanaSpecificSchema, {
|
|
18
17
|
recentBlockHash,
|
|
19
|
-
priorityFee: priorityFeePrice.toString(),
|
|
20
18
|
computeLimit: solanaConfig.priorityFeeLimit.toString(),
|
|
21
19
|
});
|
|
20
|
+
// Scope the priority-fee query to slots that wrote to the contended
|
|
21
|
+
// accounts on this transaction. The global feed is dominated by vote
|
|
22
|
+
// txs and underestimates fees for hot accounts (e.g. a THORChain
|
|
23
|
+
// inbound vault during LP add).
|
|
24
|
+
//
|
|
25
|
+
// For native SOL the recipient lamports change, so it's writable.
|
|
26
|
+
// For SPL the SystemProgram never touches the recipient's main
|
|
27
|
+
// wallet — only the sender/recipient ATAs are writable.
|
|
28
|
+
const writableAccounts = [];
|
|
22
29
|
if (coin.id) {
|
|
23
30
|
const fromAccount = await getSplAssociatedAccount({
|
|
24
31
|
account: coin.address,
|
|
@@ -26,19 +33,21 @@ export const getSolanaChainSpecific = async ({ keysignPayload, walletCore }) =>
|
|
|
26
33
|
});
|
|
27
34
|
chainSpecific.fromTokenAssociatedAddress = fromAccount.address;
|
|
28
35
|
chainSpecific.programId = fromAccount.isToken2022;
|
|
36
|
+
writableAccounts.push(new PublicKey(fromAccount.address));
|
|
29
37
|
const { data } = await attempt(getSplAssociatedAccount({
|
|
30
38
|
account: receiver,
|
|
31
39
|
token: coin.id,
|
|
32
40
|
}));
|
|
33
41
|
if (data) {
|
|
34
42
|
chainSpecific.toTokenAssociatedAddress = data.address;
|
|
43
|
+
writableAccounts.push(new PublicKey(data.address));
|
|
35
44
|
}
|
|
36
45
|
}
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
46
|
+
else {
|
|
47
|
+
writableAccounts.push(new PublicKey(receiver));
|
|
48
|
+
}
|
|
49
|
+
const priorityFeePrice = await withFallback(attempt(getDynamicPriorityFeePrice(writableAccounts)), solanaConfig.priorityFeePrice);
|
|
50
|
+
chainSpecific.priorityFee = priorityFeePrice.toString();
|
|
51
|
+
return chainSpecific;
|
|
43
52
|
};
|
|
44
53
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../../packages/core/mpc/keysign/chainSpecific/resolvers/solana/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAA;AAE3C,OAAO,EAAE,eAAe,EAAE,MAAM,2CAA2C,CAAA;AAC3E,OAAO,EAAE,YAAY,EAAE,MAAM,iDAAiD,CAAA;AAC9E,OAAO,EAAE,uBAAuB,EAAE,MAAM,gEAAgE,CAAA;AACxG,OAAO,EAAE,oBAAoB,EAAE,MAAM,qEAAqE,CAAA;AAC1G,OAAO,EAAE,eAAe,EAAE,MAAM,4CAA4C,CAAA;AAC5E,OAAO,EAAE,OAAO,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAA;AAEnE,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAA;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../../packages/core/mpc/keysign/chainSpecific/resolvers/solana/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAA;AAC3C,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAA;AAE3C,OAAO,EAAE,eAAe,EAAE,MAAM,2CAA2C,CAAA;AAC3E,OAAO,EAAE,0BAA0B,EAAE,MAAM,+DAA+D,CAAA;AAC1G,OAAO,EAAE,YAAY,EAAE,MAAM,iDAAiD,CAAA;AAC9E,OAAO,EAAE,uBAAuB,EAAE,MAAM,gEAAgE,CAAA;AACxG,OAAO,EAAE,oBAAoB,EAAE,MAAM,qEAAqE,CAAA;AAC1G,OAAO,EAAE,eAAe,EAAE,MAAM,4CAA4C,CAAA;AAC5E,OAAO,EAAE,OAAO,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAA;AAEnE,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAA;AAG9D,MAAM,CAAC,MAAM,sBAAsB,GAE/B,KAAK,EAAE,EAAE,cAAc,EAAE,EAAE,EAAE;IAC/B,MAAM,IAAI,GAAG,cAAc,CAAoB,cAAc,CAAC,CAAA;IAC9D,MAAM,QAAQ,GAAG,eAAe,CAAC,cAAc,CAAC,SAAS,CAAC,CAAA;IAC1D,MAAM,MAAM,GAAG,eAAe,EAAE,CAAA;IAEhC,MAAM,eAAe,GAAG,CAAC,MAAM,MAAM,CAAC,kBAAkB,EAAE,CAAC,CAAC,SAAS,CAAA;IAErE,MAAM,aAAa,GAAG,MAAM,CAAC,oBAAoB,EAAE;QACjD,eAAe;QACf,YAAY,EAAE,YAAY,CAAC,gBAAgB,CAAC,QAAQ,EAAE;KACvD,CAAC,CAAA;IAEF,oEAAoE;IACpE,qEAAqE;IACrE,iEAAiE;IACjE,gCAAgC;IAChC,EAAE;IACF,kEAAkE;IAClE,+DAA+D;IAC/D,wDAAwD;IACxD,MAAM,gBAAgB,GAAgB,EAAE,CAAA;IAExC,IAAI,IAAI,CAAC,EAAE,EAAE,CAAC;QACZ,MAAM,WAAW,GAAG,MAAM,uBAAuB,CAAC;YAChD,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,KAAK,EAAE,IAAI,CAAC,EAAE;SACf,CAAC,CAAA;QACF,aAAa,CAAC,0BAA0B,GAAG,WAAW,CAAC,OAAO,CAAA;QAC9D,aAAa,CAAC,SAAS,GAAG,WAAW,CAAC,WAAW,CAAA;QACjD,gBAAgB,CAAC,IAAI,CAAC,IAAI,SAAS,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,CAAA;QAEzD,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,OAAO,CAC5B,uBAAuB,CAAC;YACtB,OAAO,EAAE,QAAQ;YACjB,KAAK,EAAE,IAAI,CAAC,EAAE;SACf,CAAC,CACH,CAAA;QACD,IAAI,IAAI,EAAE,CAAC;YACT,aAAa,CAAC,wBAAwB,GAAG,IAAI,CAAC,OAAO,CAAA;YACrD,gBAAgB,CAAC,IAAI,CAAC,IAAI,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAA;QACpD,CAAC;IACH,CAAC;SAAM,CAAC;QACN,gBAAgB,CAAC,IAAI,CAAC,IAAI,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAA;IAChD,CAAC;IAED,MAAM,gBAAgB,GAAG,MAAM,YAAY,CACzC,OAAO,CAAC,0BAA0B,CAAC,gBAAgB,CAAC,CAAC,EACrD,YAAY,CAAC,gBAAgB,CAC9B,CAAA;IAED,aAAa,CAAC,WAAW,GAAG,gBAAgB,CAAC,QAAQ,EAAE,CAAA;IAEvD,OAAO,aAAa,CAAA;AACtB,CAAC,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"solana.d.ts","sourceRoot":"","sources":["../../../../../../../packages/core/mpc/keysign/fee/resolvers/solana.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"solana.d.ts","sourceRoot":"","sources":["../../../../../../../packages/core/mpc/keysign/fee/resolvers/solana.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAA;AAI/C,eAAO,MAAM,kBAAkB,EAAE,iBAmBhC,CAAA"}
|
|
@@ -1,6 +1,17 @@
|
|
|
1
|
+
import { solanaConfig } from '@vultisig/core-chain/chains/solana/solanaConfig';
|
|
2
|
+
import { isFeeCoin } from '@vultisig/core-chain/coin/utils/isFeeCoin';
|
|
1
3
|
import { getBlockchainSpecificValue } from '../../chainSpecific/KeysignChainSpecific.js';
|
|
4
|
+
import { getKeysignCoin } from '../../utils/getKeysignCoin.js';
|
|
5
|
+
const MICRO_LAMPORTS_PER_LAMPORT = 1000000n;
|
|
2
6
|
export const getSolanaFeeAmount = ({ keysignPayload }) => {
|
|
3
|
-
const { priorityFee } = getBlockchainSpecificValue(keysignPayload.blockchainSpecific, 'solanaSpecific');
|
|
4
|
-
|
|
7
|
+
const { priorityFee, computeLimit, toTokenAssociatedAddress } = getBlockchainSpecificValue(keysignPayload.blockchainSpecific, 'solanaSpecific');
|
|
8
|
+
const priorityFeeAmount = (BigInt(priorityFee) *
|
|
9
|
+
BigInt(computeLimit ?? solanaConfig.priorityFeeLimit)) /
|
|
10
|
+
MICRO_LAMPORTS_PER_LAMPORT;
|
|
11
|
+
const coin = getKeysignCoin(keysignPayload);
|
|
12
|
+
const ataRent = !isFeeCoin(coin) && !toTokenAssociatedAddress
|
|
13
|
+
? BigInt(solanaConfig.ataRentLamports)
|
|
14
|
+
: 0n;
|
|
15
|
+
return BigInt(solanaConfig.baseFee) + ataRent + priorityFeeAmount;
|
|
5
16
|
};
|
|
6
17
|
//# sourceMappingURL=solana.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"solana.js","sourceRoot":"","sources":["../../../../../../../packages/core/mpc/keysign/fee/resolvers/solana.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,0BAA0B,EAAE,MAAM,0CAA0C,CAAA;
|
|
1
|
+
{"version":3,"file":"solana.js","sourceRoot":"","sources":["../../../../../../../packages/core/mpc/keysign/fee/resolvers/solana.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iDAAiD,CAAA;AAC9E,OAAO,EAAE,SAAS,EAAE,MAAM,2CAA2C,CAAA;AAErE,OAAO,EAAE,0BAA0B,EAAE,MAAM,0CAA0C,CAAA;AACrF,OAAO,EAAE,cAAc,EAAE,MAAM,4BAA4B,CAAA;AAG3D,MAAM,0BAA0B,GAAG,QAAU,CAAA;AAE7C,MAAM,CAAC,MAAM,kBAAkB,GAAsB,CAAC,EAAE,cAAc,EAAE,EAAE,EAAE;IAC1E,MAAM,EAAE,WAAW,EAAE,YAAY,EAAE,wBAAwB,EAAE,GAC3D,0BAA0B,CACxB,cAAc,CAAC,kBAAkB,EACjC,gBAAgB,CACjB,CAAA;IAEH,MAAM,iBAAiB,GACrB,CAAC,MAAM,CAAC,WAAW,CAAC;QAClB,MAAM,CAAC,YAAY,IAAI,YAAY,CAAC,gBAAgB,CAAC,CAAC;QACxD,0BAA0B,CAAA;IAE5B,MAAM,IAAI,GAAG,cAAc,CAAC,cAAc,CAAC,CAAA;IAC3C,MAAM,OAAO,GACX,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,wBAAwB;QAC3C,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC,eAAe,CAAC;QACtC,CAAC,CAAC,EAAE,CAAA;IAER,OAAO,MAAM,CAAC,YAAY,CAAC,OAAO,CAAC,GAAG,OAAO,GAAG,iBAAiB,CAAA;AACnE,CAAC,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"send.d.ts","sourceRoot":"","sources":["../../../../../../../../packages/core/mpc/keysign/signingInputs/resolvers/solana/send.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,iEAAiE,CAAA;
|
|
1
|
+
{"version":3,"file":"send.d.ts","sourceRoot":"","sources":["../../../../../../../../packages/core/mpc/keysign/signingInputs/resolvers/solana/send.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,iEAAiE,CAAA;AAEhG,OAAO,EAAE,EAAE,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAA;AAMzD,KAAK,8BAA8B,GAAG;IACpC,cAAc,EAAE,cAAc,CAAA;IAC9B,UAAU,EAAE,UAAU,CAAA;CACvB,CAAA;AAED,eAAO,MAAM,yBAAyB,GAAI,iCAGvC,8BAA8B,KAAG,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,YA+FnD,CAAA"}
|
|
@@ -1,11 +1,15 @@
|
|
|
1
1
|
import { solanaConfig } from '@vultisig/core-chain/chains/solana/solanaConfig';
|
|
2
|
+
import { maxBigInt } from '@vultisig/lib-utils/math/maxBigInt';
|
|
2
3
|
import { TW } from '@trustwallet/wallet-core';
|
|
3
4
|
import Long from 'long';
|
|
4
5
|
import { getBlockchainSpecificValue } from '../../../chainSpecific/KeysignChainSpecific.js';
|
|
5
6
|
import { getKeysignCoin } from '../../../utils/getKeysignCoin.js';
|
|
6
7
|
export const getSolanaSendSigningInput = ({ keysignPayload, walletCore, }) => {
|
|
7
8
|
const coin = getKeysignCoin(keysignPayload);
|
|
8
|
-
const { recentBlockHash, fromTokenAssociatedAddress, toTokenAssociatedAddress, programId, computeLimit, } = getBlockchainSpecificValue(keysignPayload.blockchainSpecific, 'solanaSpecific');
|
|
9
|
+
const { recentBlockHash, fromTokenAssociatedAddress, toTokenAssociatedAddress, programId, computeLimit, priorityFee, } = getBlockchainSpecificValue(keysignPayload.blockchainSpecific, 'solanaSpecific');
|
|
10
|
+
// Floor at the config minimum so co-signers all encode the same
|
|
11
|
+
// `setComputeUnitPrice` instruction when the wire value is missing.
|
|
12
|
+
const priorityFeePrice = maxBigInt(priorityFee ? BigInt(priorityFee) : 0n, BigInt(solanaConfig.priorityFeePrice));
|
|
9
13
|
const amount = BigInt(keysignPayload.toAmount);
|
|
10
14
|
const sender = coin.address;
|
|
11
15
|
const recipient = keysignPayload.toAddress;
|
|
@@ -28,6 +32,7 @@ export const getSolanaSendSigningInput = ({ keysignPayload, walletCore, }) => {
|
|
|
28
32
|
amount: Long.fromString(amount.toString()),
|
|
29
33
|
decimals: coin.decimals,
|
|
30
34
|
tokenProgramId,
|
|
35
|
+
memo: keysignPayload.memo,
|
|
31
36
|
};
|
|
32
37
|
if (!toTokenAssociatedAddress) {
|
|
33
38
|
const receiverSolanaAddress = walletCore.SolanaAddress.createWithString(recipient);
|
|
@@ -55,7 +60,7 @@ export const getSolanaSendSigningInput = ({ keysignPayload, walletCore, }) => {
|
|
|
55
60
|
recentBlockhash: recentBlockHash,
|
|
56
61
|
sender,
|
|
57
62
|
priorityFeePrice: TW.Solana.Proto.PriorityFeePrice.create({
|
|
58
|
-
price: Long.fromString(
|
|
63
|
+
price: Long.fromString(priorityFeePrice.toString()),
|
|
59
64
|
}),
|
|
60
65
|
priorityFeeLimit: TW.Solana.Proto.PriorityFeeLimit.create({
|
|
61
66
|
limit: computeLimit
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"send.js","sourceRoot":"","sources":["../../../../../../../../packages/core/mpc/keysign/signingInputs/resolvers/solana/send.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iDAAiD,CAAA;AAE9E,OAAO,EAAE,EAAE,EAAc,MAAM,0BAA0B,CAAA;AACzD,OAAO,IAAI,MAAM,MAAM,CAAA;AAEvB,OAAO,EAAE,0BAA0B,EAAE,MAAM,6CAA6C,CAAA;AACxF,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAA;AAO9D,MAAM,CAAC,MAAM,yBAAyB,GAAG,CAAC,EACxC,cAAc,EACd,UAAU,GACqB,EAAgC,EAAE;IACjE,MAAM,IAAI,GAAG,cAAc,CAAC,cAAc,CAAC,CAAA;IAE3C,MAAM,EACJ,eAAe,EACf,0BAA0B,EAC1B,wBAAwB,EACxB,SAAS,EACT,YAAY,
|
|
1
|
+
{"version":3,"file":"send.js","sourceRoot":"","sources":["../../../../../../../../packages/core/mpc/keysign/signingInputs/resolvers/solana/send.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@vultisig/core-mpc",
|
|
3
|
-
"version": "1.2.
|
|
3
|
+
"version": "1.2.3",
|
|
4
4
|
"description": "MPC, keysign, and vault types shared across Vultisig clients",
|
|
5
5
|
"license": "MIT",
|
|
6
6
|
"repository": {
|
|
@@ -239,11 +239,6 @@
|
|
|
239
239
|
"import": "./dist/keysign/chainSpecific/resolvers/solana/index.js",
|
|
240
240
|
"default": "./dist/keysign/chainSpecific/resolvers/solana/index.js"
|
|
241
241
|
},
|
|
242
|
-
"./keysign/chainSpecific/resolvers/solana/refine": {
|
|
243
|
-
"types": "./dist/keysign/chainSpecific/resolvers/solana/refine.d.ts",
|
|
244
|
-
"import": "./dist/keysign/chainSpecific/resolvers/solana/refine.js",
|
|
245
|
-
"default": "./dist/keysign/chainSpecific/resolvers/solana/refine.js"
|
|
246
|
-
},
|
|
247
242
|
"./keysign/chainSpecific/resolvers/sui": {
|
|
248
243
|
"types": "./dist/keysign/chainSpecific/resolvers/sui/index.d.ts",
|
|
249
244
|
"import": "./dist/keysign/chainSpecific/resolvers/sui/index.js",
|
|
@@ -972,7 +967,7 @@
|
|
|
972
967
|
"@noble/hashes": "^1.8.0",
|
|
973
968
|
"@solana/web3.js": "^1.98.4",
|
|
974
969
|
"@trustwallet/wallet-core": "^4.6.0",
|
|
975
|
-
"@vultisig/core-chain": "1.5.
|
|
970
|
+
"@vultisig/core-chain": "1.5.1",
|
|
976
971
|
"@vultisig/core-config": "0.9.1",
|
|
977
972
|
"@vultisig/lib-dkls": "0.9.0",
|
|
978
973
|
"@vultisig/lib-mldsa": "0.9.0",
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import { SolanaSpecific } from '@vultisig/core-mpc/types/vultisig/keysign/v1/blockchain_specific_pb';
|
|
2
|
-
import { KeysignPayload } from '@vultisig/core-mpc/types/vultisig/keysign/v1/keysign_message_pb';
|
|
3
|
-
import { WalletCore } from '@trustwallet/wallet-core';
|
|
4
|
-
type RefineSolanaChainSpecificInput = {
|
|
5
|
-
keysignPayload: KeysignPayload;
|
|
6
|
-
chainSpecific: SolanaSpecific;
|
|
7
|
-
priorityFeePrice: number;
|
|
8
|
-
walletCore: WalletCore;
|
|
9
|
-
};
|
|
10
|
-
export declare const refineSolanaChainSpecific: ({ keysignPayload, chainSpecific, priorityFeePrice, walletCore, }: RefineSolanaChainSpecificInput) => Promise<SolanaSpecific>;
|
|
11
|
-
export {};
|
|
12
|
-
//# sourceMappingURL=refine.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"refine.d.ts","sourceRoot":"","sources":["../../../../../../../../packages/core/mpc/keysign/chainSpecific/resolvers/solana/refine.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,cAAc,EAAE,MAAM,qEAAqE,CAAA;AACpG,OAAO,EACL,cAAc,EAEf,MAAM,iEAAiE,CAAA;AAExE,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAA;AASrD,KAAK,8BAA8B,GAAG;IACpC,cAAc,EAAE,cAAc,CAAA;IAC9B,aAAa,EAAE,cAAc,CAAA;IAC7B,gBAAgB,EAAE,MAAM,CAAA;IACxB,UAAU,EAAE,UAAU,CAAA;CACvB,CAAA;AAED,eAAO,MAAM,yBAAyB,GAAU,kEAK7C,8BAA8B,KAAG,OAAO,CAAC,cAAc,CAqDzD,CAAA"}
|
|
@@ -1,53 +0,0 @@
|
|
|
1
|
-
import { create } from '@bufbuild/protobuf';
|
|
2
|
-
import { Chain } from '@vultisig/core-chain/Chain';
|
|
3
|
-
import { getSolanaClient } from '@vultisig/core-chain/chains/solana/client';
|
|
4
|
-
import { solanaConfig } from '@vultisig/core-chain/chains/solana/solanaConfig';
|
|
5
|
-
import { isFeeCoin } from '@vultisig/core-chain/coin/utils/isFeeCoin';
|
|
6
|
-
import { KeysignPayloadSchema, } from '@vultisig/core-mpc/types/vultisig/keysign/v1/keysign_message_pb';
|
|
7
|
-
import { Message } from '@solana/web3.js';
|
|
8
|
-
import { getPreSigningOutput } from '../../../preSigningOutput/index.js';
|
|
9
|
-
import { getEncodedSigningInputs } from '../../../signingInputs/index.js';
|
|
10
|
-
import { getKeysignCoin } from '../../../utils/getKeysignCoin.js';
|
|
11
|
-
const rentExemptionAccountSize = 165;
|
|
12
|
-
const microLamportsPerLamport = 1000000n;
|
|
13
|
-
export const refineSolanaChainSpecific = async ({ keysignPayload, chainSpecific, priorityFeePrice, walletCore, }) => {
|
|
14
|
-
const coin = getKeysignCoin(keysignPayload);
|
|
15
|
-
const client = getSolanaClient();
|
|
16
|
-
const [txInputData] = getEncodedSigningInputs({
|
|
17
|
-
keysignPayload: create(KeysignPayloadSchema, {
|
|
18
|
-
...keysignPayload,
|
|
19
|
-
blockchainSpecific: {
|
|
20
|
-
case: 'solanaSpecific',
|
|
21
|
-
value: chainSpecific,
|
|
22
|
-
},
|
|
23
|
-
}),
|
|
24
|
-
walletCore,
|
|
25
|
-
});
|
|
26
|
-
const { data } = getPreSigningOutput({
|
|
27
|
-
walletCore,
|
|
28
|
-
txInputData,
|
|
29
|
-
chain: Chain.Solana,
|
|
30
|
-
});
|
|
31
|
-
const message = Message.from(data);
|
|
32
|
-
const getBaseFee = async () => {
|
|
33
|
-
const response = await client.getFeeForMessage(message, 'confirmed');
|
|
34
|
-
return BigInt(response.value ?? 0);
|
|
35
|
-
};
|
|
36
|
-
const getRentExemptionFee = async () => {
|
|
37
|
-
if (!isFeeCoin(coin) && !chainSpecific.toTokenAssociatedAddress) {
|
|
38
|
-
const rentExemption = await client.getMinimumBalanceForRentExemption(rentExemptionAccountSize);
|
|
39
|
-
return BigInt(rentExemption);
|
|
40
|
-
}
|
|
41
|
-
return 0n;
|
|
42
|
-
};
|
|
43
|
-
const baseFee = await getBaseFee();
|
|
44
|
-
const rentExemptionFee = await getRentExemptionFee();
|
|
45
|
-
const priorityFeeAmount = (BigInt(priorityFeePrice) * BigInt(solanaConfig.priorityFeeLimit)) /
|
|
46
|
-
microLamportsPerLamport;
|
|
47
|
-
const totalFee = baseFee + rentExemptionFee + priorityFeeAmount;
|
|
48
|
-
return {
|
|
49
|
-
...chainSpecific,
|
|
50
|
-
priorityFee: totalFee.toString(),
|
|
51
|
-
};
|
|
52
|
-
};
|
|
53
|
-
//# sourceMappingURL=refine.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"refine.js","sourceRoot":"","sources":["../../../../../../../../packages/core/mpc/keysign/chainSpecific/resolvers/solana/refine.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAA;AAC3C,OAAO,EAAE,KAAK,EAAE,MAAM,4BAA4B,CAAA;AAClD,OAAO,EAAE,eAAe,EAAE,MAAM,2CAA2C,CAAA;AAC3E,OAAO,EAAE,YAAY,EAAE,MAAM,iDAAiD,CAAA;AAC9E,OAAO,EAAE,SAAS,EAAE,MAAM,2CAA2C,CAAA;AAErE,OAAO,EAEL,oBAAoB,GACrB,MAAM,iEAAiE,CAAA;AACxE,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAA;AAGzC,OAAO,EAAE,mBAAmB,EAAE,MAAM,2BAA2B,CAAA;AAC/D,OAAO,EAAE,uBAAuB,EAAE,MAAM,wBAAwB,CAAA;AAChE,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAA;AAE9D,MAAM,wBAAwB,GAAG,GAAG,CAAA;AACpC,MAAM,uBAAuB,GAAG,QAAU,CAAA;AAS1C,MAAM,CAAC,MAAM,yBAAyB,GAAG,KAAK,EAAE,EAC9C,cAAc,EACd,aAAa,EACb,gBAAgB,EAChB,UAAU,GACqB,EAA2B,EAAE;IAC5D,MAAM,IAAI,GAAG,cAAc,CAAC,cAAc,CAAC,CAAA;IAC3C,MAAM,MAAM,GAAG,eAAe,EAAE,CAAA;IAEhC,MAAM,CAAC,WAAW,CAAC,GAAG,uBAAuB,CAAC;QAC5C,cAAc,EAAE,MAAM,CAAC,oBAAoB,EAAE;YAC3C,GAAG,cAAc;YACjB,kBAAkB,EAAE;gBAClB,IAAI,EAAE,gBAAgB;gBACtB,KAAK,EAAE,aAAa;aACrB;SACF,CAAC;QACF,UAAU;KACX,CAAC,CAAA;IAEF,MAAM,EAAE,IAAI,EAAE,GAAG,mBAAmB,CAAC;QACnC,UAAU;QACV,WAAW;QACX,KAAK,EAAE,KAAK,CAAC,MAAM;KACpB,CAAC,CAAA;IAEF,MAAM,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IAElC,MAAM,UAAU,GAAG,KAAK,IAAI,EAAE;QAC5B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,gBAAgB,CAAC,OAAO,EAAE,WAAW,CAAC,CAAA;QAEpE,OAAO,MAAM,CAAC,QAAQ,CAAC,KAAK,IAAI,CAAC,CAAC,CAAA;IACpC,CAAC,CAAA;IAED,MAAM,mBAAmB,GAAG,KAAK,IAAI,EAAE;QACrC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,wBAAwB,EAAE,CAAC;YAChE,MAAM,aAAa,GAAG,MAAM,MAAM,CAAC,iCAAiC,CAClE,wBAAwB,CACzB,CAAA;YACD,OAAO,MAAM,CAAC,aAAa,CAAC,CAAA;QAC9B,CAAC;QAED,OAAO,EAAE,CAAA;IACX,CAAC,CAAA;IAED,MAAM,OAAO,GAAG,MAAM,UAAU,EAAE,CAAA;IAClC,MAAM,gBAAgB,GAAG,MAAM,mBAAmB,EAAE,CAAA;IAEpD,MAAM,iBAAiB,GACrB,CAAC,MAAM,CAAC,gBAAgB,CAAC,GAAG,MAAM,CAAC,YAAY,CAAC,gBAAgB,CAAC,CAAC;QAClE,uBAAuB,CAAA;IAEzB,MAAM,QAAQ,GAAG,OAAO,GAAG,gBAAgB,GAAG,iBAAiB,CAAA;IAE/D,OAAO;QACL,GAAG,aAAa;QAChB,WAAW,EAAE,QAAQ,CAAC,QAAQ,EAAE;KACjC,CAAA;AACH,CAAC,CAAA"}
|