Ali Behjati 183081cc20 Expose pythnet message buffer idls (#865) 2 years ago
..
src 3aa953e153 [xc-admin] Add support for arbitrary wormhole payloads (#759) 2 years ago
.eslintrc.js 481c61bc2c [refactor] Improve typescript codebase (#553) 2 years ago
.gitignore 084acdb57e [refactor] Convert hyphen to underscore in the directory tree (#524) 2 years ago
LICENSE 084acdb57e [refactor] Convert hyphen to underscore in the directory tree (#524) 2 years ago
README.md 084acdb57e [refactor] Convert hyphen to underscore in the directory tree (#524) 2 years ago
jest.config.js 084acdb57e [refactor] Convert hyphen to underscore in the directory tree (#524) 2 years ago
package-lock.json 084acdb57e [refactor] Convert hyphen to underscore in the directory tree (#524) 2 years ago
package.json e995a2b89e Add CI workflow to publish javascript packages (#707) 2 years ago
tsconfig.json 183081cc20 Expose pythnet message buffer idls (#865) 2 years ago

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.
  • Node 19 doesn't work!
  • 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.

Create a multisig transaction

npm start -- create -c <CLUSTER: [mainnet|devnet]> -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 -l -p hello

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

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

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

To use hot wallet :

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

Execute a multisig transaction

npm start -- execute -c <CLUSTER: [mainnet|devnet]> -w <WALLET_SECRET_KEY_FILEPATH> -t <TX_ID>

To use ledger with default derivation account and change:

npm start -- execute -c devnet -l -m keys/message.json -t GSC8r7Qsi9pc698fckaQgzHufG6LqVq3vZijyu5KsXLh

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

npm start -- execute -c devnet -l -lda 0 -m keys/message.json -t GSC8r7Qsi9pc698fckaQgzHufG6LqVq3vZijyu5KsXLh

npm start -- execute -c devnet -l -lda 0 -ldc 1 -m keys/message.json -t GSC8r7Qsi9pc698fckaQgzHufG6LqVq3vZijyu5KsXLh

Example:

npm start -- execute -c devnet -w keys/key.json -m keys/message.json -t GSC8r7Qsi9pc698fckaQgzHufG6LqVq3vZijyu5KsXLh

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