Yellowstone Node.js gRPC client
This library implements a client for streaming account updates for backend applications.
You can find more information and documentation on the Triton One website.
Prerequisites
You need to have the latest version of protoc installed.
Please refer to the installation guide on the Protobuf website.
Usage
Install required dependencies by running
npm install
Build the project (this will generate the gRPC client and compile TypeScript):
npm run build
Please refer to examples/typescript for some usage examples.
Troubleshooting
For macOS:
You might have to run npm run build with RUSTFLAGS="-Clink-arg=-undefined -Clink-arg=dynamic_lookup" to skip the strict linkers from failing the build step and resolve dylibs via runtime.
RUSTFLAGS="-Clink-arg=-undefined -Clink-arg=dynamic_lookup" npm run build
Working
Since the start, the @triton-one/yellowstone-grpc package has used the @grpc/grpc-js lib for gRPC types enforcement, connection and subscription management. This hit a bottleneck, described in this blog
From v5.0.0 the napi-rs framework is used for gRPC connection and subscription management. It's described into this blog
These changes are internal to the SDK and do not have any breaking changes for client code. If you face any issues, please open an issue
The napi-rs based implementation is inspired from the implemenation of the LaserStream SDK
Type Compatibility
The public SDK always returns the generated protobuf-compatible types from
src/grpc/geyser.ts.
- Unary methods return generated response objects (for example
PongResponse,
GetSlotResponse, GetVersionResponse) instead of raw N-API wrapper shapes.
- Subscription stream updates are normalized to
SubscribeUpdate with
top-level oneof fields (account, slot, transaction, etc).
- The internal N-API
Js... objects are an implementation detail and are
converted automatically by the SDK wrapper.
This allows existing user code typed against the generated src/grpc types to
remain stable while using the N-API backend.
Development
Local Testing
When building for local testing at the root of the project where the Makefile resides, you must:
-
Clean build artifacts if any with make clean
-
Navigate to the SDK (where this README resides) and install dependencies with npm install and npm run build:dev. Make sure to use build:dev to reflect local changes in your test runs and NOT build.
-
Navigate to examples/typescript folder and install dependencies with npm install.
-
Run client.ts with an example subscription request below:
tsx examples/typescript/src/client.ts --endpoint <ENDPOINT> --x-token <X-TOKEN> --commitment processed subscribe --transactions TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA