What is the character limit for SMS text messages?
GSM-7 Encoding (Standard Characters)
| Message Length | Segments | Characters per Segment |
|---|---|---|
| 1-160 characters | 1 | 160 |
| 161-1600 characters | Multiple | 153 (7 chars for header) |
Unicode Encoding (Special Characters)
| Message Length | Segments | Characters per Segment |
|---|---|---|
| 1-70 characters | 1 | 70 |
| 71+ characters | Multiple | 67 (3 chars for header) |
What is automatic encoding?
Automatic encoding replaces Unicode characters with GSM-7 equivalents to prevent accidental segmentation from smart quotes, em dashes, etc.Enable Auto-Replace
- Navigate to Messaging > Settings > Other Settings
- Enable Auto-replace
How does SMS concatenation work?
Long messages are automatically split and reassembled:- Plivo splits message into segments
- Concatenation header added to each segment
- Carrier reassembles at delivery
- Recipient sees single message
Billing
Each segment is billed separately. A 200-character message = 2 segments = 2x SMS cost.How do I send SMS via API?
Single Message
Can I send bulk SMS?
Yes. Send to multiple recipients in one request:< character.
How can I receive SMS messages on my Plivo numbers?
- Create an application with a
message_url - Assign a Plivo number to the application
- Plivo POSTs inbound messages to your URL
How is an incoming message delivered to my application?
| Stage | Description |
|---|---|
| Received | Plivo receives from carrier (charged) |
| Delivered | Successfully posted to your message_url |
| Undelivered | Failed to deliver to your URL |
message_url is not configured, messages remain in “received” status.
Can the source number for an outbound text message be a non-Plivo number?
US and Canada
- Must use Plivo number as source
- Non-Plivo numbers not permitted (telecom regulations)
International
- Dynamic sender IDs may be used
- Delivery not guaranteed for non-Plivo numbers
- Check country coverage for sender ID support
What are Geo-Permissions and why should I use them?
Geo-Permissions control which countries can receive your SMS, protecting against fraud.Default Enabled Countries
- United States
- United Kingdom
- India
How Can I Manage Geo-Permissions?
- Navigate to Messaging > Settings > Geo Permissions
- Enable/disable countries as needed
- Set messages-per-hour fraud thresholds
Can I configure SMS Geo Permissions for each subaccount separately?
Yes. By default, subaccounts inherit main account settings. Override for subaccount:- Go to Geo Permissions
- Select subaccount from dropdown
- Customize settings
- Subaccount shows “Overridden” tag
- Select overridden subaccount
- Click Remove Override
Why are my outbound messages failing with error code 450?
Error 450 means “destination country barred.” The destination country is not enabled in your Geo Permissions. Enable the country in Messaging > Settings > Geo Permissions.What is SMS Pumping and how does Plivo protect against it?
SMS pumping is fraud where attackers flood OTP fields with fake requests to premium numbers.Protection Features
Enabled by default for all accounts:- Automated traffic analysis
- Suspicious pattern detection
- Alerts for unusual activity
How to Prevent SMS Pumping Attacks?
- Enable Geo Permissions
- Set rate limits on OTP endpoints
- Implement CAPTCHA on forms
- Monitor traffic patterns
- Use Plivo’s fraud detection tools
How to access the message content?
Message content is stored for 7 days.View in Console
- Navigate to Messaging > Logs
- Search by timeframe or UUID
- View message details
Why should I authorize Plivo to view my SMS content?
Allow Plivo support to view content for debugging:- Helps identify spam filter triggers
- Assists with delivery issues
- Enables content policy review
What happens to my outbound messages if I don’t have sufficient balance?
When balance is insufficient:- Messages fail with error code 900
- API requests fail for 2 minutes with “Insufficient Credit”
- Queued messages continue to fail until recharged
Why were we charged for an undelivered SMS message?
Plivo charges when a message is successfully handed off to downstream carriers. Once accepted by the carrier, Plivo has no control over final delivery. Reasons for undelivered status:- Invalid or unreachable destination number
- Carrier filtering
- Device issues (phone off, full inbox)
What are the different SMS statuses in Plivo?
| Status | Description |
|---|---|
| queued | Message accepted, waiting to send |
| sent | Successfully passed to downstream carrier (charged) |
| delivered | Confirmed delivery to recipient device |
| undelivered | Carrier could not deliver to recipient |
| failed | Internal error before reaching carrier (not charged) |
What are the Toll-Free Surcharges?
US carriers impose surcharges on toll-free messaging:| Carrier | Surcharge per Segment |
|---|---|
| Verizon | $0.0025 |
| T-Mobile | Varies |
| AT&T | Varies |
What is the Number Lookup API?
Get information about phone numbers:- Local and E.164 formatting
- Carrier information
- Caller ID name (CNAM)