Skip to main content

Providing the Compass API to langchain agents.

Project description

langchain-compass

The Compass-LangChain toolkit contains tools which enable an LLM agent to perform onchain operations on major DeFi protocols.

YouTube Introduction

Setup

Installation

pip install -U langchain-compass

Environment Setup

# .env
OPENAI_API_KEY=your_openai_api_key_here

Usage:

List Tools in Toolkit:

from langchain_compass.toolkits import LangchainCompassToolkit

toolkit = LangchainCompassToolkit(compass_api_key=None)
tools = toolkit.get_tools()
for tool in tools:
    print(tool.name)

Expected output:

# output
aave_supply_
aave_borrow_
aave_repay_
aave_withdraw_
aave_asset_price_get_
...

Using with an agent

from langchain_openai import ChatOpenAI
from langgraph.prebuilt import create_react_agent
from langchain_compass.toolkits import LangchainCompassToolkit
from dotenv import load_dotenv
from langgraph.checkpoint.memory import MemorySaver
load_dotenv()


# Initialize LLM - replace 'gpt-4o' with a model of your choice
llm = ChatOpenAI(model='gpt-4o')

# Get the DeFi tools from LangchainCompassToolkit
tools = LangchainCompassToolkit(compass_api_key=None).get_tools()

# Setup memory for your agent
memory = MemorySaver()

# Create a ReAct agent with the specified LLM, tools, and memory
agent = create_react_agent(
    llm,
    tools=tools,
    checkpointer=memory,
    prompt="You are a helpful agent that can interact onchain using tools that you've been told how to use. If you are uncertain that you have sufficient information to call your tools then please ask the user for more information until you have sufficient information to call your tool."
)

# Example user query
from langchain_core.messages import HumanMessage
user_input = 'what is the balance of vitalic.eth.'

# Optional config data, such as thread IDs or session context
config = {"configurable": {"thread_id": "abc123"}}

# Invoke the agent with the user query
output = agent.invoke(input={"messages": [HumanMessage(content=user_input)]}, config=config)

# Display the agent's final response
print(output["messages"][-1].content)

Expected output:

$ python main.py 
The balance of the wallet associated with **vitalik.eth** is approximately **$486,222.54**. Here's a breakdown of the token balances:

- **1INCH**: 6.037 ($1.03)
- **AAVE**: 0.010 ($1.43)
- **BAL**: 0.932 ($1.04)
- **crvUSD**: 0.775 ($0.78)
- **DAI**: 317,203.872 ($317,242.95)
- **ENS**: 1,144.036 ($16,710.33)
- **LINK**: 1.778 ($22.52)
- **rsETH**: 0.00003 ($0.05)
- **UNI**: 0.000017 ($0.00009)
- **USDC**: 123,223.707 ($123,215.08)
- **USDT**: 170.148 ($170.12)
- **WBTC**: 0.00107 ($91.93)
- **WETH**: 16.395 ($28,765.28)

These values are subject to market fluctuations.

Run the agent interactively based on user input.

To run the agent interactively please add this snippet to the bottom of the code in the previous section.

from rich.console import Console
from rich.markdown import Markdown
console = Console()
print("Starting chat mode... Type 'exit' to end.")
while True:
    user_input = input("\nPrompt: ")
    output = agent.invoke(input = {"messages": [HumanMessage(content=user_input)]}, config=config)
    answer = output["messages"][-1].content
    console.print(Markdown(answer))

Next Steps

To see a full implementation of a LangChain agent using these tools, please check out our GitHub repo here.

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

langchain_compass-0.2.13.tar.gz (7.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

langchain_compass-0.2.13-py3-none-any.whl (9.7 kB view details)

Uploaded Python 3

File details

Details for the file langchain_compass-0.2.13.tar.gz.

File metadata

  • Download URL: langchain_compass-0.2.13.tar.gz
  • Upload date:
  • Size: 7.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for langchain_compass-0.2.13.tar.gz
Algorithm Hash digest
SHA256 e102959e28633063d7e980914323041dc9755c4af805a8fae1f5df989e2ec14d
MD5 74bef601c0a5f71b84871fe14d2b460c
BLAKE2b-256 092460d9852c845ee5744fb899243c606e677eebf67a4b1a3fed4c5bfe3caa7d

See more details on using hashes here.

File details

Details for the file langchain_compass-0.2.13-py3-none-any.whl.

File metadata

File hashes

Hashes for langchain_compass-0.2.13-py3-none-any.whl
Algorithm Hash digest
SHA256 174b3ed11f5ab33aba2fee63944553ba7c5e0e402ede6d5f622b74e0f821a2cf
MD5 bc038ce63a6fefd3a64103ade78d469b
BLAKE2b-256 da5f3512df6a7c05bb1a2232be487c7d9f87f181255107c689c9947b9b9da06f

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page