Ali Behjati b86a9d1b38 Use hex payload instead of string (#284) 3 năm trước cách đây
..
src b86a9d1b38 Use hex payload instead of string (#284) 3 năm trước cách đây
.eslintrc.js 1c6977ec96 add pyth multisig cli program (#276) 3 năm trước cách đây
.gitignore 1c6977ec96 add pyth multisig cli program (#276) 3 năm trước cách đây
LICENSE 1c6977ec96 add pyth multisig cli program (#276) 3 năm trước cách đây
README.md f3e17ad307 add ledger support (#277) 3 năm trước cách đây
jest.config.js 1c6977ec96 add pyth multisig cli program (#276) 3 năm trước cách đây
package-lock.json f3e17ad307 add ledger support (#277) 3 năm trước cách đây
package.json f3e17ad307 add ledger support (#277) 3 năm trước cách đây
tsconfig.json 1c6977ec96 add pyth multisig cli program (#276) 3 năm trước cách đây

README.md

Pyth Governance Multisig CLI Program

This program allows you to create/execute a multisig transaction that includes an instruction from wormhole for cross-chain governance.

Installation

npm install

Usage

Note:

  • Node.js v17.15.0 or higher is required as it introduces support for fetch API.
  • When using with Ledger, please enable blind signing in the Solana app settings. TLDR: When you enable blind signing, you enable your device to approve a smart contract transaction, even though it hasn’t been able to display full contract data to you. In other words, you’re agreeing to trust, instead of verify, the transaction. You still have to manually approve each transactions.
  • Information about ledger derivation can be found here.
  • RPC URLs can be found here.

Create a multisig transaction

npm start -- create -c <CLUSTER> -v <VAULT_ADDRESS> -l -lda <LEDGER_DERIVATION_ACCOUNT> -ldc <LEDGER_DERIVATION_CHANGE> -w <WALLET_SECRET_KEY_FILEPATH> -p <PAYLOAD>

To use ledger with default derivation account and change:

npm start -- create -c devnet -v HezRVdwZmKpdKbksxFytKnHTQVztiTmL3GHdNadMFYui -l -p hello

To use ledger with custom derivation account and/or change:

npm start -- create -c devnet -v HezRVdwZmKpdKbksxFytKnHTQVztiTmL3GHdNadMFYui -l -lda 0 -p hello

npm start -- create -c devnet -v HezRVdwZmKpdKbksxFytKnHTQVztiTmL3GHdNadMFYui -l -lda 0 -ldc 1 -p hello

To use hot wallet :

npm start -- create -c devnet -v HezRVdwZmKpdKbksxFytKnHTQVztiTmL3GHdNadMFYui -w keys/key.json -p hello

Execute a multisig transaction

npm start -- execute -c <CLUSTER> -v <VAULT_ADDRESS> -w <WALLET_SECRET_KEY_FILEPATH> -m <MESSAGE_SECRET_KEY_FILEPATH> -t <TX_ID> -u <RPC_URL>

To use ledger with default derivation account and change:

npm start -- execute -c devnet -v HezRVdwZmKpdKbksxFytKnHTQVztiTmL3GHdNadMFYui -l -m keys/message.json -t GSC8r7Qsi9pc698fckaQgzHufG6LqVq3vZijyu5KsXLh -u https://wormhole-v2-testnet-api.certus.one/

To use ledger with custom derivation account and/or change:

npm start -- execute -c devnet -v HezRVdwZmKpdKbksxFytKnHTQVztiTmL3GHdNadMFYui -l -lda 0 -m keys/message.json -t GSC8r7Qsi9pc698fckaQgzHufG6LqVq3vZijyu5KsXLh -u https://wormhole-v2-testnet-api.certus.one/

npm start -- execute -c devnet -v HezRVdwZmKpdKbksxFytKnHTQVztiTmL3GHdNadMFYui -l -lda 0 -ldc 1 -m keys/message.json -t GSC8r7Qsi9pc698fckaQgzHufG6LqVq3vZijyu5KsXLh -u https://wormhole-v2-testnet-api.certus.one/

Example:

npm start -- execute -c devnet -v HezRVdwZmKpdKbksxFytKnHTQVztiTmL3GHdNadMFYui -w keys/key.json -m keys/message.json -t GSC8r7Qsi9pc698fckaQgzHufG6LqVq3vZijyu5KsXLh -u https://wormhole-v2-testnet-api.certus.one/

https://github.com/LedgerHQ/ledger-live/wiki/LLC:derivation