• Stars
    star
    1,335
  • Rank 33,836 (Top 0.7 %)
  • Language
    Ruby
  • License
    MIT License
  • Created over 14 years ago
  • Updated 8 months ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

A Ruby gem for communicating with the Twilio API and generating TwiML

twilio-ruby

Tests Gem Version Learn with TwilioQuest

Documentation

The documentation for the Twilio API can be found here.

The individual releases here.

Versions

twilio-ruby uses a modified version of Semantic Versioning for all changes. See this document for details.

Supported Ruby Versions

This library supports the following Ruby implementations:

  • Ruby 2.4

  • Ruby 2.5

  • Ruby 2.6

  • Ruby 2.7

  • Ruby 3.0

  • Ruby 3.1

  • Ruby 3.2

  • JRuby 9.2

  • JRuby 9.3

  • JRuby 9.4

Migrating from 5.x

Upgrade Guide

Installation

To install using Bundler grab the latest stable version:

gem 'twilio-ruby', '~> 7.0.2'

To manually install twilio-ruby via Rubygems simply gem install:

gem install twilio-ruby -v 7.0.2

To build and install the development branch yourself from the latest source:

git clone [email protected]:twilio/twilio-ruby.git
cd twilio-ruby
make install

Info If the command line gives you an error message that says Permission Denied, try running the above commands with sudo.

For example: sudo gem install twilio-ruby

Test your installation

To make sure the installation was successful, try sending yourself an SMS message, like this:

require "twilio-ruby"

# Your Account SID and Auth Token from console.twilio.com
account_sid = "ACXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX"
auth_token = "your_auth_token"

@client = Twilio::REST::Client.new account_sid, auth_token
message = @client.messages.create(
  body: "Hello from Ruby",
  to: "+12345678901",  # Text this number
  from: "+15005550006", # From a valid Twilio number
)

puts message.sid

Warning It's okay to hardcode your credentials when testing locally, but you should use environment variables to keep them secret before committing any code or deploying to production. Check out How to Set Environment Variables for more information.

Usage

Authenticate the Client

require 'twilio-ruby'

# Your Account SID and Auth Token from console.twilio.com
account_sid = 'ACxxxxxxxxxxxxxxxxxxxxxxxxxxxxx'
auth_token = 'yyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy'

# Initialize the Twilio Client with your credentials
@client = Twilio::REST::Client.new account_sid, auth_token

Use An API Key

require 'twilio-ruby'

# Your Account SID from console.twilio.com
account_sid = 'ACxxxxxxxxxxxxxxxxxxxxxxxxxxxxx'
# API Key from twilio.com/console/project/api-keys
api_key_sid = 'zzzzzzzzzzzzzzzzzzzzzz'
api_key_secret = 'yyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy'

# set up a client to talk to the Twilio REST API using an API Key
@client = Twilio::REST::Client.new api_key_sid, api_key_secret, account_sid

Specify a Region and/or Edge

To take advantage of Twilio's Global Infrastructure, specify the target Region and/or Edge for the client:

# set up a client to talk to the Twilio REST API over a specific region and edge
@client = Twilio::REST::Client.new account_sid, auth_token, nil, 'au1'
@client.edge = 'sydney'

# you may also specify the region and/or edge after client creation
@client = Twilio::REST::Client.new account_sid, auth_token
@client.region = 'au1'
@client.edge = 'sydney'

This will result in the hostname transforming from api.twilio.com to api.sydney.au1.twilio.com.

Make a Call

@client.calls.create(
  from: '+14159341234',
  to: '+16105557069',
  url: 'http://example.com'
)

Send an SMS

@client.messages.create(
  from: '+14159341234',
  to: '+16105557069',
  body: 'Hey there!'
)

List your SMS Messages

@client.messages.list(limit: 20)

Fetch a single SMS message by Sid

# put the message sid you want to retrieve here:
message_sid = 'SMxxxxxxxxxxxxxxxxxxxxxxxxxxxxx'
@client.messages(message_sid).fetch

