|
|
5 mesi fa | |
|---|---|---|
| .. | ||
| cli | 956f53e598 feat(solana-receiver-js-sdk): verify & post TWAPs (#2186) | 11 mesi fa |
| common_test_utils | 955a805e85 chore: apply rustfmt | 1 anno fa |
| migrations | 16caff1b04 [solana] Start to implement the solana receiver contract (#557) | 2 anni fa |
| program_simulator | 955a805e85 chore: apply rustfmt | 1 anno fa |
| programs | c716a93a41 fix(pyth-solana-receiver): improve perf and security (#2222) | 10 mesi fa |
| pyth_solana_receiver_sdk | 4f7d3c5324 Fix missed FeedId anchor serialization patch (#2603) | 7 mesi fa |
| scripts | 5a676978db feat: add pyth_push_oracle to dockerfile (#1470) | 1 anno fa |
| sdk | 20df3a347d feat: support multiple JITO endpoints with round-robin retry (#2664) | 5 mesi fa |
| target | 8f62566dbb [solana] Fix idl (#1279) | 1 anno fa |
| .gitignore | f2d5bdc842 chore(target_chains/solana): add verifiable build script (#1378) | 1 anno fa |
| .prettierignore | 16caff1b04 [solana] Start to implement the solana receiver contract (#557) | 2 anni fa |
| Anchor.toml | f3249d9cba feat(apps/hermes): new client package for hermes (#1653) | 1 anno fa |
| Cargo.lock | 4f7d3c5324 Fix missed FeedId anchor serialization patch (#2603) | 7 mesi fa |
| Cargo.toml | 63595df1ad chore(target_chains/solana): rename pyth-price-publisher to pyth-price-store (#1884) | 1 anno fa |
| Dockerfile | 5a676978db feat: add pyth_push_oracle to dockerfile (#1470) | 1 anno fa |
| README.md | f31ef9e812 docs: update solana readme, add rust sdk readme (#1387) | 1 anno fa |
| rust-toolchain.toml | 5ef1ff097a Bump toolchain: (#1382) | 1 anno fa |
This folder contains:
programs/pyth-solana-receiverpyth_solana_receiver_sdksdk/js/pyth_solana_receiverPosting a Pyth price update involves two steps:
This contract offers two ways to post a Pyth price update onto Solana:
post_update allows you to do it in 2 transactions and checks all the Wormhole guardian signatures (the quorum is currently 13 signatures). It relies on the Wormhole contract to verify the signatures.post_update_atomic allows you to do it in 1 transaction but only partially checks the Wormhole guardian signatures (5 signatures seems like the best it can currently do). Therefore it is less secure. It relies on a guardian set account from the Wormhole contract to check the signatures against the guardian keys.post_update is also a more efficient way to post updates if you're looking to post data for many different price feeds at a single point in time.
This is because it persists a verified encoded VAA, so guardian signatures will only get checked once. Then that single posted VAA can be used to prove the price update for all price feeds for that given point in time.
The program is currently deployed on Solana (Mainnet, Devnet) and Eclipse Testnet with addresses:
HDwcJBJXjL9FpJ7UBsYBtaDjsBUhuLCUYoz3zr8SWWaQ for the Wormhole receiverrec5EKMGg6MxZYaMdyBfgwp4d5rB9T1VQH5pJv5LtFJ for the Pyth receiverThe cli folder contains some useful client code to interact with both the Wormhole receiver and the Pyth receiver.
To run the full flow of posting a price update (on devnet) please follow the following steps:
Get a Hermes update from Hermes stable:
curl "https://hermes.pyth.network/api/latest_vaas?ids[]=0xff61491a931112ddf1bd8147cd1b641375f79f5825126d665480874634fd0ace"
Post it to devnet:
cargo run --package pyth-solana-receiver-cli -- --url https://api.devnet.solana.com --keypair ${PATH_TO_KEYPAIR} --wormhole HDwcJBJXjL9FpJ7UBsYBtaDjsBUhuLCUYoz3zr8SWWaQ post-price-update-atomic -p ${HERMES_UPDATE_IN_BASE_64}
or
cargo run --package pyth-solana-receiver-cli -- --url https://api.devnet.solana.com --keypair ${PATH_TO_KEYPAIR} --wormhole HDwcJBJXjL9FpJ7UBsYBtaDjsBUhuLCUYoz3zr8SWWaQ post-price-update -p ${HERMES_UPDATE_IN_BASE_64}