2023-01-19 06:38:42 -08:00
# Lite RPC For Solana Blockchain
2022-11-25 04:24:12 -08:00
2022-12-16 18:35:49 -08:00
Submitting a [transaction ](https://docs.solana.com/terminology#transaction ) to be executed on the solana blockchain,
requires the client to identify the next few leaders based on the
[leader schedule ](https://docs.solana.com/terminology#leader-schedule ), look up their peering information in gossip and
connect to them via the [quic protocol ](https://en.wikipedia.org/wiki/QUIC ). In order to simplify the
process so it can be triggered from a web browser, most applications
run full [validators ](https://docs.solana.com/terminology#validator ) that forward the transactions according to the
protocol on behalf of the web browser. Running full solana [validators ](https://docs.solana.com/terminology#validator )
is incredibly resource intensive `(>256GB RAM)` , the goal of this
project would be to create a specialized micro-service that allows
to deploy this logic quickly and allows [horizontal scalability ](https://en.wikipedia.org/wiki/Scalability ) with
commodity vms.
2022-11-25 04:24:12 -08:00
2022-12-17 02:36:26 -08:00
### Confirmation strategies
2022-11-25 04:24:12 -08:00
2022-12-17 02:36:26 -08:00
1) Subscribe to new blocks using [blockSubscribe ](https://docs.solana.com/developing/clients/jsonrpc-api#blocksubscribe---unstable-disabled-by-default )
2) Subscribing to signatures with pool of rpc servers. (Under development)
2023-01-19 06:38:42 -08:00
3) Listening to gossip protocol. (Future roadmap)
2022-12-17 02:36:26 -08:00
## Executing
*make sure `solana-validator` is running in the background with `--rpc-pubsub-enable-block-subscription` *
*run using*
2022-12-16 18:35:49 -08:00
```bash
2022-12-17 02:36:26 -08:00
$ cargo run --release
2022-12-16 18:35:49 -08:00
```
2022-11-25 04:24:12 -08:00
2022-12-17 02:36:26 -08:00
*to know about command line options*
2022-12-16 18:35:49 -08:00
```bash
2022-12-17 02:36:26 -08:00
$ cargo run --release -- --help
2022-12-16 18:35:49 -08:00
```
2022-11-25 04:24:12 -08:00
2022-12-17 02:36:26 -08:00
## Test and Bench
*Make sure both `solana-validator` and `lite-rpc` is running*
2022-11-25 04:24:12 -08:00
2022-12-17 02:37:58 -08:00
*test*
2022-12-16 18:35:49 -08:00
```bash
2022-12-17 02:36:26 -08:00
$ cargo test
2022-12-07 08:30:29 -08:00
```
2022-12-17 02:37:58 -08:00
*bench*
2022-12-16 18:35:49 -08:00
```bash
2023-01-12 02:54:25 -08:00
$ cd bench and cargo run --release
2022-12-07 08:30:29 -08:00
```
2022-12-16 18:35:49 -08:00
Find a new file named `metrics.csv` in the project root.
2022-12-17 02:36:26 -08:00
2023-01-31 05:30:52 -08:00
## Metrics and Postgres
LiteRpc implements a postgres service that can write to a postgres database tables as defined
in `./migrations`
### env variables
| env | purpose |
| --------- | ------ |
| `CA_PEM_B64` | Base64 encoded `ca.pem` |
| `CLIENT_PKS_B64` | Base64 encoded `client.pks` |
| `CLIENT_PKS_PASS` | Password to `client.pks` |
| `PG_CONFIG` | Postgres Connection Config |
2022-12-17 02:36:26 -08:00
## License & Copyright
Copyright (c) 2022 Blockworks Foundation
Licensed under the ** [MIT LICENSE ](LICENSE )**