Iterate through records

The library automatically handles paging for you. Collections, such as calls and messages, have list and stream methods that page under the hood. With both list and stream, you can specify the number of records you want to receive (limit) and the maximum size you want each page fetch to be (page_size). The library will then handle the task for you.

list eagerly fetches all records and returns them as a list, whereas stream returns an enumerator and lazily retrieves pages of records as you iterate over the collection. You can also page manually using the page method.

For more information about these methods, view the auto-generated library docs.

require 'twilio-ruby'

account_sid = 'ACXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'
auth_token = 'your_auth_token'

@client = Twilio::REST::Client.new(account_sid, auth_token)

@client.calls.list
       .each do |call|
         puts call.direction
       end

Enable Debug logging

In order to enable debug logging, pass in a 'logger' instance to the client with the level set to at least 'DEBUG'

@client = Twilio::REST::Client.new account_sid, auth_token
myLogger = Logger.new(STDOUT)
myLogger.level = Logger::DEBUG
@client.logger = myLogger

@client = Twilio::REST::Client.new account_sid, auth_token
myLogger = Logger.new('my_log.log')
myLogger.level = Logger::DEBUG
@client.logger = myLogger

Handle Exceptions {#exceptions}

If the Twilio API returns a 400 or a 500 level HTTP response, the twilio-ruby library will throw a Twilio::REST::RestError. 400-level errors are normal during API operation (“Invalid number”, “Cannot deliver SMS to that number”, for example) and should be handled appropriately.

require 'twilio-ruby'

account_sid = 'ACXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'
auth_token = 'your_auth_token'

@client = Twilio::REST::Client.new account_sid, auth_token

begin
  messages = @client.messages.list(limit: 20)
rescue Twilio::REST::RestError => e
  puts e.message
end

Debug API requests

To assist with debugging, the library allows you to access the underlying request and response objects. This capability is built into the default HTTP client that ships with the library.

For example, you can retrieve the status code of the last response like so:

require 'rubygems' # Not necessary with ruby 1.9 but included for completeness
require 'twilio-ruby'

# Your Account SID and Auth Token from console.twilio.com
account_sid = 'ACXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX'
auth_token = 'your_auth_token'

@client = Twilio::REST::Client.new(account_sid, auth_token)

@message = @client.messages.create(
  to: '+14158675309',
  from: '+14258675310',
  body: 'Ahoy!'
)

# Retrieve the status code of the last response from the HTTP client
puts @client.http_client.last_response.status_code

Customize your HTTP Client

twilio-ruby uses Faraday to make HTTP requests. You can tell Twilio::REST::Client to use any of the Faraday adapters like so:

@client.http_client.adapter = :typhoeus

To use a custom HTTP client with this helper library, please see the advanced example of how to do so.

To apply customizations such as middleware, you can use the configure_connection method like so:

@client.http_client.configure_connection do |faraday|
  faraday.use SomeMiddleware
end

Get started With Client Capability Tokens

If you just need to generate a Capability Token for use with Twilio Client, you can do this:

require 'twilio-ruby'

# put your own account credentials here:
account_sid = 'ACxxxxxxxxxxxxxxxxxxxxxxxxxxxxx'
auth_token = 'yyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy'

# set up
capability = Twilio::JWT::ClientCapability.new account_sid, auth_token

# allow outgoing calls to an application
outgoing_scope = Twilio::JWT::ClientCapability::OutgoingClientScope.new 'AP11111111111111111111111111111111'
capability.add_scope(outgoing_scope)

# allow incoming calls to 'andrew'
incoming_scope = Twilio::JWT::ClientCapability::IncomingClientScope.new 'andrew'
capability.add_scope(incoming_scope)

# generate the token string
@token = capability.to_s

There is a slightly more detailed document in the Capability section of the wiki.

Generate TwiML

To control phone calls, your application needs to output TwiML.

You can construct a TwiML response like this:

require 'twilio-ruby'

response = Twilio::TwiML::VoiceResponse.new do |r|
  r.say(message: 'hello there', voice: 'alice')
  r.dial(caller_id: '+14159992222') do |d|
    d.client 'jenny'
  end
end

# print the result
puts response.to_s

This will print the following (except for the whitespace):

<?xml version="1.0" encoding="UTF-8"?>
<Response>
  <Say voice="alice">hello there</Say>
  <Dial callerId="+14159992222">
    <Client>jenny</Client>
  </Dial>
</Response>

Docker Image

The Dockerfile present in this repository and its respective twilio/twilio-ruby Docker image are currently used by Twilio for testing purposes only.

Getting help

If you need help installing or using the library, please check the Twilio Support Help Center first, and file a support ticket if you don't find an answer to your question.

If you've instead found a bug in the library or would like new features added, go ahead and open issues or pull requests against this repo!

More Repositories

1

twilio-video-app-react

A collaboration application built with the twilio-video.js SDK and React.js
TypeScript
1,793
star
2

twilio-python

A Python module for communicating with the Twilio API and generating TwiML.
Python
1,707
star
3

stashboard

An open-source status dashboard running on App Engine
Python
1,594
star
4

twilio-php

A PHP library for communicating with the Twilio REST API and generating TwiML.
PHP
1,447
star
5

twilio-node

Node.js helper library
TypeScript
1,304
star
6

OpenVBX

OpenVBX is a web-based open source phone system for business.
PHP
699
star
7

twilio-csharp

Twilio C#/.NET Helper Library for .NET Framework 3.5+ and supported .NET Core versions
C#
636
star
8

BankersBox

redis-like wrapper for javascript storage
CoffeeScript
571
star
9

twilio-video.js

Twilio’s Programmable Video JavaScript SDK
JavaScript
563
star
10

video-quickstart-ios

Twilio Video Quickstart for iOS
Swift
455
star
11

twilio-java

A Java library for communicating with the Twilio REST API and generating TwiML.
Java
440
star
12

video-quickstart-js

A quickstart and code samples for Twilio Video JavaScript SDK. https://www.twilio.com/docs/video
JavaScript
390
star
13

shadow

A HTTP debugging proxy that helps you with your continuous deployments
JavaScript
330
star
14

twilio-go

A Go package for communicating with the Twilio API.
Go
249
star
15

twilio-video-app-ios

A collaboration application built with the Twilio Video iOS SDK
Swift
246
star
16

authy-php

A PHP client for Authy
PHP
245
star
17

twilio-sans-mono

Twilio Sans Mono is a beautiful and extensive open source programming font
Shell
240
star
18

twilio-video-app-android

A collaboration application built with the Twilio Video Android SDK
Kotlin
239
star
19

video-quickstart-android

Twilio Video Quickstart for Android
Java
210
star
20

authy-devise

Authy Devise plugin to add Two-Factor Authentication
Ruby
199
star
21

authy-python

Authy API Client for Python
Python
188
star
22

twilio-salesforce

A Salesforce/Force.com library for communicating with the Twilio REST API and generating TwiML. Need help? Post your questions to http://getsatisfaction.com/twilio or email us at [email protected]
Apex
186
star
23

voice-quickstart-android

Quickstart app for the Voice Android SDK
Java
185
star
24

voice-quickstart-ios

Twilio Voice Quickstart for iOS with Swift
Objective-C
177
star
25

authy-ruby

**Deprecated** Ruby library to access the authy API
Ruby
156
star
26

audioswitch

An Android audio management library for real-time communication apps.
Kotlin
153
star
27

authy-openvpn

Authy Open VPN Two-Factor Authentication
C
152
star
28

twilio-cli

Unleash the power of Twilio from your command prompt
JavaScript
150
star
29

gameday

A collection of Twilio SRE's Gameday Templates
140
star
30

chessms

Play Chess over SMS!
Erlang
112
star
31

TwilioChatJsReactNative

ReactNative app example for Twilio Programmable Chat with working iOS and Android push messages https://www.twilio.com/chat
JavaScript
112
star
32

twilio-oai

The Twilio OpenAPI Specification
Makefile
112
star
33

apkscale

A Gradle plugin to measure the app size impact of Android libraries
Kotlin
94
star
34

OpenVBX-iPhone

OpenVBX for iPhone
Objective-C
92
star
35

twilio-chat-demo-js

Programmable Chat API Demo Application for JavaScript
JavaScript
92
star
36

media-streams

Quick start guides for configuring and consuming Twilio Media Streams
Ruby
90
star
37

twilio-conversations-demo-react

Twilio Conversations Demo Web Application
TypeScript
87
star
38

starter-node

A starter app for node.js developers embarking on their first Twilio quest!
JavaScript
84
star
39

authy-form-helpers

Authy javascripts and css file to help create quick forms for the authy api
CoffeeScript
83
star
40

flex-plugin-builder

Packages related to building a Twilio Flex Plugin
TypeScript
82
star
41

starter-python

A starter app for Python developers embarking on their first Twilio quest!
CSS
76
star
42

sourd.io

sourd.io: temperature, humidity, and rise monitoring for your sourdough starter
C++
72
star
43

authy-java

Java Client for Twilio Authy Two-Factor Authentication (2FA) API
Java
65
star
44

twilio-client.js

Twilio’s Programmable Voice JavaScript SDK
TypeScript
65
star
45

twilio-video-ios

Programmable Video SDK by Twilio
Swift
64
star
46

twilio-chat-demo-android

Chat API Demo Application for Android
Kotlin
63
star
47

terraform-provider-twilio

Terraform Twilio provider
Go
57
star
48

twilio-webchat-react-app

Twilio Webchat React App is an application that demonstrates a website chat widget built with Twilio's Conversations JS SDK, Twilio Paste Design library and Create React App.
TypeScript
55
star
49

twilio-voice-react-native

TypeScript
51
star
50

twilio-webrtc.js

WebRTC-related APIs and shims used by twilio-video.js
JavaScript
49
star
51

rtc-diagnostics

TypeScript
44
star
52

twilio-voice.js

Twilio's JavaScript Voice SDK
TypeScript
44
star
53

flex-ui-sample

Twilio Flex UI Sample
JavaScript
42
star
54

twilio-video-diagnostics-react-app

A diagnostics tool that tests a participant's ability to have a quality video call. Built with the twilio-video.js SDK, RTC Diagnostics SDK, and React.js.
TypeScript
41
star
55

wiztowar

Build WARs from your Dropwizard apps
Java
40
star
56

voice-quickstart-objc

Twilio Voice Quickstart for iOS with Objective-C
Objective-C
38
star
57

hackathons

A collection of tips and tricks for using Twilio at hackathons
37
star
58

sample-code

Auto-generated code samples for the Twilio REST API
Java
36
star
59

draw-with-twilio

Draw with Twilio
JavaScript
35
star
60

twilio-voice-ios

Programmable Voice SDK by Twilio
Swift
34
star
61

twilio-voice-notification-app

Reference app built in ReactJS that demonstrates how to leverage Twilio Programmable Voice and Twilio SDKs to create a voice notification system.
TypeScript
34
star
62

video-quickstart-objc

Twilio Video Quickstart for iOS with Objective-C
Objective-C
33
star
63

twilio-video-processors.js

Twilio Video Processors is a collection of video processing tools which can be used with Twilio Video JavaScript SDK to apply transformations and filters to a video track.
TypeScript
33
star
64

TwilioChatXamarinBindings

Twilio Chat Bindings for Xamarin (Android and iOS) and Sample app with working FCM and APN pushes using those bindings.
C#
32
star
65

twilio-live-interactive-video

An interactive live video app built with Twilio Live and Twilio Video
TypeScript
31
star
66

twilio-video.js-recording-bot

JavaScript
30
star
67

flex-webchat-ui-sample

Twilio Flex Web Chat UI Sample
JavaScript
30
star
68

twilio-chat-demo-ios

Twilio Programmable Chat Demo Application for iOS
Objective-C
28
star
69

ortc-adapter

ORTC to WebRTC Adapter
JavaScript
28
star
70

cloudsec

27
star
71

starter-ruby

A starter app for Ruby developers embarking on their first Twilio quest!
JavaScript
27
star
72

calcite-kudu

Apache Calcite Adapter for Apache Kudu
Java
26
star
73

autopilot-cli

The Twilio Autopilot CLI is now deprecated. Please use the Autopilot Plugin for the Twilio CLI here https://www.twilio.com/docs/autopilot/twilio-autopilot-cli
JavaScript
26
star
74

twilio-oai-generator

Twilio OpenAPI client generator
Java
25
star
75

voice-quickstart-server-python

Python
25
star
76

twilio-video-room-monitor.js

A browser-based tool that displays information and metrics about Twilio Video JavaScript applications
TypeScript
24
star
77

video-shared-arkit-sample

ARKit + Twilio Video Data Tracks demo
Swift
24
star
78

twilio-voice-react-native-app

TypeScript
24
star
79

twilio-boost-build

Build tool for boost libraries on android, ios, linux and osx
Shell
23
star
80

voice-quickstart-server-node

voice quickstart server example in node
JavaScript
23
star
81

wireless-security-camera

Create a Twilio-powered device that keeps watch over dangerous and remote locations and alerts stakeholders of intrusions or safety concerns.
CSS
22
star
82

starter-java

A starter app for Java developers embarking on their first Twilio quest!
CSS
22
star
83

twilio-taskrouter.js

JS SDK v2 for Twilio's TaskRouter skills based routing system.
JavaScript
21
star
84

autopilot-templates

JavaScript
20
star
85

wireless-fleet-tracker

Create a Twilio-powered Fleet Tracker that uses off-the-shelf components to track and log: miles driven, hours of uptime and downtime, locations, average speed, and fuel consumption.
CSS
20
star
86

client-js-1.4-examples

Examples for using the new Client JS 1.4 Audio functionality
JavaScript
19
star
87

voices

Twilio Voices - Contribute programming tutorials to the Twilio blog. Get paid for each post you publish.
19
star
88

wp-click2call

Wordpress Plugin for Click2Call
PHP
19
star
89

authy.net

.NET Library to access the Authy API
C#
19
star
90

starter-php

A starter app for PHP developers embarking on their first Twilio quest!
PHP
19
star
91

Breakout_Arduino_Library

C
18
star
92

howtos

Sample applications that cover common use cases in a variety of languages.
Python
18
star
93

wireless-postman-collection

This repository includes a group of Programmable Wireless HTTP requests for your convenience. You can learn more about Programmable Wireless HTTP request formats in the Programmable Wireless Documentation.
18
star
94

rtc-diagnostics-react-app

TypeScript
18
star
95

linkit-one-sensor-samples

Samples for the LinkIt ONE Starter Kit
C++
17
star
96

cerebro

Python
17
star
97

twilio-flex-token-validator

Flex JWE Token Validator
TypeScript
17
star
98

twilio-conversations-demo-android-kotlin

An application demonstrating use of Twilio Conversations on Android - this is a full working Kotlin application
Kotlin
16
star
99

twilio-verify-ios

Twilio Verify Push SDK helps you verify users by adding a low-friction, secure, cost-effective, "push verification" factor into your own apps. This project provides an SDK to implement Verify Push for your iOS app.
Swift
16
star
100

twilio-chat-console-webapp.js

Web Console example app for Twilio Programmable Chat with working push messages
JavaScript
15
star