Big News: Socket Selected for OpenAI's Cybersecurity Grant Program.Details
Socket
Book a DemoSign in
Socket

@triton-one/yellowstone-grpc

Package Overview
Dependencies
Maintainers
4
Versions
45
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@triton-one/yellowstone-grpc

Yellowstone gRPC Geyser Node.js Client

latest
Source
npmnpm
Version
5.0.8
Version published
Weekly downloads
18K
-25.66%
Maintainers
4
Weekly downloads
 
Created
Source

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

Keywords

solana

FAQs

Package last updated on 07 Apr 2026

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts