js-stellar-sdk is a JavaScript library for communicating with a
Stellar Horizon server
and Stellar RPC. While
primarily intended for applications built on Node.js or in the browser, it can
be adapted for use in other environments with some tinkering.
The library provides:
- a networking layer API for Horizon endpoints (REST-based),
- a networking layer for Soroban RPC (JSONRPC-based).
- facilities for building and signing transactions, for communicating with a Stellar Horizon instance, and for submitting transactions or querying network history.
Jump to:
- Installation: details on hitting the ground running
- Usage: links to documentation and a variety of workarounds for non-traditional JavaScript environments
- CLI: generate TypeScript bindings for Stellar smart contracts
- Developing: contribute to the project!
- License
Using npm, pnpm, or yarn to include stellar-sdk in your own project:
npm install --save @stellar/stellar-sdk
# or
pnpm add @stellar/stellar-sdk
# or
yarn add @stellar/stellar-sdkThen, require or import it in your JavaScript code:
var StellarSdk = require("@stellar/stellar-sdk");
// or
import * as StellarSdk from "@stellar/stellar-sdk";(Preferably, you would only import the pieces you need to enable tree-shaking and lower your final bundle sizes.)
You can use a CDN:
<script src="https://cdnjs.cloudflare.com/ajax/libs/stellar-sdk/{version}/stellar-sdk.js"></script>Note that this method relies on using a third party to host the JS library. This may not be entirely secure. You can self-host it via Bower:
bower install @stellar/stellar-sdkand include it in the browser:
<script src="./bower_components/stellar-sdk/stellar-sdk.js"></script>
<script>
console.log(StellarSdk);
</script>If you don't want to use or install Bower, you can copy the packaged JS files from the Bower repo, or just build the package yourself locally (see Developing ➡️ Building) and copy the bundle.
| Always make sure that you are using the latest version number. They can be found on the releases page in GitHub. |
|---|
The default bundle uses a native-fetch HTTP client with no axios dependency. If
you need the axios transport (for example, to match the behavior of older SDK
versions), set the USE_AXIOS environment variable to true when building.
pnpm run build:lib:axios
This will create stellar-sdk-axios.js in dist/. Consumers can also import
the axios-backed entry from Node via @stellar/stellar-sdk/axios.
@stellar/stellar-base is now folded into @stellar/stellar-sdk. Its classes
and functions are bundled in and re-exported from the top level, so the SDK is
the only package you need.
This only matters if you import @stellar/stellar-base directly. If you depend
on @stellar/stellar-sdk and never installed the base package separately, skip
this section. The fold-in landed in @stellar/stellar-sdk v16.0.0; on earlier
versions the SDK still depends on the separate base package, so don't remove it
there.
To migrate:
-
Install
@stellar/stellar-sdkif you don't already (see Installation). -
Update your imports. The symbols you import keep their names, so a project-wide find and replace of
"@stellar/stellar-base"with"@stellar/stellar-sdk"usually does it:// before import { Keypair, TransactionBuilder, Asset } from "@stellar/stellar-base"; // after import { Keypair, TransactionBuilder, Asset } from "@stellar/stellar-sdk";
-
Uninstall the base package:
npm uninstall @stellar/stellar-base
Don't keep both packages installed. Two copies of the base library cause
confusing runtime errors, such as instanceof checks failing on values that
look correct.
Always use the latest @stellar/stellar-sdk. The Stellar network upgrades its
protocol periodically, and an older SDK may fail to decode newer data (for
example, newer XDR). You can check the protocol a network currently runs in the
current_protocol_version field of its Horizon root (for example
horizon.stellar.org for Mainnet; Testnet and
Futurenet expose their own).
These docs and the API reference cover the latest version only. To read docs for
an older version, find its Git tag on the
releases page and browse the
docs/ directory at that ref on GitHub. The release notes there mark the breaking
changes in each version.
The usage documentation for this library lives in a handful of places:
- across the Stellar Developer Docs, which includes tutorials and examples, and
- on the generated API doc site —
which also publishes
agent-friendly bundles, raw markdown siblings, and a crawler policy
for AI tools. The site's URL, base path, and AI policy values live in
config/site.ts.
You can also refer to:
- the documentation for the
Horizon REST API (if using the
Horizonmodule) and - the documentation for Soroban
RPC's API (if using the
rpcmodule)
The SDK works in React Native, but its JavaScript runtime doesn't ship a couple of things the SDK expects from Node. You'll need to provide them in your app's entry file:
- A global
Buffer. XDR encoding/decoding relies onBuffer. Install a polyfill and assign it toglobal.Buffer. - A Web Crypto random source.
Keypair.random()and SEP-10 challenge generation callcrypto.getRandomValues(), which React Native doesn't provide out of the box. Add a polyfill that registers it on the global scope, imported once before any SDK code runs.
Modern React Native uses Metro with autolinking, so beyond adding the two polyfills above, no manual native linking or custom resolver config is required.
If you use Horizon streaming (server.…().stream()), be aware it depends on an
EventSource, which is now an included dependency and will work in any runtimes
that support fetch,
ReadableStream,
TextDecoder,
URL,
Event,
MessageEvent,
EventTarget.
Expo has the same two requirements as React Native above — a global Buffer and
a crypto.getRandomValues() source. Install polyfills for both (use
npx expo install so versions are matched to your Expo SDK) and import them at
the top of your entry point (by default App.js) before any SDK code.
Once crypto.getRandomValues() is available, Keypair.random() works normally
— the manual expo-random workaround from older Expo SDKs is no longer needed.
The SDK defaults to a native-fetch HTTP client, so Horizon and RPC requests
work in the Workers runtime without an HTTP adapter. The things to watch for
are:
- Node compatibility. The SDK relies on
Buffer. Enable thenodejs_compatflag in yourwrangler.tomlso Node built-ins are available. - Streaming. Horizon's
.stream()depends onEventSource; long-lived streaming connections don't fit the Workers request model well, so prefer polling (.call()/.cursor()) for Horizon data in a Worker.
The SDK includes a command-line tool for generating TypeScript bindings from Stellar smart contracts. These bindings provide fully-typed client code with IDE autocompletion and compile-time type checking.
# Using npx (no installation required)
npx @stellar/stellar-sdk generate [options]
# Or if installed globally
stellar-js generate [options]You can generate bindings from three different sources:
npx @stellar/stellar-sdk generate \
--wasm ./path/to/wasm_file/my_contract.wasm \
--output-dir ./my-contract-client \
--contract-name my-contract# testnet, futurenet, and localnet have default RPC URLs
npx @stellar/stellar-sdk generate \
--wasm-hash <hex-encoded-hash> \
--network testnet \
--output-dir ./my-contract-client \
--contract-name my-contractnpx @stellar/stellar-sdk generate \
--contract-id CABC...XYZ \
--network testnet \
--output-dir ./my-contract-clientFor mainnet or when connecting to RPC servers that require authentication:
# Mainnet requires --rpc-url (no default)
npx @stellar/stellar-sdk generate \
--contract-id CABC...XYZ \
--rpc-url https://my-rpc-provider.com \
--network mainnet \
--output-dir ./my-contract-client
# With custom timeout and headers for authenticated RPC servers
npx @stellar/stellar-sdk generate \
--contract-id CABC...XYZ \
--rpc-url https://my-rpc-server.com \
--network mainnet \
--output-dir ./my-contract-client \
--timeout 30000 \
--headers '{"Authorization": "Bearer my-token"}'
# localnet with default RPC URL auto-enables --allow-http
npx @stellar/stellar-sdk generate \
--contract-id CABC...XYZ \
--network localnet \
--output-dir ./my-contract-client
# When overriding the default URL, you must specify --allow-http if using HTTP
npx @stellar/stellar-sdk generate \
--contract-id CABC...XYZ \
--rpc-url http://my-local-server:8000/rpc \
--network localnet \
--output-dir ./my-contract-client \
--allow-http| Option | Description |
|---|---|
--wasm <path> |
Path to a local WASM file |
--wasm-hash <hash> |
Hex-encoded hash of WASM blob on the network |
--contract-id <id> |
Contract ID of a deployed contract |
--rpc-url <url> |
Stellar RPC server URL (has defaults for testnet/futurenet/localnet, required for mainnet) |
--network <network> |
Network to use: testnet, mainnet, futurenet, or localnet (required for network sources) |
--output-dir <dir> |
Output directory for generated bindings (required) |
--contract-name <name> |
Name for the generated package (derived from filename if not provided) |
--overwrite |
Overwrite existing files in the output directory |
--allow-http |
Allow insecure HTTP connections to RPC server (default: false) |
--timeout <ms> |
RPC request timeout in milliseconds |
--headers <json> |
Custom headers as JSON object (e.g., '{"Authorization": "Bearer token"}') |
When using --network, the CLI provides default RPC URLs for most networks:
| Network | Default RPC URL |
|---|---|
testnet |
https://soroban-testnet.stellar.org |
futurenet |
https://rpc-futurenet.stellar.org |
localnet |
http://localhost:8000/rpc (auto-enables --allow-http only when using default URL) |
mainnet |
None - you must provide --rpc-url (find providers) |
The CLI generates a complete npm package structure:
my-contract-client/
├── src/
│ ├── index.ts # Barrel exports
│ ├── client.ts # Typed Client class with contract methods
│ └── types.ts # TypeScript interfaces for contract types
├── package.json
├── tsconfig.json
├── README.md
└── .gitignore
After generating, you can use the bindings in your project:
import { Client } from "./my-contract-client";
const client = new Client({
contractId: "CABC...XYZ",
networkPassphrase: Networks.TESTNET,
rpcUrl: "https://soroban-testnet.stellar.org",
publicKey: keypair.publicKey(),
...basicNodeSigner(keypair, Networks.TESTNET),
});
// Fully typed method calls with IDE autocompletion
const result = await client.transfer({
from: "GABC...",
to: "GDEF...",
amount: 1000n,
});So you want to contribute to the library: welcome! Whether you're working on a fork or want to make an upstream request, the dev-test loop is pretty straightforward.
- Clone the repo:
git clone https://github.com/stellar/js-stellar-sdk.git- Install Node
Because we support the oldest maintenance version of Node, please install and
develop on the version pinned in .nvmrc (currently Node 22) so you
don't get surprised when your code works locally but breaks in CI.
Here's how to install nvm if you haven't: https://github.com/creationix/nvm
nvm installIf you work on several projects that use different Node versions, you might it helpful to install this automatic version manager: https://github.com/wbyoung/avn
- Enable Corepack
corepack enable- Install dependencies inside js-stellar-sdk folder:
cd js-stellar-sdk
pnpm install- Observe the project's code style
While you're making changes, make sure to run the linter to catch any linting errors (in addition to making sure your text editor supports ESLint) and conform to the project's code style.
pnpm run fmtYou can build the developer version (unoptimized, commented, with source maps, etc.) or the production bundles:
pnpm run build
# or
pnpm run build:prodTo run all tests:
pnpm run testTo run a specific set of tests:
pnpm run test:node
pnpm run test:browser
pnpm run test:integrationTo generate and check the documentation site:
# generate the docs site (reference pages, llms bundles, and the Astro site under dist/site)
pnpm run docs
# preview the built site in a browser
pnpm docs:preview
# the preview server prints the local URL (default http://localhost:4321)
# for a live-reloading dev server instead, use:
pnpm docs:devFor information on how to contribute or publish new versions of this software to
npm, please refer to our
contribution guide.
js-stellar-sdk is licensed under an Apache-2.0 license. See the LICENSE file for details.