Paymaster Management
Paymasters in Slot allow you to sponsor transaction fees for your applications, enabling gasless experiences for your users. The Cartridge Paymaster is a powerful feature that enables gasless transactions for your users, creating a more seamless Web3 experience. When enabled, the paymaster automatically covers transaction fees on behalf of your users, eliminating the need for them to hold ETH / STRK for gas fees. You can manage budgets, policies, and monitor usage through the Slot CLI.
Availability
The paymaster service is available across all networks with different activation requirements:
- 
Testnet Networks
- Automatically enabled, no additional setup required
 
- 
Mainnet
- Available and fully self-served
- Manage everything through the Slot CLI
- Define your own usage scopes and spending limits
 
Integration
One of the key benefits of the Cartridge Paymaster is that it requires zero additional integration work. When the paymaster is enabled for your application, it will automatically activate for all eligible transactions. No code changes or configuration are needed.
Prerequisites
Make sure you are authenticated with Slot:
slot auth loginTeam Setup
Before creating a paymaster, you need a team with sufficient credits.
Create a Team (if it doesn't exist)
slot teams <team-name> create --email <your-email@example.com>Fund Your Account and Transfer to Team
Paymasters automatically deduct from your team's account balance when created. If you don't have sufficient credits:
# Buy credits for your account (opens browser)
slot auth fund- Select the team you want to fund from the list
- Choose your payment method (credit card or crypto)
- Complete the purchase
Creating a Paymaster
Create a new paymaster with an initial budget:
slot paymaster <paymaster-name> create --team <team-name> --budget <amount> --unit CREDITExample
slot paymaster my-game-pm create --team my-team --budget 1000 --unit CREDIT✅ Paymaster Created Successfully
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
 
🏢 Details:
  • Name: my-game-pm
  • Team: my-team
 
💰 Initial Budget:
  • Amount: 1000 CREDIT ($10.00 USD)Managing Budget
Increase Budget
Add funds to your paymaster:
slot paymaster <paymaster-name> budget increase --amount <amount> --unit CREDIT✅ Budget Increased Successfully
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
 
🏢 Paymaster: my-game-pm
 
📈 Operation:
  • Action: Increased
  • Amount: 500 CREDIT
 
💰 New Budget:
  • Amount: 1500 CREDIT ($15.00 USD)Decrease Budget
Remove funds from your paymaster:
slot paymaster <paymaster-name> budget decrease --amount <amount> --unit CREDIT✅ Budget Decreased Successfully
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
 
🏢 Paymaster: my-game-pm
 
📉 Operation:
  • Action: Decreased
  • Amount: 200 CREDIT
 
💰 New Budget:
  • Amount: 1300 CREDIT ($13.00 USD)Policy Management
Policies define which contracts and entry points your paymaster will sponsor.
Understanding Paymaster Predicates
Paymaster policies now support predicates - conditional logic that determines whether a transaction should be sponsored. This enables sophisticated sponsorship rules based on game state, user eligibility, or other custom conditions.
How Predicates Work:- When a transaction is submitted to a paymaster with a predicate-enabled policy
- The paymaster first calls the predicate contract function
- If the predicate returns true, the transaction is sponsored
- If the predicate returns falseor reverts, the transaction is not sponsored
- Sponsor moves only for players with sufficient in-game energy
- Sponsor attacks only during specific game phases
- Sponsor crafting only for players with required materials
- Rate-limit sponsorship per user or per game session
Add Policies from Preset (Recommended)
The preferred way to add policies is using verified contract presets for your games:
slot paymaster <paymaster-name> policy add-from-preset --name <preset-name>slot paymaster my-game-pm policy add-from-preset --name dope-warsAdd a Single Policy
For individual contract policies or custom contracts not yet in presets:
slot paymaster <paymaster-name> policy add --contract <contract-address> --entrypoint <entry-point>Add Policies from JSON File
For bulk adding multiple custom policies:
slot paymaster <paymaster-name> policy add-from-json --file <path-to-json>[
  {
    "contractAddress": "0x1234...abcd",
    "entrypoint": "move_player"
  },
  {
    "contractAddress": "0x5678...efgh",
    "entrypoint": "attack",
    "predicate": {
      "address": "0x9abc...1234",
      "entrypoint": "check_attack_eligibility"
    }
  }
]Remove a Policy
slot paymaster <paymaster-name> policy remove --contract <contract-address> --entrypoint <entry-point>Successfully removed policy: PolicyArgs { contract: "0x1234...abcd", entrypoint: "move_player" }Remove All Policies
slot paymaster <paymaster-name> policy remove-allList Policies
slot paymaster <paymaster-name> policy listPaymaster Information
Get comprehensive information about your paymaster:
slot paymaster <paymaster-name> info🔍 Paymaster Info for 'my-game-pm'
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
🏢 Details:
  • Team: my-team
  • Active: ✅ Yes
 
💰 Budget:
  • Total: 9000 CREDIT ($90.00 USD)
  • Spent: 1759.56 CREDIT ($17.60 USD)
  • Usage: [█████░░░░░░░░░░░░░░░░░░░░░░░░░] 19.7%
 
📋 Policies:
  • Count: 3Updating Paymaster Configuration
Update your paymaster's basic configuration settings:
slot paymaster <current-name> update [OPTIONS]Update Paymaster Name
slot paymaster my-game-pm update --name new-game-pmChange Team Association
Transfer the paymaster to a different team:
slot paymaster my-game-pm update --team new-teamEnable/Disable Paymaster
Toggle the active state of your paymaster:
# Disable paymaster (stops sponsoring transactions)
slot paymaster my-game-pm update --active false
 
# Re-enable paymaster
slot paymaster my-game-pm update --active trueStatistics and Monitoring
View usage statistics for your paymaster:
slot paymaster <paymaster-name> stats --last <time-period>slot paymaster my-game-pm stats --last 24hr- 1hr,- 2hr,- 24hr
- 1day,- 2day,- 7day
- 1week
📊 Paymaster Stats for 'my-game-pm' (Last 24hr)
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
📈 Transactions:
  • Total: 1,247
  • Successful: 1,198
  • Reverted: 49
  • Success Rate: 96.1%
 
💰 Fees (USD):
  • Total (24hr): $12.45
  • Average: $0.009988
  • Minimum: $0.001234
  • Maximum: $0.045678
 
👥 Users:
  • Unique Users: 89Transaction History
View detailed transaction history for your paymaster with filtering and sorting options:
slot paymaster <paymaster-name> transactions [OPTIONS]Basic Usage
View recent transactions:
slot paymaster my-game-pm transactions📊 Paymaster Transactions for 'my-game-pm' (Last 24hr)
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
Transaction Hash                                                   Executed     Status       USD Fee
──────────────────────────────────────────────────────────────────────────────────────────────────────────────
0x50c2dd556593564fe2b814d61b3b1592682de83702552a993d24f9e897710e7  11s ago      SUCCESS      $0.0026
0x41b0f547741bd1fdc29dd4c82a80da2a452314e710ae7cbe0e05cb4cb1e6c0e  22s ago      SUCCESS      $0.0025
0x4b74ee2ab7764cb3d11f3319b64c2698b868727fdf99728bdf74aa023b5e77d  32s ago      REVERTED     $0.0028
0x2af69b9798355e91119c6a9adb1363b2f533f0557601e4687dcfe9725e8feaa  42s ago      SUCCESS      $0.0025
0x25dfc115dabda89a2027366790ee5cfcfefb861fe1b584c6fb15dc1588e0816  47s ago      REVERTED     $0.0032Filtering Options
Filter by Status:# Show only successful transactions
slot paymaster my-game-pm transactions --filter SUCCESS
 
# Show only reverted transactions
slot paymaster my-game-pm transactions --filter REVERTED
 
# Show all transactions (default)
slot paymaster my-game-pm transactions --filter ALL# Last hour
slot paymaster my-game-pm transactions --last 1hr# Sort by fees (ascending)
slot paymaster my-game-pm transactions --order-by FEES_ASC
 
# Sort by fees (descending)
slot paymaster my-game-pm transactions --order-by FEES_DESC
 
# Sort by execution time (most recent first - default)
slot paymaster my-game-pm transactions --order-by EXECUTED_AT_DESC
 
# Sort by execution time (oldest first)
slot paymaster my-game-pm transactions --order-by EXECUTED_AT_ASC# Show up to 50 transactions (max 1000)
slot paymaster my-game-pm transactions --limit 50Dune Analytics Queries
Generate Dune Analytics queries to analyze your paymaster's transaction data:
slot paymaster <paymaster-name> dune [OPTIONS]Example Dashboard
See a live example of paymaster analytics at Blob Arena Stats on Dune Analytics.
Basic Usage
Generate a comprehensive SQL query for your paymaster:
slot paymaster my-game-pm duneThe query provides exhaustive analysis including:
- Finds all execute_from_outside_v3 selectors in transaction calldata
- Handles both normal calls and multi-call VRF helpers
- Matches all patterns including nested VRF calls
- Comprehensive metrics with daily, weekly, and monthly breakdowns
Time Period Options
By default, queries use the paymaster's creation time. You can specify a custom time period:
# Last 24 hours
slot paymaster my-game-pm dune --last 24hr
 
# Last week
slot paymaster my-game-pm dune --last 1week- 1hr,- 2hr,- 24hr
- 1day,- 2day,- 7day
- 1week
Dune Template Parameters
For dynamic queries in Dune dashboards, use template parameters:
slot paymaster my-game-pm dune --dune-paramsThis generates a query with {{start_time}} and {{end_time}} parameters that you can configure in your Dune dashboard.
Query Output
The command generates a comprehensive SQL query that includes:
Daily Metrics:- Transaction counts and unique users
- New vs returning users
- Fees in STRK and USD
- Transactions per user ratio
- 7-day active users (WAU)
- 30-day active users (MAU)
- Weekly and monthly summaries
- Overall totals and averages
- User acquisition and retention metrics
Usage Tips
For Dashboard Creation:- Use --dune-paramsfor interactive dashboards
- Copy the generated SQL directly into Dune Analytics
- Set up time range parameters for flexible analysis
- Specify --lastwith appropriate time period
- Query will include actual timestamps for immediate execution
Common Use Cases
Growth Analysis:slot paymaster my-game-pm dune --last 1weekAnalyze weekly growth trends, user acquisition, and engagement patterns.
Daily Monitoring:slot paymaster my-game-pm dune --last 24hrMonitor recent activity, transaction success rates, and costs.
Dashboard Setup:slot paymaster my-game-pm dune --dune-paramsCreate flexible dashboards with configurable time ranges.
Quick Debugging Use Cases
The transaction history is useful for identifying issues:
View expensive transactions that might indicate inefficient contract calls:slot paymaster my-game-pm transactions --order-by FEES_DESC --limit 10slot paymaster my-game-pm transactions --filter REVERTED --last 24hrBest Practices
Budget Management
- Start with a conservative budget and increase as needed
- Monitor spending through the stats command
- Keep sufficient team balance for paymaster operations
Policy Management
- Be specific with your policies to avoid sponsoring unintended transactions
- Use presets whenever possible for verified game contracts in the Dojo ecosystem
- Contribute your game contracts to the preset repository for community verification
- Regularly review and update policies as your application evolves
- Test policies with small budgets before scaling up
Security
- Only add policies for contracts you trust
- Keep your team membership limited to necessary collaborators
Common Workflows
Setting up a new game paymaster
# Create team if it doesn't exist
slot teams my-team create --email developer@mygame.com
 
# Fund a team
slot auth fund
 
# Create paymaster
slot paymaster my-game-pm create --team my-team --budget 1000 --unit CREDIT
 
# Add game contract policies
slot paymaster my-game-pm policy add --contract 0x123...abc --entrypoint move_player
slot paymaster my-game-pm policy add --contract 0x123...abc --entrypoint attack_enemy
slot paymaster my-game-pm policy add --contract 0x123...abc --entrypoint use_item
 
# Check initial setup
slot paymaster my-game-pm infoMonitoring and maintenance
# Check daily stats
slot paymaster my-game-pm stats --last 24hr
 
# Check current status
slot paymaster my-game-pm info
 
# Add more budget if needed (ensure team has credits)
slot paymaster my-game-pm budget increase --amount 500 --unit CREDITInsufficient Credits Error
If you encounter insufficient credits when creating or funding a paymaster:
# Check team balance first
slot teams my-team info
 
# Fund a team
slot auth fund
 
# Retry your paymaster operation
slot paymaster my-game-pm create --team my-team --budget 1000 --unit CREDIT