npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

@brian-ai/langchain

v1.2.9

Published

Repository containing the LangchainJS toolkit for creating powerful web3 agents.

Downloads

220

Readme

🤖 @brian-ai/langchain

Attention: this repository it's still under active development. Expect bugs and breaking changes. Use it at your own risk.

A powerful TypeScript SDK for creating Langchain agents that can interact with the blockchain.

💪🏻 Features

  • 🤖 AI-powered blockchain interactions
  • 🔄 Cross-chain operations
  • 💱 Token swaps
  • 🌉 Token bridging
  • 💰 DeFi operations (deposit, withdraw, borrow, repay)
  • 💸 Token transfers
  • 💼 Balance checking
  • And more...

📦 Installation

npm install @brian-ai/langchain

🚀 Quick Start

import { createBrianAgent } from "@brian-ai/langchain";
import { ChatOpenAI } from "@langchain/openai";

const agent = await createBrianAgent({
  apiKey: "your-brian-api-key",
  privateKeyOrAccount: "your-private-key-or-account",
  llm: new ChatOpenAI(),
});

// Execute blockchain operations using natural language
const result = await agent.invoke({
  input: "Swap 100 USDC for ETH on Ethereum",
});

🔩 Using the Brian toolkit

You could also import directly the BrianToolkit in your agent without the need of using the createBrianAgent function:

import { BrianToolkit } from "@brian-ai/langchain";

const { tools } = new BrianToolkit({
  apiKey: "your-brian-api-key",
  privateKeyOrAccount: "your-private-key-or-account",
});

// import the tools into your own agent

🛠️ Available Tools

The SDK includes several tools for different blockchain operations:

  • Swap: Exchange tokens on various chains
  • Bridge: Transfer tokens across different blockchains
  • Deposit: Deposit tokens into DeFi protocols
  • Withdraw: Withdraw tokens from DeFi protocols
  • Borrow: Borrow tokens from lending protocols
  • Repay: Repay borrowed tokens
  • Transfer: Send tokens to other addresses
  • Balance: Check token balances

Note: all the actions above will be executed by the agent account using the private key provided. This means that some funds could be lost in the process in case of errors.

🔵 Using CDP Wallets

The SDK also supports the creation of Agents that use the CDP SDK instead of viem for the wallet.

import { createBrianAgent } from "@brian-ai/langchain";
import { ChatOpenAI } from "@langchain/openai";

const agent = await createBrianCDPAgent({
  apiKey: "your-brian-api-key",
  coinbaseApiKey: "your-coinbase-api-key-name",
  coinbaseApiKeySecret: "your-coinbase-api-key-secret",
  walletData: JSON.parse(process.env.COINBASE_WALLET_DATA!),
  llm: new ChatOpenAI(),
});

// Execute blockchain operations using natural language
const result = await agent.invoke({
  input: "Swap 100 USDC for ETH on Ethereum",
});

🔩 Using the Brian CDP toolkit

You could also import directly the BrianCDPToolkit in your agent without the need of using the createBrianCDPAgent function:

import { BrianCDPToolkit } from "@brian-ai/langchain";

const brianCDPToolkit = new BrianCDPToolkit({
  apiKey: "your-brian-api-key",
  coinbaseApiKey: "your-coinbase-api-key-name",
  coinbaseApiKeySecret: "your-coinbase-api-key-secret",
});

// load the wallet data into a variable
const walletData = /* ... */

const { tools } = await brianCDPToolkit.setup({ walletData })

// import the tools into your own agent

🛠️ CDP Available Tools

The SDK includes several tools for different blockchain operations:

  • Swap: Exchange tokens on various chains
  • Bridge: Transfer tokens across different blockchains
  • Deposit: Deposit tokens into DeFi protocols
  • Withdraw: Withdraw tokens from DeFi protocols
  • Transfer: Send tokens to other addresses
  • Balance: Check token balances
  • Deploy NFT: Deploy an NFT contract
  • Deploy Token: Deploy an ERC-20 token
  • Faucet: Gets some faucet tokens (only on Base Sepolia)

Note: all the actions above will be executed by the agent account using the CDP wallet provided. This means that some funds could be lost in the process in case of errors.

