Go to file
Lioncat2002 0fc3308710
feat: integrated solana validator with yarn test
2022-12-10 13:10:44 +05:30
scripts feat: integrated solana validator with yarn test 2022-12-10 13:10:44 +05:30
src fix: fixed typescript tests 2022-12-10 12:51:41 +05:30
tests fix: fixed typescript tests 2022-12-10 12:51:41 +05:30
.gitignore feat: integrated solana validator with yarn test 2022-12-10 13:10:44 +05:30
Cargo.lock Adding info about memory used and nb of threads current process has in performance counters 2022-12-04 21:58:34 +01:00
Cargo.toml Adding info about memory used and nb of threads current process has in performance counters 2022-12-04 21:58:34 +01:00
LICENSE
README.md chore: updated the cli so that it can accept ports correctly 2022-12-06 10:51:03 +05:30
jest.config.js feat: Updated typescript tests 2022-12-06 10:27:12 +05:30
package.json feat: integrated solana validator with yarn test 2022-12-10 13:10:44 +05:30
tsconfig.json feat: Updated typescript tests 2022-12-06 10:27:12 +05:30
yarn.lock feat: Updated typescript tests 2022-12-06 10:27:12 +05:30

README.md

Solana Lite RPC

This project aims to create a lite rpc server which is responsible only for sending and confirming the transactions. The lite-rpc server will not have any ledger or banks. While sending transaction the lite rpc server will send the transaction to next few leader (FANOUT) and then use different strategies to confirm the transaction. The rpc server will also have a websocket port which is reponsible for just subscribing to slots and signatures. The lite rpc server will be optimized to confirm transactions which are forwarded to leader using the same server. This project is currently based on an unstable feature of block subscription of solana which can be enabled using --rpc-pubsub-enable-block-subscription while running rpc node.

Confirmation strategies

  1. Subscribing to blocks changes and checking the confirmations. (Under development)
  2. Subscribing to signatures with pool of rpc servers. (Under development)
  3. Listining to gossip protocol. (Future roadmap)

Build

cargo build

Run

  • For RPC node : http://localhost:8899,
  • Websocket : http://localhost:8900 (Optional),
  • Port : 9000 Listening port for LiteRpc server,
  • Subscription Port : 9001 Listening port of websocket subscriptions for LiteRpc server,
cargo run --bin lite-rpc -- --port 9000 --subscription-port 9001 --rpc-url http://localhost:8899