A Python toolkit for Solana agents
Project description
Dipe AI Agent Framework
A powerful toolkit for interacting with the Solana blockchain, providing easy-to-use functions for token operations, trading, and more. Now integrated with LangChain for enhanced functionality.
Key Features
Token Operations
- Transfer SOL & SPL tokens
- Check token balances
- Stake SOL
- Create custom SPL tokens
- Request faucet funds
- Burn tokens & close accounts
Trading & Exchange Integration
- Seamless Jupiter Exchange integration
- Efficient token swaps with slippage control
- Raydium liquidity trading
AI-Enhanced Blockchain Automation
- Leverage LangChain AI
- Automated token performance analysis
- Smart transaction monitoring
Blockchain Data & Monitoring
- Monitor live transactions per second (TPS) on Solana
- Retrieve detailed token insights on Solana
Special Features
- Launch SPL tokens on Solana with Pump.fun
- Create dynamic DLMM liquidity pools on Solana with Meteora
Installation
pip install dipe
Quick Start
from dipe import SolanaAgentKit, create_solana_tools
# Initialize with private key and optional RPC URL
agent = SolanaAgentKit(
"your-wallet-private-key-as-base58",
"https://api.mainnet-beta.solana.com",
"your-openai-api-key"
)
# Create LangChain tools
tools = create_solana_tools(agent)
Usage Examples
Fetch price of a token
from dipe import SolanaAgentKit
async def main():
agent = SolanaAgentKit(
"your-wallet-private-key-as-base58",
"https://api.mainnet-beta.solana.com",
"your-openai-api-key"
)
# Get balance
balance = await agent.fetch_price("FKMKctiJnbZKL16pCmR7ig6bvjcMJffuUMjB97YD7LJs")
print(f"Price: {balance} SOL")
# Run the async function
import asyncio
asyncio.run(main())
Swap Tokens
from dipe import SolanaAgentKit
from solders.pubkey import Pubkey
async def main():
agent = SolanaAgentKit(
"your-wallet-private-key-as-base58",
"https://api.mainnet-beta.solana.com",
"your-openai-api-key"
)
signature = await agent.trade(
agent,
output_mint=Pubkey.from_string("target-token-mint"),
input_amount=100, # amount
input_mint=Pubkey.from_string("source-token-mint"),
slippage_bps=300 # 3% slippage
)
import asyncio
asyncio.run(main())
Lend Tokens
from dipe import SolanaAgentKit
from solders.pubkey import Pubkey
async def main():
agent = SolanaAgentKit(
"your-wallet-private-key-as-base58",
"https://api.mainnet-beta.solana.com",
"your-openai-api-key"
)
signature = await agent.lend_assets(
amount=100 # amount
)
import asyncio
asyncio.run(main())
Stake SOL
from dipe import SolanaAgentKit
from solders.pubkey import Pubkey
async def main():
agent = SolanaAgentKit(
"your-wallet-private-key-as-base58",
"https://api.mainnet-beta.solana.com",
"your-openai-api-key"
)
signature = await agent.stake(
amount=1 # amount in SOL
)
import asyncio
asyncio.run(main())
Request Faucet Funds
from dipe import SolanaAgentKit
async def main():
agent = SolanaAgentKit(
"your-wallet-private-key-as-base58",
"https://api.mainnet-beta.solana.com",
"your-openai-api-key"
)
response = await agent.request_faucet_funds()
print(response)
import asyncio
asyncio.run(main())
Fetch Current TPS
from dipe import SolanaAgentKit
async def main():
agent = SolanaAgentKit(
"your-wallet-private-key-as-base58",
"https://api.mainnet-beta.solana.com",
"your-openai-api-key"
)
tps = await agent.get_tps()
print(f"Current TPS: {tps}")
import asyncio
asyncio.run(main())
Get Token Data by Ticker
from dipe import SolanaAgentKit
async def main():
agent = SolanaAgentKit(
"your-wallet-private-key-as-base58",
"https://api.mainnet-beta.solana.com",
"your-openai-api-key"
)
token_data = await agent.get_token_data_by_ticker("SOL")
print(token_data)
import asyncio
asyncio.run(main())
Get Token Data by Address
from dipe import SolanaAgentKit
from solders.pubkey import Pubkey
async def main():
agent = SolanaAgentKit(
"your-wallet-private-key-as-base58",
"https://api.mainnet-beta.solana.com",
"your-openai-api-key"
)
token_data = await agent.get_token_data_by_address("your-token-mint-address")
print(token_data)
import asyncio
asyncio.run(main())
Launch Pump Fun Token
from dipe import SolanaAgentKit
from dipe.types import PumpfunTokenOptions
async def main():
agent = SolanaAgentKit(
"your-wallet-private-key-as-base58",
"https://api.mainnet-beta.solana.com",
"your-openai-api-key"
)
options = PumpfunTokenOptions(
# Add your options here
)
response = await agent.launch_pump_fun_token(
token_name="MyToken",
token_ticker="MTK",
description="This is a fun token",
image_url="https://example.com/image.png",
options=options
)
print(response)
Create Meteora DLMM Pool
from dipe import SolanaAgentKit
from solders.pubkey import Pubkey
from dipe.utils.meteora_dlmm.types import ActivationType
async def main():
agent = SolanaAgentKit(
"your-wallet-private-key-as-base58",
"https://api.mainnet-beta.solana.com",
"your-openai-api-key"
)
response = await agent.create_meteora_dlmm_pool(
bin_step=1,
token_a_mint=Pubkey.from_string("token-a-mint"),
token_b_mint=Pubkey.from_string("token-b-mint"),
initial_price=1.0,
price_rounding_up=True,
fee_bps=30,
activation_type=ActivationType.Timestamp,
has_alpha_vault=True,
activation_point=None
)
print(response)
import asyncio
asyncio.run(main())
Buy Tokens with Raydium
from dipe import SolanaAgentKit
from solders.pubkey import Pubkey
async def main():
agent = SolanaAgentKit(
"your-wallet-private-key-as-base58",
"https://api.mainnet-beta.solana.com",
"your-openai-api-key"
)
confirmed = await agent.buy_using_raydium(
pair_address=Pubkey.from_string("target-pair-address"), # The pair you want to buy from
sol_in=1, # Amount of SOL or input token to spend
slippage=300 # Maximum slippage in basis points (3% here)
)
print(f"Transaction confirmed: {confirmed}")
import asyncio
asyncio.run(main())
Sell Tokens with Raydium
from dipe import SolanaAgentKit
from solders.pubkey import Pubkey
async def main():
agent = SolanaAgentKit(
"your-wallet-private-key-as-base58",
"https://api.mainnet-beta.solana.com",
"your-openai-api-key"
)
confirmed = await agent.sell_using_raydium(
input_mint=Pubkey.from_string("source-token-mint"), # The token you want to sell
percentage=100,
slippage_bps=250 # Maximum slippage in basis points (2.5% here)
)
print(f"Transaction confirmed: {confirmed}")
import asyncio
asyncio.run(main())
Burn and Close Token Account
from dipe import SolanaAgentKit
async def main():
agent = SolanaAgentKit(
"your-wallet-private-key-as-base58",
"https://api.mainnet-beta.solana.com",
"your-openai-api-key"
)
response = await agent.burn_and_close_accounts("token-account-address")
print("Account burned and closed:", response)
import asyncio
asyncio.run(main())
Batch burn and Close Token Account
from dipe import SolanaAgentKit
async def main():
agent = SolanaAgentKit(
"your-wallet-private-key-as-base58",
"https://api.mainnet-beta.solana.com",
"your-openai-api-key"
)
token_accounts = ["token-account-address-1", "token-account-address-2"]
responses = await agent.multiple_burn_and_close_accounts(token_accounts)
print("Accounts burned and closed:", responses)
import asyncio
asyncio.run(main())
API Reference
Core Functions
transfer(agent, to, amount, mint?)
Transfer SOL or SPL tokens to a recipient.
trade(agent, output_mint, input_amount, input_mint?, slippage_bps?)
Swap tokens using Jupiter Exchange integration.
get_balance(agent, token_address)
Check SOL or token balance for the agent's wallet.
lend_asset(agent, asset_mint, amount)
Lend idle assets to earn interest with Lulo.
stake(agent, amount)
Stake SOL with Jupiter to earn rewards.
request_faucet_funds(agent)
Request faucet funds for testing purposes.
deploy_token(agent, decimals)
Deploy a new token with specified decimals.
fetch_price(agent, token_id)
Fetch the price of a token.
get_tps(agent)
Fetch the current transactions per second (TPS) on the Solana network.
get_token_data_by_ticker(agent, ticker)
Get token data by ticker.
get_token_data_by_address(agent, mint)
Get token data by address.
launch_pump_fun_token(agent, token_name, token_ticker, description, image_url, options)
Launch a Pump & Fun token with customizable options.
create_meteora_dlmm_pool(agent, bin_step, token_a_mint, token_b_mint, initial_price, price_rounding_up, fee_bps, activation_type, has_alpha_vault, activation_point)
Create a Meteora DLMM pool with various configurations.
buy_using_raydium(agent, pair_address, sol_in, slippage)
Buy tokens from Raydium liquidity pools.
sell_using_raydium(agent, pair_address, percentage, slippage)
Sell tokens using Raydium liquidity pools.
burn_and_close_accounts(agent, token_account)
Burns and closes token account.
multiple_burn_and_close_accounts(agent, token_accounts)
Burns and closes multiple token accounts.
Dependencies
The toolkit relies on several key Solana and Metaplex libraries:
- solana-py
- spl-token-py
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
License
ISC License
Security
This toolkit handles private keys and transactions. Always ensure you're using it in a secure environment and never share your private keys.
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file dipe-1.2.8.tar.gz.
File metadata
- Download URL: dipe-1.2.8.tar.gz
- Upload date:
- Size: 48.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.0.1 CPython/3.12.6
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1d9bbd4beb7aff1aa054f9f73df74b21753136724686664c9371b9eaeb7490aa
|
|
| MD5 |
34470e4066938619400d75e95b37bbde
|
|
| BLAKE2b-256 |
63f82397b8d62e951faf8c0e00b184c5892dc4985dc73d00fcea6d5396998f32
|
File details
Details for the file dipe-1.2.8-py3-none-any.whl.
File metadata
- Download URL: dipe-1.2.8-py3-none-any.whl
- Upload date:
- Size: 63.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.0.1 CPython/3.12.6
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1cfb3d0e63f52c918289caacdf6f04ef9ce9162ad69acd094b376dd4fee25248
|
|
| MD5 |
35f14368e8e4da5a11a8435a294d1d52
|
|
| BLAKE2b-256 |
d23b2a43cb5927668c1e53c89b6e4704d12758060390c1b381530351c4d8ac71
|