@stacks/wallet-sdk
is a library for building wallets for the Stacks blockchain.
A Secret Key is a 12 or 24 word mnemonic phrase, which can be used to deterministically generate a wallet and any number of addresses. When the same Secret Key is used, the exact same addresses will be generated. The Secret Key acts as an easily rememberable and highly secure mechanism for backing up a wallet.
Secret Keys conform to the BIP 39 standard.
A "wallet" is a set of private keys for an individual user. A wallet will contain any number of accounts.
Accounts act as a way for users to separate assets and data within their own account. You could think of accounts like different Google accounts while logged into Gmail. You can easily switch between different accounts, but they all have different data and information.
Private keys are generated according to the BIP32 and BIP44 standards.
The "coin type" for the Stacks blockchain is 5757
.
The private key for each account's STX address is derived from m/44'/5757'/0'/0/n
, where n
is the index of the account.
With NPM:
npm install @stacks/wallet-sdk
By default, a random 24-word Secret Key is generated, using 256 bits of entropy. You can generate a random 12-word key by passing 128
as the entropy
argument.
import { generateSecretKey } from '@stacks/wallet-sdk';
const secretKey = generateSecretKey();
// aunt birth lounge misery utility blind holiday walnut fuel make gift parent gap picnic exact various express sphere family nerve oil drill engage youth
const secretKey128 = generateSecretKey(128);
// winter crash infant long upset beauty cram tank short remove decade ladder
Create a random Secret Key and a Wallet
object. When a wallet is generated, the first account is automatically generated as well.
import { generateWallet, generateSecretKey } from '@stacks/wallet-sdk';
const password = 'password';
const secretKey = generateSecretKey();
const wallet = await generateWallet({
secretKey,
password,
});
A Wallet
is a normal JavaScript object with the following properties:
interface Wallet {
/** Used when generating app private keys, which encrypt app-specific data */
salt: string;
/** The private key associated with the root of a BIP39 keychain */
rootKey: string;
/** A private key used to encrypt configuration data */
configPrivateKey: string;
/** The encrypted secret key */
encryptedSecretKey: string;
/** A list of accounts generated by this wallet */
accounts: Account[];
}
Accounts allow users to use separate Stacks addresses from within the same wallet. Each account has it's own Stacks address and balance. When a user logs into an app, they choose a specific account.
When using generateNewAccount
, the new account is created with next index, based on the existing accounts in a wallet. For example, if a wallet has 5 accounts, calling generateNewAccount
will make the sixth account. The generateNewAccount
treats as the input wallet as immutable. It returns a new wallet object with all available accounts (based on the input wallet object and the additional generated account).
import { generateWallet, generateNewAccount } from '@stacks/wallet-sdk';
let wallet = await generateWallet({
secretKey,
password,
});
wallet = generateNewAccount(wallet); // adds a new account to an existing wallet object, immutable, NOT in-place
An Account
is a JavaScript object with these properties:
interface Account {
/** The private key used for STX payments */
stxPrivateKey: string;
/** The private key used in Stacks 1.0 to register BNS names */
dataPrivateKey: string;
/** The salt is the same as the wallet-level salt. Used for app-specific keys */
salt: string;
/** A single username registered via BNS for this account */
username?: string;
/** A profile object that is publicly associated with this account's username */
profile?: Profile;
/** The root of the keychain used to generate app-specific keys */
appsKey: string;
/** The index of this account in the user's wallet. Zero-indexed */
index: number;
}
When a user restores their wallet in a new app, you can automatically restore any previously-used accounts from the same wallet. It will also restore any usernames owned by this user.
The private keys used to encrypt this data is derived from the path m/44/5757'/0'/1
. This data is stored in Gaia, the decentralized storage system in the Stacks network. Users can host their own Gaia hub, and this library's API can use that Gaia hub, if provided.
import { restoreWalletAccounts } from '@stacks/wallet-sdk';
const restoredWallet = await restoreWalletAccounts({
// `baseWallet` is returned from `generateWallet`
wallet: baseWallet,
gaiaHubUrl: 'https://hub.blockstack.org',
network: new StacksMainnet(),
});
With an account, you can generate an authentication response, which conforms to the Stacks authentication protocol. The resulting authResponse
is a string, representing a signed JSON web token. Learn more about the authentication protocol.
// The transit public key is provided in an "authentication request"
const transitPublicKey = 'xxxx';
const authResponse = await makeAuthResponse({
gaiaHubUrl: 'https://hub.blockstack.org',
appDomain: 'https://example-app.com',
transitPublicKey,
scopes: ['publish_data'],
// `account` is one of the user's accounts
account,
});
@stacks/transactions
This library is meant to be used in conjunction with the @stacks/transactions
library for signing transactions.
import { getStxAddress } from '@stacks/wallet-sdk';
import { TransactionVersion } from '@stacks/transactions';
// get an account from the user's wallet
const account = wallet.accounts[0];
const testnetAddress = getStxAddress({ account, transactionVersion: TransactionVersion.Testnet });
const mainnetAddress = getStxAddress({ account, transactionVersion: TransactionVersion.Mainnet });
You can generate signed transactions by following the documentation from @stacks/transactions
. Use the stxPrivateKey
of an account as the senderKey
option when creating a transaction.
import { StacksMainnet } from '@stacks/network';
import { makeSTXTokenTransfer } from '@stacks/transactions';
const network = new StacksMainnet();
// get an account from the user's wallet
const account = wallet.accounts[0];
const txOptions = {
recipient: 'SP3FGQ8Z7JY9BWYZ5WM53E0M9NK7WHJF0691NZ159',
amount: 12345n,
senderKey: account.stxPrivateKey,
network,
};
const transaction = await makeSTXTokenTransfer(txOptions);
Generated using TypeDoc