Go to file
aniketfuryrocks 5f047c9c4d
lite-client, tests and bench
2022-12-10 23:01:37 +05:30
benches lite-client, tests and bench 2022-12-10 23:01:37 +05:30
lite-bench-utils lite-client, tests and bench 2022-12-10 23:01:37 +05:30
lite-client lite-client, tests and bench 2022-12-10 23:01:37 +05:30
src lite-client, tests and bench 2022-12-10 23:01:37 +05:30
tests lite-client, tests and bench 2022-12-10 23:01:37 +05:30
.gitignore feat: Updated typescript tests 2022-12-06 10:27:12 +05:30
Cargo.lock lite-client, tests and bench 2022-12-10 23:01:37 +05:30
Cargo.toml lite-client, tests and bench 2022-12-10 23:01:37 +05:30
LICENSE Initial commit 2022-11-12 14:01:34 +01:00
README.md doc: Update readme 2022-12-07 22:00:29 +05:30
jest.config.js feat: Updated typescript tests 2022-12-06 10:27:12 +05:30
package.json chore: modifying the ts test command 2022-12-07 22:17:40 +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 -- run --port 9000 --subscription-port 9001 --rpc-url http://localhost:8899

Tests

cargo run --bin lite-rpc -- test