A Rust SDK to interact with the Jupiter Aggregator APIs.
Easily fetch token quotes and execute swaps programmatically from your Rust applications.
cargo add jup-ag-sdkor Add this to your Cargo.toml:
[dependencies]
jup-ag-sdk = "1.0.6"- Complete API Coverage - All Jupiter APIs included Ultra, Swap, Trigger, Recurring, Token and Price
- Strongly typed – Full Rust structs for all request/response types
- Composable builders – Chainable methods to customize request payloads (e.g. taker, referral, fee, excluded routers)
Below is a simple example that shows how to fetch and execute an Ultra order with the SDK. For detailed example checkout examples/
use jup_ag_sdk::{
    JupiterClient,
    types::{UltraExecuteOrderRequest, UltraOrderRequest},
};
#[tokio::main]
async fn main() {
    // Initialize the Jupiter client with the Lite API endpoint
    let client = JupiterClient::new("https://lite-api.jup.ag");
    // Example: swap: 10 USDC (6 decimals) to SOL
    let input_token = "EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v"; // USDC
    let output_token = "So11111111111111111111111111111111111111112"; // SOL
    let amount = 10_000_000; // 10 USDC (in micro units)
    // Create an order request and specify the taker's wallet address
    let order_request = UltraOrderRequest::new(input_token, output_token, amount)
        .add_taker("your taker wallet address");
    // Fetch the unsigned transaction and request ID from Jupiter
    let order_response = client
        .get_ultra_order(&order_request)
        .await
        .expect("Failed to fetch ultra order");
    let unsigned_tx_base64 = order_response
        .transaction
        .expect("No transaction found in ultra order response");
    // sign the transaction. Checkout examples/src/lib.rs on how to sign the transaction
    // execute the signed transaction
    let execute_request = UltraExecuteOrderRequest {
        signed_transaction: signed_tx_base64,
        request_id: quote.request_id,
    };
    // Send the signed transaction to Jupiter for execution
    let execute_response = client
        .ultra_execute_order(&execute_request)
        .await
        .expect("Failed to execute transaction");
    // Print the transaction signature
    let tx_signature = execute_response
        .signature
        .expect("No signature found in execution response");
    println!("✅ Transaction submitted: {}", tx_signature);
}git clone https://github.com/Jupiter-DevRel/jup-rust-sdk
cd jup-rust-sdk
cargo buildopen to contributions and suggestions.
MIT License