Skip to main content
Use the Node.js SDK to interact with Circle’s User-Controlled Wallet APIs, which allow you to embed secure wallets in your applications and create blockchain transactions using the Developer Services platform. This page provides short examples of how to install and use the user-controlled wallets SDK. For complete examples, see the Sample Projects page. For more information see the user-controlled wallets documentation.

Prerequisites

To successfully use the user-controlled wallets SDK, you need the following:

Install the SDK

Use the following commands to install the SDK. You can view the package information on the npm site.
npm install @circle-fin/user-controlled-wallets --save

User-controlled wallets client

To start using the SDK, you first need to configure a client. Import the initiateUserControlledWalletsClient factory from the SDK, and then initialize the client using your API key.

Import the client

The following example shows how to import the client and configure it to use your API key:
const {
  initiateUserControlledWalletsClient,
} = require("@circle-fin/user-controlled-wallets");
const client = initiateUserControlledWalletsClient({
  apiKey: "<your-api-key>",
});

Create a transaction

The following example shows how to create a transaction using the client:
Javascript
const response = await client.createTransaction({
  userToken: "dummy-user-token",
  amounts: ["0.01"],
  destinationAddress: "0xa51c9c604b79a0fadbfed35dd576ca1bce71da0a",
  tokenId: "738c8a6d-8896-46d1-b2cb-083600c1c69b",
  walletId: "a635d679-4207-4e37-b12e-766afb9b3892",
  fee: {
    type: "level",
    config: {
      feeLevel: "HIGH",
    },
  },
});
console.log(response.data?.challengeId);

Client configuration options

The client for the user-controlled wallets SDK accepts the following configuration parameters:
OptionRequired?Description
apiKeyYesThe API key used to authenticate requests to the Circle API.
storageNoOptional custom storage solution for persisting data. If not provided, the SDK uses in-memory storage.
I