Billing Overview
Exotel operates on a prepaid, credit-based billing model. You purchase credits in advance, and usage is deducted in real time as calls are made and SMS messages are sent. This guide explains how billing works across all Exotel services.
To check your current balance or add credits, log in to my.exotel.com and navigate to Billing in the left sidebar.
How Exotel Billing Worksβ
ββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
β Exotel Billing Flow β
β β
β Add Credits βββΊ Account Balance βββΊ Usage Deducted β
β (Prepaid) (Real-Time) (Per-Pulse/SMS) β
β β
β βββββββββββββββ βββββββββββββββ βββββββββββββββ β
β β Voice β β SMS β β ExoPhone β β
β β Per-pulse β β Per-messageβ β Rental β β
β βββββββββββββββ βββββββββββββββ βββββββββββββββ β
ββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
Billing Componentsβ
| Component | Billing Model | Frequency |
|---|---|---|
| Voice Calls | Per-pulse (typically 60-second pulses) | Real-time deduction |
| SMS Messages | Per-message (varies by route/type) | Real-time deduction |
| ExoPhone Rental | Monthly rental per virtual number | Monthly charge |
| WhatsApp Messages | Per-conversation (24-hour window) | Real-time deduction |
| Contact Center | Per-agent seat (monthly) | Monthly charge |
| Add-on Services | Varies by feature | As configured |
Account Balanceβ
Your account balance is the total credit available for usage. It is displayed in real time on the Exotel dashboard and can be queried via the API.
Balance Deduction Priorityβ
- Voice calls -- Deducted at the end of each pulse during the call
- SMS -- Deducted when the message is submitted to the carrier
- Recurring charges -- Deducted on the renewal date (ExoPhone rental, agent seats)
If your account balance reaches zero, all outbound calls and SMS will be blocked immediately. Inbound calls to your ExoPhones will also stop working. Set up usage alerts to avoid service disruption.
Billing Cycleβ
Exotel follows a calendar month billing cycle:
- Credit Purchase -- Add credits at any time via the dashboard or bank transfer
- Real-Time Usage -- Credits are consumed as services are used
- Monthly Invoice -- A GST-compliant invoice is generated at the end of each month
- Renewal Charges -- ExoPhone rentals and seat licenses renew on their activation anniversary
Key Billing Conceptsβ
Pulse-Based Voice Billingβ
Voice calls are billed in pulses. A pulse is the minimum billable unit for a call, typically 60 seconds. If a call lasts 61 seconds with a 60-second pulse, you are charged for 2 pulses.
See Pricing Model for detailed pulse billing mechanics.
Per-SMS Billingβ
SMS messages are billed per message sent, regardless of delivery status. Rates vary based on:
- Message type -- Transactional, promotional, or OTP
- Route -- DLT-compliant routes have different pricing
- Volume -- Higher volumes may qualify for discounted rates
ExoPhone Rentalβ
Each virtual number (ExoPhone) incurs a monthly rental charge. Rental amounts depend on:
- Number type -- Landline, mobile, or toll-free
- Region -- Indian or international numbers
- Features -- Standard vs. vanity numbers
Billing Dashboardβ
Access your billing information at my.exotel.com > Billing:
| Section | What You Can Do |
|---|---|
| Balance | View current credit balance and recent transactions |
| Add Credits | Purchase credits via multiple payment methods |
| Usage | View detailed usage breakdown by service type |
| Invoices | Download monthly GST-compliant invoices |
| Alerts | Configure low-balance and spending alerts |
| Payment History | View all past credit purchases and payments |
Related Topicsβ
- Pricing Model -- Understand per-pulse and per-SMS rate structures
- Plans Comparison -- Compare Starter, Growth, and Enterprise plans
- Add Credits -- Payment methods and auto-recharge setup
- Usage Tracking -- Real-time balance monitoring and spending limits
- Invoices -- Monthly invoicing and GST compliance
- Refund Policy -- Cancellation and refund terms
- Enterprise Billing -- Custom pricing and volume discounts
- International Rates -- Calling and SMS rates by country