Shortcuts Library
Explore shortcuts for common DeFi workflows.
The Enso Shortcuts system offers two powerful APIs for building DeFi workflows:
- Automated Routing: The POST
shortcuts/route
API calculates optimized multi-step paths for entering/exiting DeFi positions or swapping ERC20 tokens. It automatically creates a path between two positions specified in the request. - Bundling DeFi Actions: The POST
shortcuts/bundle
API lets you orchestrate DeFi workflows by composing multi-step sequences of Actions of your choosing.
Both APIs return a transaction object with calldata representing your workflow, ready to be submitted to EnsoShortcutRouter
for execution.
The following examples are on Ethereum (chainID=1).
1. Automated Routing
The POST route
API is suitable for single-path operations with automatic optimization.
Token Swaps
Optimize conversions between tokens by leveraging automated routing across DEXs.
Example: Swapping 1 ETH to USDC with the best execution price and 0.5% slippage
- Input: 1 ETH
- Output: USDC worth of 1 ETH
- Slippage: 0.5%
LST Staking Entry
Transform base tokens directly into staked liquid staking positions with a single call.
Example: Converting 1 ETH to stETH (Lido Staked ETH) in one step
- Input: 1 ETH
- Output: stETH
- Slippage: 0.5%
Yield Position Entry
Enter yield-generating positions from base assets.
Example: Moving from 1 WETH to a Yearn vault (yvWETH)
- Input: 1 WETH Output: yvWETH (exact amount depends on the vault’s share price)
- Slippage: 0.5%
Position Exit (Single Token)
Exit completely from a DeFi position back to a single base token.
Example: Converting 1 yvWETH (Yearn ETH vault) back to WETH
- Input: 1 yvWETH
- Output: WETH (actual amount depends on accrued yield)
- Slippage: 0.5%
LP Position Entry
Enter into LP token positions with automatic routing and slippage protection.
Example: Going from 1 ETH to ETH/USDC Uniswap LP tokens
- Output: ~0.92 ETH/USDC LP tokens (varies with pool composition)
- Slippage: 1%
Simple LST Zapping
Direct entry into or exit from liquid staking tokens.
Example: Converting 1 stETH back to ETH
- Input: 1 stETH (Lido Staked ETH)
- Output: ETH (varies with current discount/premium)
- Slippage: 1%
Note: Limited to simple LST interactions without complex staking steps. Use Bundle API for multi-step LST staking flows.
2. Bundling DeFi Actions
The Bundle API (POST /v1/shortcuts/bundle
) excels at orchestrating complex sequences of operations.
Multi-Position Entry
Splitting funds across several positions simultaneously
Example: Distributing 1 ETH into three LST tokens in one transaction
- Input: 1 ETH
- Outputs:
- stETH (Lido Staked ETH)
- rETH (Rocket Pool ETH)
- cbETH (Coinbase Staked ETH)
- Slippage: 1% for each conversion
- Process:
- Convert 1/3 ETH (0.333 ETH) to stETH
- Convert 1/3 ETH (0.333 ETH) to rETH
- Convert 1/3 ETH (0.334 ETH) to cbETH
Staking Pipeline
Chain multiple actions together to create a complete Curve LP staking workflow.
Example: Creating a staked Curve 3pool position starting with 1 ETH
- Input: 1 ETH
- Final Output: 3pool LP tokens staked in Curve gauge
- Process:
- Swap 1 ETH to USDC
- Deposit USDC into Curve 3pool to get 3pool LP tokens
- Stake 3pool LP tokens in the Curve gauge
Portfolio Rebalancing
Adjusting position sizes across multiple protocols.
Example: Rebalancing from 70% ETH/30% USDC to 50% ETH/50% USDC across Aave positions
- Input: 0.6 WETH (for reallocation)
- Output:
- 0.4 WETH deposited to Aave (aWETH)
- ~$580 USDC (from 0.2 WETH) deposited to Aave (aUSDC)
- Process:
- Convert 0.2 WETH to USDC
- Deposit 0.4 WETH into Aave (aWETH position)
- Deposit the acquired USDC into Aave (aUSDC position)
Position Migration
Moving from one protocol to another
Example: Migrating 1 aWETH from Aave to Compound’s cETH
- Input: 1 aWETH (Aave WETH)
- Output: cETH (Compound ETH)
- Process:
- Withdraw 1 WETH from Aave by redeeming aWETH
- Unwrap WETH to ETH
- Deposit ETH into Compound to get cETH
Leveraged Positions
Creating leveraged positions through multiple actions
Example: Creating a 2x ETH position using Aave
- Input: 1 WETH initial collateral
- Final Result: WETH worth of collateral in Aave
- Process:
- Deposit 1 WETH as collateral in Aave
- Borrow ~1,000 USDC against the WETH collateral
- Swap the borrowed 1,000 USDC back to ~0.35 WETH
- Deposit the additional WETH back into Aave as more collateral
Complex LST Zapping
Multi-step entry into or exit from liquid staking tokens with additional operations.
Example: Creating diversified LP and LST positions with 1 ETH
- Input: 1 ETH split evenly
- Slippage: 3% for each conversion
- Process:
- Convert 0.5 ETH to stETH/ETH Curve LP tokens
- Convert 0.5 ETH to BAL/WETH Balancer LP tokens
Yield Compounding Flow
Automate yield compounding by harvesting rewards, swapping, and redepositing in a single transaction.
Example: Compounding Curve gauge rewards back into the stETH/ETH pool
- Input: Existing position in stETH/ETH Curve gauge
- Process:
- Harvest accumulated wstETH rewards from the Curve gauge
- Convert wstETH rewards to stETH
- Deposit stETH back into the stETH/ETH Curve pool
- Slippage: 3%