@triton-one/yellowstone-grpc
v5.0.2
Published
Yellowstone gRPC Geyser Node.js Client
Keywords
Readme
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 installBuild the project (this will generate the gRPC client and compile TypeScript):
npm run buildPlease 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 buildWorking
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
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 cleanNavigate to the SDK (where this README resides) and install dependencies with
npm installandnpm run build:dev. Make sure to usebuild:devto reflect local changes in your test runs and NOTbuild.Navigate to
examples/typescriptfolder and install dependencies withnpm install.Run
client.tswith an example subscription request below:tsx examples/typescript/src/client.ts --endpoint <ENDPOINT> --x-token <X-TOKEN> --commitment processed subscribe --transactions TokenkegQfeZyiNwAJbNbGKPFXCWuBvf9Ss623VQ5DA