⚙️ Architecture

The SDK is built on top of LangChain's agent framework and uses:

  • zod for schema validation
  • viem for blockchain interactions
  • LangChain for agent orchestration
  • Brian AI SDK for transaction processing
  • CDP SDK for the Brian CDP Agent

🤙🏻 Callback Handlers

This SDK also contains some useful callback handlers to log the agent's thoughts and actions.

💬 XMTPCallbackHandler

The XMTPCallbackHandler sends the agent's thoughts and actions using the HandlerContext from XMTP. To create an XMTP-powered agent, you can use the following quick-start code:

import { HandlerContext, run } from "@xmtp/message-kit";
import { createBrianAgent } from "@brian-ai/langchain";
import { ChatOpenAI } from "@langchain/openai";

run(async (context: HandlerContext) => {
  const brianAgent = await createBrianAgent({
    apiKey: process.env.BRIAN_API_KEY!,
    privateKeyOrAccount: process.env.AGENT_PRIVATE_KEY as `0x${string}`,
    llm: new ChatOpenAI({ apiKey: process.env.OPENAI_API_KEY }),
    xmtpHandler: context,
    xmtpHandlerOptions: {
      onAgentAction: true,
      onToolStart: true,
    },
  });
  const { content } = context.message;
  const result = await brianAgent.invoke({ input: content.text });
  await context.send(result.output);
});

You can also of course use a CDP wallet agent with the XMTP handler:

import { HandlerContext, run } from "@xmtp/message-kit";
import { createBrianCDPAgent } from "@brian-ai/langchain";
import { ChatOpenAI } from "@langchain/openai";

run(async (context: HandlerContext) => {
  const brianAgent = await createBrianCDPAgent({
    apiKey: process.env.BRIAN_API_KEY!,
    coinbaseApiKeyName: process.env.COINBASE_API_KEY_NAME!,
    coinbaseApiKeySecret: process.env.COINBASE_API_KEY_SECRET!,
    llm: new ChatOpenAI({ apiKey: process.env.OPENAI_API_KEY }),
    walletData: JSON.parse(process.env.COINBASE_WALLET_DATA!),
    xmtpHandler: context,
    xmtpHandlerOptions: {
      onAgentAction: true,
      onToolStart: true,
    },
  });
  const { content } = context.message;
  const result = await brianAgent.invoke({ input: content.text });
  await context.send(result.output);
});

You can customize which messages are sent to the XMTP handler by setting the xmtpHandlerOptions object. The available options are (by default they are all set to false):

type XMTPCallbackHandlerOptions = {
  onChainStart?: boolean; // sends a message when the chain starts
  onChainEnd?: boolean; // sends a message when the chain ends
  onChainError?: boolean; // sends a message when the chain errors
  onLLMStart?: boolean; // sends a message when the LLM starts
  onLLMEnd?: boolean; // sends a message when the LLM ends
  onLLMError?: boolean; // sends a message when the LLM errors
  onToolStart?: boolean; // sends a message when a tool starts
  onToolEnd?: boolean; // sends a message when a tool ends
  onToolError?: boolean; // sends a message when a tool errors
  onRetrieverStart?: boolean; // sends a message when the retriever starts
  onRetrieverEnd?: boolean; // sends a message when the retriever ends
  onRetrieverError?: boolean; // sends a message when the retriever errors
  onAgentAction?: boolean; // sends a message when the agent performs an action
};

🤝🏻 Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

🛡️ License

This project is licensed under the terms of the MIT license. See LICENSE for more details.

‼️ Disclaimer

This code is being provided as is. No guarantee, representation or warranty is being made, express or implied, as to the safety or correctness of the code. It has not been audited and as such there can be no assurance it will work as intended, and users may experience delays, failures, errors, omissions or loss of transmitted information. Nothing in this repo should be construed as investment advice or legal advice for any particular facts or circumstances and is not meant to replace competent counsel. It is strongly advised for you to contact a reputable attorney in your jurisdiction for any questions or concerns with respect thereto. Brian is not liable for any use of the foregoing, and users should proceed with caution and use at their own risk.