twilio-ruby 4.7.0.edge → 4.7.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/CHANGES.md +28 -0
- data/lib/twilio-ruby.rb +2 -13
- data/lib/twilio-ruby/rest/list_resource.rb +3 -4
- data/lib/twilio-ruby/rest/next_gen_list_resource.rb +2 -3
- data/lib/twilio-ruby/rest/pricing_client.rb +1 -1
- data/lib/twilio-ruby/rest/trunking_client.rb +2 -2
- data/lib/twilio-ruby/rest/utils.rb +1 -12
- data/lib/twilio-ruby/util/access_token.rb +96 -0
- data/lib/twilio-ruby/version.rb +1 -1
- data/spec/rest/pricing_client_spec.rb +15 -0
- data/spec/util/access_token_spec.rb +84 -0
- metadata +23 -43
- data/lib/twilio-ruby/rest/conversations/completed.rb +0 -13
- data/lib/twilio-ruby/rest/conversations/conversations.rb +0 -23
- data/lib/twilio-ruby/rest/conversations/in_progress.rb +0 -13
- data/lib/twilio-ruby/rest/conversations/participants.rb +0 -8
- data/lib/twilio-ruby/rest/conversations_client.rb +0 -99
- data/lib/twilio-ruby/rest/ip-messaging/channels.rb +0 -21
- data/lib/twilio-ruby/rest/ip-messaging/credentials.rb +0 -22
- data/lib/twilio-ruby/rest/ip-messaging/members.rb +0 -8
- data/lib/twilio-ruby/rest/ip-messaging/messages.rb +0 -8
- data/lib/twilio-ruby/rest/ip-messaging/roles.rb +0 -8
- data/lib/twilio-ruby/rest/ip-messaging/services.rb +0 -22
- data/lib/twilio-ruby/rest/ip-messaging/users.rb +0 -8
- data/lib/twilio-ruby/rest/ip_messaging_client.rb +0 -100
- data/spec/conversations/conversations_spec.rb +0 -61
- data/spec/rest/conversations_client_spec.rb +0 -13
- data/spec/rest/ip-messaging/channel_spec.rb +0 -21
- data/spec/rest/ip-messaging/service_spec.rb +0 -30
- data/spec/rest/ip_messaging_client_spec.rb +0 -21
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: f7ec300417fba6ebe8e47a95a97c8511c174d47b
|
4
|
+
data.tar.gz: 3758c5d95113ca3013b4374569f05f59e030f4b8
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 99f35b8c1ad3c4b9beeaf5683be2bfb66b6c16ea42afd7b1b93c8c28653f0f97cd792ea5ff55209658f79a761c9306395b0b1499b1b61695965643369df2ef01
|
7
|
+
data.tar.gz: ced9b1a9fcb3755b5907587619b94664682d49c65909028778b95261440564a2fa9ea1324d05446d93b696d98e425768ec77edf410a0684a1cb2b3fba66c2fce
|
data/CHANGES.md
CHANGED
@@ -1,6 +1,34 @@
|
|
1
1
|
twilio-ruby changelog
|
2
2
|
=====================
|
3
3
|
|
4
|
+
Version 4.7.0
|
5
|
+
-------------
|
6
|
+
|
7
|
+
Release December 3, 2015
|
8
|
+
|
9
|
+
- Add access tokens
|
10
|
+
|
11
|
+
Version 4.6.2
|
12
|
+
-------------
|
13
|
+
|
14
|
+
Release November 19, 2015
|
15
|
+
|
16
|
+
- Fix Pricing Messages
|
17
|
+
|
18
|
+
Version 4.6.1
|
19
|
+
-------------
|
20
|
+
|
21
|
+
Release November 10, 2015
|
22
|
+
|
23
|
+
- Fix TrunkingClient references
|
24
|
+
|
25
|
+
Version 4.6.0
|
26
|
+
-------------
|
27
|
+
|
28
|
+
Release October 28, 2015
|
29
|
+
|
30
|
+
- Add /Keys endpoint
|
31
|
+
|
4
32
|
Version 4.4.0
|
5
33
|
-------------
|
6
34
|
|
data/lib/twilio-ruby.rb
CHANGED
@@ -10,6 +10,7 @@ require 'jwt'
|
|
10
10
|
|
11
11
|
require 'twilio-ruby/version' unless defined?(Twilio::VERSION)
|
12
12
|
require 'twilio-ruby/util'
|
13
|
+
require 'twilio-ruby/util/access_token'
|
13
14
|
require 'twilio-ruby/util/client_config'
|
14
15
|
require 'twilio-ruby/util/configuration'
|
15
16
|
require 'twilio-ruby/util/request_validator'
|
@@ -35,17 +36,6 @@ require 'twilio-ruby/rest/pricing/phone_numbers'
|
|
35
36
|
require 'twilio-ruby/rest/pricing/voice/numbers'
|
36
37
|
require 'twilio-ruby/rest/pricing/voice'
|
37
38
|
require 'twilio-ruby/rest/pricing/messaging'
|
38
|
-
require 'twilio-ruby/rest/conversations/in_progress'
|
39
|
-
require 'twilio-ruby/rest/conversations/completed'
|
40
|
-
require 'twilio-ruby/rest/conversations/conversations'
|
41
|
-
require 'twilio-ruby/rest/conversations/participants'
|
42
|
-
require 'twilio-ruby/rest/ip-messaging/services'
|
43
|
-
require 'twilio-ruby/rest/ip-messaging/channels'
|
44
|
-
require 'twilio-ruby/rest/ip-messaging/members'
|
45
|
-
require 'twilio-ruby/rest/ip-messaging/messages'
|
46
|
-
require 'twilio-ruby/rest/ip-messaging/roles'
|
47
|
-
require 'twilio-ruby/rest/ip-messaging/users'
|
48
|
-
require 'twilio-ruby/rest/ip-messaging/credentials'
|
49
39
|
require 'twilio-ruby/rest/sms'
|
50
40
|
require 'twilio-ruby/rest/sms/short_codes'
|
51
41
|
require 'twilio-ruby/rest/sms/messages'
|
@@ -107,12 +97,11 @@ require 'twilio-ruby/rest/notifications'
|
|
107
97
|
require 'twilio-ruby/rest/addresses'
|
108
98
|
require 'twilio-ruby/rest/addresses/dependent_phone_numbers'
|
109
99
|
require 'twilio-ruby/rest/client'
|
110
|
-
require 'twilio-ruby/rest/conversations_client'
|
111
100
|
require 'twilio-ruby/rest/task_router_client'
|
101
|
+
require 'twilio-ruby/rest/trunking_client'
|
112
102
|
require 'twilio-ruby/rest/lookups_client'
|
113
103
|
require 'twilio-ruby/rest/pricing_client'
|
114
104
|
require 'twilio-ruby/rest/monitor_client'
|
115
|
-
require 'twilio-ruby/rest/ip_messaging_client'
|
116
105
|
require 'rack/twilio_webhook_authentication'
|
117
106
|
|
118
107
|
module Twilio
|
@@ -10,7 +10,7 @@ module Twilio
|
|
10
10
|
'Countries' => 'Country',
|
11
11
|
'Feedback' => 'FeedbackInstance',
|
12
12
|
'IpAddresses' => 'IpAddress',
|
13
|
-
'Media' => 'MediaInstance'
|
13
|
+
'Media' => 'MediaInstance',
|
14
14
|
}
|
15
15
|
@path, @client = path, client
|
16
16
|
resource_name = self.class.name.split('::')[-1]
|
@@ -46,8 +46,7 @@ module Twilio
|
|
46
46
|
raise "Can't get a resource list without a REST Client" unless @client
|
47
47
|
response = @client.get @path, params, full_path
|
48
48
|
resources = response[@list_key]
|
49
|
-
path =
|
50
|
-
path = full_path ? path.split('.')[0] : path
|
49
|
+
path = full_path ? @path.split('.')[0] : @path
|
51
50
|
resource_list = resources.map do |resource|
|
52
51
|
@instance_class.new "#{path}/#{resource[@instance_id_key]}", @client,
|
53
52
|
resource
|
@@ -81,7 +80,7 @@ module Twilio
|
|
81
80
|
# attribute of the returned instance resource object, such as
|
82
81
|
# its #date_created or #voice_url attributes.
|
83
82
|
def get(sid)
|
84
|
-
@instance_class.new "#{@
|
83
|
+
@instance_class.new "#{@path}/#{sid}", @client
|
85
84
|
end
|
86
85
|
alias :find :get # for the ActiveRecord lovers
|
87
86
|
|
@@ -4,12 +4,11 @@ module Twilio
|
|
4
4
|
def list(params={}, full_path=false)
|
5
5
|
raise "Can't get a resource list without a REST Client" unless @client
|
6
6
|
response = @client.get @path, params, full_path
|
7
|
-
list_key = response['meta']['key']
|
7
|
+
list_key = response['meta']['key']
|
8
8
|
raise "Couldn't find a list key in response meta" unless list_key
|
9
9
|
resources = response[list_key]
|
10
|
-
path = @frozen_path ? @frozen_path : @path
|
11
10
|
resource_list = resources.map do |resource|
|
12
|
-
@instance_class.new "#{path}/#{resource[@instance_id_key]}", @client,
|
11
|
+
@instance_class.new "#{@path}/#{resource[@instance_id_key]}", @client,
|
13
12
|
resource
|
14
13
|
end
|
15
14
|
client, list_class = @client, self.class
|
@@ -89,9 +89,9 @@ module Twilio
|
|
89
89
|
protected
|
90
90
|
|
91
91
|
##
|
92
|
-
# Set up +
|
92
|
+
# Set up +trunks+ attribute.
|
93
93
|
def set_up_subresources # :doc:
|
94
|
-
@
|
94
|
+
@trunks = Twilio::REST::Trunking::Trunks.new "/#{API_VERSION}/Trunks", self
|
95
95
|
end
|
96
96
|
|
97
97
|
##
|
@@ -19,13 +19,6 @@ module Twilio
|
|
19
19
|
|
20
20
|
protected
|
21
21
|
|
22
|
-
# Freeze the base list path.
|
23
|
-
# Used on list resources so filters (such as /Local) do not affect the
|
24
|
-
# instance resource path.
|
25
|
-
def freeze_path
|
26
|
-
@frozen_path = @path
|
27
|
-
end
|
28
|
-
|
29
22
|
def resource(*resources)
|
30
23
|
custom_resource_names = { sms: 'SMS', sip: 'SIP' }
|
31
24
|
resources.each do |r|
|
@@ -38,11 +31,7 @@ module Twilio
|
|
38
31
|
Twilio::REST.const_get(@submodule)
|
39
32
|
end
|
40
33
|
resource_class = enclosing_module.const_get resource
|
41
|
-
|
42
|
-
instance_variable_set("@#{r}", resource_object)
|
43
|
-
if @frozen_path
|
44
|
-
resource_object.instance_variable_set(:@frozen_path, @frozen_path)
|
45
|
-
end
|
34
|
+
instance_variable_set("@#{r}", resource_class.new(path, @client))
|
46
35
|
end
|
47
36
|
self.class.instance_eval { attr_reader *resources }
|
48
37
|
end
|
@@ -0,0 +1,96 @@
|
|
1
|
+
module Twilio
|
2
|
+
module Util
|
3
|
+
class AccessToken
|
4
|
+
def initialize(account_sid, signing_key_id, secret, ttl=3600, identity=nil)
|
5
|
+
@account_sid = account_sid
|
6
|
+
@signing_key_sid = signing_key_id
|
7
|
+
@secret = secret
|
8
|
+
@ttl = ttl
|
9
|
+
@identity = identity
|
10
|
+
@grants = []
|
11
|
+
end
|
12
|
+
|
13
|
+
def add_grant(grant)
|
14
|
+
@grants.push(grant)
|
15
|
+
end
|
16
|
+
|
17
|
+
def to_jwt(algorithm='HS256')
|
18
|
+
now = Time.now.to_i - 1
|
19
|
+
headers = {
|
20
|
+
'cty' => 'twilio-fpa;v=1',
|
21
|
+
'typ' => 'JWT'
|
22
|
+
}
|
23
|
+
|
24
|
+
grants = {}
|
25
|
+
if @identity
|
26
|
+
grants['identity'] = @identity
|
27
|
+
end
|
28
|
+
|
29
|
+
@grants.each { |grant| grants[grant.key] = grant.payload }
|
30
|
+
|
31
|
+
payload = {
|
32
|
+
'jti' => "#{@signing_key_sid}-#{now}",
|
33
|
+
'iss' => @signing_key_sid,
|
34
|
+
'sub' => @account_sid,
|
35
|
+
'nbf' => now,
|
36
|
+
'exp' => now + @ttl,
|
37
|
+
'grants' => grants
|
38
|
+
}
|
39
|
+
JWT.encode payload, @secret, algorithm, headers
|
40
|
+
end
|
41
|
+
|
42
|
+
def to_s
|
43
|
+
to_jwt
|
44
|
+
end
|
45
|
+
|
46
|
+
class ConversationsGrant
|
47
|
+
attr_accessor :configuration_profile_sid
|
48
|
+
|
49
|
+
def key
|
50
|
+
'rtc'
|
51
|
+
end
|
52
|
+
|
53
|
+
def payload
|
54
|
+
payload = {}
|
55
|
+
if @configuration_profile_sid
|
56
|
+
payload['configuration_profile_sid'] = @configuration_profile_sid
|
57
|
+
end
|
58
|
+
|
59
|
+
payload
|
60
|
+
end
|
61
|
+
|
62
|
+
end
|
63
|
+
|
64
|
+
class IpMessagingGrant
|
65
|
+
attr_accessor :service_sid,
|
66
|
+
:endpoint_id,
|
67
|
+
:deployment_role_sid,
|
68
|
+
:push_credential_sid
|
69
|
+
|
70
|
+
def key
|
71
|
+
'ip_messaging'
|
72
|
+
end
|
73
|
+
|
74
|
+
def payload
|
75
|
+
payload = {}
|
76
|
+
if @service_sid
|
77
|
+
payload['service_sid'] = @service_sid
|
78
|
+
end
|
79
|
+
if @endpoint_id
|
80
|
+
payload['endpoint_id'] = @endpoint_id
|
81
|
+
end
|
82
|
+
if @role_sid
|
83
|
+
payload['deployment_role_sid'] = @deployment_role_sid
|
84
|
+
end
|
85
|
+
if @credential_sid
|
86
|
+
payload['push_credential_sid'] = @push_credential_sid
|
87
|
+
end
|
88
|
+
|
89
|
+
payload
|
90
|
+
end
|
91
|
+
|
92
|
+
end
|
93
|
+
|
94
|
+
end
|
95
|
+
end
|
96
|
+
end
|
data/lib/twilio-ruby/version.rb
CHANGED
@@ -42,4 +42,19 @@ describe Twilio::REST::PricingClient do
|
|
42
42
|
'/v1/PhoneNumbers/Countries'
|
43
43
|
)
|
44
44
|
end
|
45
|
+
|
46
|
+
it 'should set up a messaging resources object' do
|
47
|
+
expect(@client).to respond_to(:messaging)
|
48
|
+
expect(@client.messaging.instance_variable_get('@path')).to eq(
|
49
|
+
'/v1/Messaging'
|
50
|
+
)
|
51
|
+
end
|
52
|
+
|
53
|
+
it 'should set up the country list resource on messaging' do
|
54
|
+
messaging = @client.messaging
|
55
|
+
expect(messaging).to respond_to(:countries)
|
56
|
+
expect(messaging.countries.instance_variable_get('@path')).to eq(
|
57
|
+
'/v1/Messaging/Countries'
|
58
|
+
)
|
59
|
+
end
|
45
60
|
end
|
@@ -0,0 +1,84 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Twilio::Util::AccessToken do
|
4
|
+
|
5
|
+
it 'should generate a token for no grants' do
|
6
|
+
scat = Twilio::Util::AccessToken.new 'AC123', 'SK123','secret'
|
7
|
+
token = scat.to_s
|
8
|
+
expect(token).not_to be_nil
|
9
|
+
payload, header = JWT.decode token, 'secret'
|
10
|
+
|
11
|
+
expect(payload['iss']).to eq('SK123')
|
12
|
+
expect(payload['sub']).to eq('AC123')
|
13
|
+
expect(payload['nbf']).not_to be_nil
|
14
|
+
expect(payload['exp']).not_to be_nil
|
15
|
+
expect(payload['nbf'] + 3600).to eq(payload['exp'])
|
16
|
+
expect(payload['jti']).not_to be_nil
|
17
|
+
expect("#{payload['iss']}-#{payload['nbf']}").to eq(payload['jti'])
|
18
|
+
expect(payload['grants']).not_to be_nil
|
19
|
+
expect(payload['grants'].count).to eq(0)
|
20
|
+
end
|
21
|
+
|
22
|
+
it 'should be able to add conversation grant' do
|
23
|
+
scat = Twilio::Util::AccessToken.new 'AC123', 'SK123','secret'
|
24
|
+
scat.add_grant(Twilio::Util::AccessToken::ConversationsGrant.new)
|
25
|
+
|
26
|
+
token = scat.to_s
|
27
|
+
expect(token).not_to be_nil
|
28
|
+
payload, header = JWT.decode token, 'secret'
|
29
|
+
|
30
|
+
expect(payload['iss']).to eq('SK123')
|
31
|
+
expect(payload['sub']).to eq('AC123')
|
32
|
+
expect(payload['nbf']).not_to be_nil
|
33
|
+
expect(payload['exp']).not_to be_nil
|
34
|
+
expect(payload['nbf'] + 3600).to eq(payload['exp'])
|
35
|
+
expect(payload['jti']).not_to be_nil
|
36
|
+
expect("#{payload['iss']}-#{payload['nbf']}").to eq(payload['jti'])
|
37
|
+
expect(payload['grants']).not_to be_nil
|
38
|
+
expect(payload['grants'].count).to eq(1)
|
39
|
+
expect(payload['grants']['rtc']).not_to be_nil
|
40
|
+
end
|
41
|
+
|
42
|
+
it 'should be able to add endpoint grants' do
|
43
|
+
scat = Twilio::Util::AccessToken.new 'AC123', 'SK123','secret'
|
44
|
+
scat.add_grant(Twilio::Util::AccessToken::IpMessagingGrant.new)
|
45
|
+
|
46
|
+
token = scat.to_s
|
47
|
+
expect(token).not_to be_nil
|
48
|
+
payload, header = JWT.decode token, 'secret'
|
49
|
+
|
50
|
+
expect(payload['iss']).to eq('SK123')
|
51
|
+
expect(payload['sub']).to eq('AC123')
|
52
|
+
expect(payload['nbf']).not_to be_nil
|
53
|
+
expect(payload['exp']).not_to be_nil
|
54
|
+
expect(payload['nbf'] + 3600).to eq(payload['exp'])
|
55
|
+
expect(payload['jti']).not_to be_nil
|
56
|
+
expect("#{payload['iss']}-#{payload['nbf']}").to eq(payload['jti'])
|
57
|
+
expect(payload['grants']).not_to be_nil
|
58
|
+
expect(payload['grants'].count).to eq(1)
|
59
|
+
expect(payload['grants']['ip_messaging']).not_to be_nil
|
60
|
+
end
|
61
|
+
|
62
|
+
it 'should add rest grants' do
|
63
|
+
scat = Twilio::Util::AccessToken.new 'AC123', 'SK123','secret'
|
64
|
+
scat.add_grant(Twilio::Util::AccessToken::ConversationsGrant.new)
|
65
|
+
scat.add_grant(Twilio::Util::AccessToken::IpMessagingGrant.new)
|
66
|
+
|
67
|
+
token = scat.to_s
|
68
|
+
expect(token).not_to be_nil
|
69
|
+
payload, header = JWT.decode token, 'secret'
|
70
|
+
|
71
|
+
expect(payload['iss']).to eq('SK123')
|
72
|
+
expect(payload['sub']).to eq('AC123')
|
73
|
+
expect(payload['nbf']).not_to be_nil
|
74
|
+
expect(payload['exp']).not_to be_nil
|
75
|
+
expect(payload['nbf'] + 3600).to eq(payload['exp'])
|
76
|
+
expect(payload['jti']).not_to be_nil
|
77
|
+
expect("#{payload['iss']}-#{payload['nbf']}").to eq(payload['jti'])
|
78
|
+
expect(payload['grants']).not_to be_nil
|
79
|
+
expect(payload['grants'].count).to eq(2)
|
80
|
+
expect(payload['grants']['rtc']).not_to be_nil
|
81
|
+
expect(payload['grants']['ip_messaging']).not_to be_nil
|
82
|
+
end
|
83
|
+
|
84
|
+
end
|
metadata
CHANGED
@@ -1,69 +1,69 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: twilio-ruby
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 4.7.0
|
4
|
+
version: 4.7.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Andrew Benton
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2015-
|
11
|
+
date: 2015-12-04 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: multi_json
|
15
15
|
requirement: !ruby/object:Gem::Requirement
|
16
16
|
requirements:
|
17
|
-
- -
|
17
|
+
- - ">="
|
18
18
|
- !ruby/object:Gem::Version
|
19
19
|
version: 1.3.0
|
20
20
|
type: :runtime
|
21
21
|
prerelease: false
|
22
22
|
version_requirements: !ruby/object:Gem::Requirement
|
23
23
|
requirements:
|
24
|
-
- -
|
24
|
+
- - ">="
|
25
25
|
- !ruby/object:Gem::Version
|
26
26
|
version: 1.3.0
|
27
27
|
- !ruby/object:Gem::Dependency
|
28
28
|
name: builder
|
29
29
|
requirement: !ruby/object:Gem::Requirement
|
30
30
|
requirements:
|
31
|
-
- -
|
31
|
+
- - ">="
|
32
32
|
- !ruby/object:Gem::Version
|
33
33
|
version: 2.1.2
|
34
34
|
type: :runtime
|
35
35
|
prerelease: false
|
36
36
|
version_requirements: !ruby/object:Gem::Requirement
|
37
37
|
requirements:
|
38
|
-
- -
|
38
|
+
- - ">="
|
39
39
|
- !ruby/object:Gem::Version
|
40
40
|
version: 2.1.2
|
41
41
|
- !ruby/object:Gem::Dependency
|
42
42
|
name: jwt
|
43
43
|
requirement: !ruby/object:Gem::Requirement
|
44
44
|
requirements:
|
45
|
-
- - ~>
|
45
|
+
- - "~>"
|
46
46
|
- !ruby/object:Gem::Version
|
47
47
|
version: '1.0'
|
48
48
|
type: :runtime
|
49
49
|
prerelease: false
|
50
50
|
version_requirements: !ruby/object:Gem::Requirement
|
51
51
|
requirements:
|
52
|
-
- - ~>
|
52
|
+
- - "~>"
|
53
53
|
- !ruby/object:Gem::Version
|
54
54
|
version: '1.0'
|
55
55
|
- !ruby/object:Gem::Dependency
|
56
56
|
name: bundler
|
57
57
|
requirement: !ruby/object:Gem::Requirement
|
58
58
|
requirements:
|
59
|
-
- - ~>
|
59
|
+
- - "~>"
|
60
60
|
- !ruby/object:Gem::Version
|
61
61
|
version: '1.5'
|
62
62
|
type: :development
|
63
63
|
prerelease: false
|
64
64
|
version_requirements: !ruby/object:Gem::Requirement
|
65
65
|
requirements:
|
66
|
-
- - ~>
|
66
|
+
- - "~>"
|
67
67
|
- !ruby/object:Gem::Version
|
68
68
|
version: '1.5'
|
69
69
|
description: A simple library for communicating with the Twilio REST API, building
|
@@ -76,8 +76,8 @@ extra_rdoc_files:
|
|
76
76
|
- README.md
|
77
77
|
- LICENSE.md
|
78
78
|
files:
|
79
|
-
- .gitignore
|
80
|
-
- .travis.yml
|
79
|
+
- ".gitignore"
|
80
|
+
- ".travis.yml"
|
81
81
|
- AUTHORS.md
|
82
82
|
- CHANGES.md
|
83
83
|
- Gemfile
|
@@ -150,25 +150,12 @@ files:
|
|
150
150
|
- lib/twilio-ruby/rest/conferences.rb
|
151
151
|
- lib/twilio-ruby/rest/conferences/participants.rb
|
152
152
|
- lib/twilio-ruby/rest/connect_apps.rb
|
153
|
-
- lib/twilio-ruby/rest/conversations/completed.rb
|
154
|
-
- lib/twilio-ruby/rest/conversations/conversations.rb
|
155
|
-
- lib/twilio-ruby/rest/conversations/in_progress.rb
|
156
|
-
- lib/twilio-ruby/rest/conversations/participants.rb
|
157
|
-
- lib/twilio-ruby/rest/conversations_client.rb
|
158
153
|
- lib/twilio-ruby/rest/errors.rb
|
159
154
|
- lib/twilio-ruby/rest/incoming_phone_numbers.rb
|
160
155
|
- lib/twilio-ruby/rest/incoming_phone_numbers/local.rb
|
161
156
|
- lib/twilio-ruby/rest/incoming_phone_numbers/mobile.rb
|
162
157
|
- lib/twilio-ruby/rest/incoming_phone_numbers/toll_free.rb
|
163
158
|
- lib/twilio-ruby/rest/instance_resource.rb
|
164
|
-
- lib/twilio-ruby/rest/ip-messaging/channels.rb
|
165
|
-
- lib/twilio-ruby/rest/ip-messaging/credentials.rb
|
166
|
-
- lib/twilio-ruby/rest/ip-messaging/members.rb
|
167
|
-
- lib/twilio-ruby/rest/ip-messaging/messages.rb
|
168
|
-
- lib/twilio-ruby/rest/ip-messaging/roles.rb
|
169
|
-
- lib/twilio-ruby/rest/ip-messaging/services.rb
|
170
|
-
- lib/twilio-ruby/rest/ip-messaging/users.rb
|
171
|
-
- lib/twilio-ruby/rest/ip_messaging_client.rb
|
172
159
|
- lib/twilio-ruby/rest/keys.rb
|
173
160
|
- lib/twilio-ruby/rest/list_resource.rb
|
174
161
|
- lib/twilio-ruby/rest/lookups/phone_numbers.rb
|
@@ -234,12 +221,12 @@ files:
|
|
234
221
|
- lib/twilio-ruby/task_router/workflow_builder.rb
|
235
222
|
- lib/twilio-ruby/twiml/response.rb
|
236
223
|
- lib/twilio-ruby/util.rb
|
224
|
+
- lib/twilio-ruby/util/access_token.rb
|
237
225
|
- lib/twilio-ruby/util/capability.rb
|
238
226
|
- lib/twilio-ruby/util/client_config.rb
|
239
227
|
- lib/twilio-ruby/util/configuration.rb
|
240
228
|
- lib/twilio-ruby/util/request_validator.rb
|
241
229
|
- lib/twilio-ruby/version.rb
|
242
|
-
- spec/conversations/conversations_spec.rb
|
243
230
|
- spec/rack/twilio_webhook_authentication_spec.rb
|
244
231
|
- spec/rest/account_spec.rb
|
245
232
|
- spec/rest/address_spec.rb
|
@@ -248,11 +235,7 @@ files:
|
|
248
235
|
- spec/rest/call_spec.rb
|
249
236
|
- spec/rest/client_spec.rb
|
250
237
|
- spec/rest/conference_spec.rb
|
251
|
-
- spec/rest/conversations_client_spec.rb
|
252
238
|
- spec/rest/instance_resource_spec.rb
|
253
|
-
- spec/rest/ip-messaging/channel_spec.rb
|
254
|
-
- spec/rest/ip-messaging/service_spec.rb
|
255
|
-
- spec/rest/ip_messaging_client_spec.rb
|
256
239
|
- spec/rest/key_spec.rb
|
257
240
|
- spec/rest/lookups/phone_number_spec.rb
|
258
241
|
- spec/rest/message_spec.rb
|
@@ -277,6 +260,7 @@ files:
|
|
277
260
|
- spec/task_router_worker_spec.rb
|
278
261
|
- spec/task_router_workspace_spec.rb
|
279
262
|
- spec/twilio_spec.rb
|
263
|
+
- spec/util/access_token_spec.rb
|
280
264
|
- spec/util/capability_spec.rb
|
281
265
|
- spec/util/client_config_spec.rb
|
282
266
|
- spec/util/configuration_spec.rb
|
@@ -289,33 +273,32 @@ licenses:
|
|
289
273
|
metadata: {}
|
290
274
|
post_install_message:
|
291
275
|
rdoc_options:
|
292
|
-
- --line-numbers
|
293
|
-
- --inline-source
|
294
|
-
- --title
|
276
|
+
- "--line-numbers"
|
277
|
+
- "--inline-source"
|
278
|
+
- "--title"
|
295
279
|
- twilio-ruby
|
296
|
-
- --main
|
280
|
+
- "--main"
|
297
281
|
- README.md
|
298
282
|
require_paths:
|
299
283
|
- lib
|
300
284
|
required_ruby_version: !ruby/object:Gem::Requirement
|
301
285
|
requirements:
|
302
|
-
- -
|
286
|
+
- - ">="
|
303
287
|
- !ruby/object:Gem::Version
|
304
288
|
version: 1.9.3
|
305
289
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
306
290
|
requirements:
|
307
|
-
- -
|
291
|
+
- - ">="
|
308
292
|
- !ruby/object:Gem::Version
|
309
|
-
version:
|
293
|
+
version: '0'
|
310
294
|
requirements: []
|
311
295
|
rubyforge_project:
|
312
|
-
rubygems_version: 2.
|
296
|
+
rubygems_version: 2.4.8
|
313
297
|
signing_key:
|
314
298
|
specification_version: 4
|
315
299
|
summary: A simple library for communicating with the Twilio REST API, building TwiML,
|
316
300
|
and generating Twilio Client Capability Tokens
|
317
301
|
test_files:
|
318
|
-
- spec/conversations/conversations_spec.rb
|
319
302
|
- spec/rack/twilio_webhook_authentication_spec.rb
|
320
303
|
- spec/rest/account_spec.rb
|
321
304
|
- spec/rest/address_spec.rb
|
@@ -324,11 +307,7 @@ test_files:
|
|
324
307
|
- spec/rest/call_spec.rb
|
325
308
|
- spec/rest/client_spec.rb
|
326
309
|
- spec/rest/conference_spec.rb
|
327
|
-
- spec/rest/conversations_client_spec.rb
|
328
310
|
- spec/rest/instance_resource_spec.rb
|
329
|
-
- spec/rest/ip-messaging/channel_spec.rb
|
330
|
-
- spec/rest/ip-messaging/service_spec.rb
|
331
|
-
- spec/rest/ip_messaging_client_spec.rb
|
332
311
|
- spec/rest/key_spec.rb
|
333
312
|
- spec/rest/lookups/phone_number_spec.rb
|
334
313
|
- spec/rest/message_spec.rb
|
@@ -353,6 +332,7 @@ test_files:
|
|
353
332
|
- spec/task_router_worker_spec.rb
|
354
333
|
- spec/task_router_workspace_spec.rb
|
355
334
|
- spec/twilio_spec.rb
|
335
|
+
- spec/util/access_token_spec.rb
|
356
336
|
- spec/util/capability_spec.rb
|
357
337
|
- spec/util/client_config_spec.rb
|
358
338
|
- spec/util/configuration_spec.rb
|
@@ -1,13 +0,0 @@
|
|
1
|
-
module Twilio
|
2
|
-
module REST
|
3
|
-
module Conversations
|
4
|
-
class Completed < NextGenListResource
|
5
|
-
def initialize(path, client)
|
6
|
-
@path, @client = path, client
|
7
|
-
@instance_class = Twilio::REST::Conversations::Conversation
|
8
|
-
@instance_id_key = 'sid'
|
9
|
-
end
|
10
|
-
end
|
11
|
-
end
|
12
|
-
end
|
13
|
-
end
|
@@ -1,23 +0,0 @@
|
|
1
|
-
module Twilio
|
2
|
-
module REST
|
3
|
-
module Conversations
|
4
|
-
class Conversations < NextGenListResource
|
5
|
-
def initialize(path, client)
|
6
|
-
@path, @client = path, client
|
7
|
-
@submodule = :Conversations
|
8
|
-
freeze_path
|
9
|
-
resource :in_progress,
|
10
|
-
:completed
|
11
|
-
end
|
12
|
-
end
|
13
|
-
|
14
|
-
class Conversation < InstanceResource
|
15
|
-
def initialize(path, client, params={})
|
16
|
-
super
|
17
|
-
@submodule = :Conversations
|
18
|
-
resource :participants
|
19
|
-
end
|
20
|
-
end
|
21
|
-
end
|
22
|
-
end
|
23
|
-
end
|
@@ -1,13 +0,0 @@
|
|
1
|
-
module Twilio
|
2
|
-
module REST
|
3
|
-
module Conversations
|
4
|
-
class InProgress < NextGenListResource
|
5
|
-
def initialize(path, client)
|
6
|
-
@path, @client = path, client
|
7
|
-
@instance_class = Twilio::REST::Conversations::Conversation
|
8
|
-
@instance_id_key = 'sid'
|
9
|
-
end
|
10
|
-
end
|
11
|
-
end
|
12
|
-
end
|
13
|
-
end
|
@@ -1,99 +0,0 @@
|
|
1
|
-
require 'twilio-ruby/rest/base_client'
|
2
|
-
module Twilio
|
3
|
-
module REST
|
4
|
-
class ConversationsClient < BaseClient
|
5
|
-
API_VERSION = 'v1'
|
6
|
-
|
7
|
-
attr_reader :conversations
|
8
|
-
|
9
|
-
host 'conversations.twilio.com'
|
10
|
-
|
11
|
-
##
|
12
|
-
# Instantiate a new HTTP Conversations client to talk to Twilio. The parameters
|
13
|
-
# +account_sid+, +auth_token+ are required, unless you have configured
|
14
|
-
# them already using the block configure syntax, and used to generate the
|
15
|
-
# HTTP basic auth header in each request. The +options+ parameter is a
|
16
|
-
# hash of connection configuration options. the following keys are
|
17
|
-
# supported:
|
18
|
-
#
|
19
|
-
# === <tt>host: 'conversations.twilio.com'</tt>
|
20
|
-
#
|
21
|
-
# The domain to which you'd like the client to make HTTP requests. Useful
|
22
|
-
# for testing. Defaults to 'conversations.twilio.com'.
|
23
|
-
#
|
24
|
-
# === <tt>port: 443</tt>
|
25
|
-
#
|
26
|
-
# The port on which to connect to the above domain. Defaults to 443 and
|
27
|
-
# should be left that way except in testing environments.
|
28
|
-
#
|
29
|
-
# === <tt>use_ssl: true</tt>
|
30
|
-
#
|
31
|
-
# Declare whether ssl should be used for connections to the above domain.
|
32
|
-
# Defaults to true and should be left alone except when testing.
|
33
|
-
#
|
34
|
-
# === <tt>ssl_verify_peer: true</tt>
|
35
|
-
#
|
36
|
-
# Declare whether to verify the host's ssl cert when setting up the
|
37
|
-
# connection to the above domain. Defaults to true, but can be turned off
|
38
|
-
# to avoid ssl certificate verification failures in environments without
|
39
|
-
# the necessary ca certificates.
|
40
|
-
#
|
41
|
-
# === <tt>ssl_ca_file: '/path/to/ca/file'</tt>
|
42
|
-
#
|
43
|
-
# Specify the path to the certificate authority bundle you'd like to use
|
44
|
-
# to verify Twilio's SSL certificate on each request. If not specified, a
|
45
|
-
# certificate bundle extraced from Firefox is packaged with the gem and
|
46
|
-
# used by default.
|
47
|
-
#
|
48
|
-
# === <tt>timeout: 30</tt>
|
49
|
-
#
|
50
|
-
# Set the time in seconds to wait before timing out the HTTP request.
|
51
|
-
# Defaults to 30 seconds. If you aren't fetching giant pages of call or
|
52
|
-
# SMS logs you can safely decrease this to something like 3 seconds or
|
53
|
-
# lower. In paricular if you are sending SMS you can set this to 1 second
|
54
|
-
# or less and swallow the exception if you don't care about the response.
|
55
|
-
#
|
56
|
-
# === <tt>proxy_addr: 'proxy.host.domain'</tt>
|
57
|
-
#
|
58
|
-
# The domain of a proxy through which you'd like the client to make HTTP
|
59
|
-
# requests. Defaults to nil.
|
60
|
-
#
|
61
|
-
# === <tt>proxy_port: 3128</tt>
|
62
|
-
#
|
63
|
-
# The port on which to connect to the above proxy. Defaults to nil.
|
64
|
-
#
|
65
|
-
# === <tt>proxy_user: 'username'</tt>
|
66
|
-
#
|
67
|
-
# The user name to use for authentication with the proxy. Defaults to nil.
|
68
|
-
#
|
69
|
-
# === <tt>proxy_pass: 'password'</tt>
|
70
|
-
#
|
71
|
-
# The password to use for authentication with the proxy. Defaults to nil.
|
72
|
-
#
|
73
|
-
# === <tt>retry_limit: 1</tt>
|
74
|
-
#
|
75
|
-
# The number of times to retry a request that has failed before throwing
|
76
|
-
# an exception. Defaults to one.
|
77
|
-
def inspect # :nodoc:
|
78
|
-
"<Twilio::REST::ConversationsClient @account_sid=#{@account_sid}>"
|
79
|
-
end
|
80
|
-
|
81
|
-
protected
|
82
|
-
|
83
|
-
##
|
84
|
-
# Create subresource properties
|
85
|
-
def set_up_subresources # :doc:
|
86
|
-
@conversations = Twilio::REST::Conversations::Conversations.new "/#{API_VERSION}/Conversations", self
|
87
|
-
end
|
88
|
-
|
89
|
-
##
|
90
|
-
# Builds up full request path
|
91
|
-
def build_full_path(path, params, method)
|
92
|
-
path = path.dup
|
93
|
-
path << "?#{url_encode(params)}" if method == :get && !params.empty?
|
94
|
-
path
|
95
|
-
end
|
96
|
-
|
97
|
-
end
|
98
|
-
end
|
99
|
-
end
|
@@ -1,21 +0,0 @@
|
|
1
|
-
module Twilio
|
2
|
-
module REST
|
3
|
-
module IpMessaging
|
4
|
-
class Channels < NextGenListResource
|
5
|
-
def initialize(path, client)
|
6
|
-
@path, client = path, client
|
7
|
-
@submodule = :IpMessaging
|
8
|
-
end
|
9
|
-
end
|
10
|
-
class Channel < InstanceResource
|
11
|
-
def initialize(path, client, params={})
|
12
|
-
super
|
13
|
-
@submodule = :IpMessaging
|
14
|
-
|
15
|
-
resource :messages,
|
16
|
-
:members
|
17
|
-
end
|
18
|
-
end
|
19
|
-
end
|
20
|
-
end
|
21
|
-
end
|
@@ -1,22 +0,0 @@
|
|
1
|
-
module Twilio
|
2
|
-
module REST
|
3
|
-
module IpMessaging
|
4
|
-
class Credentials < NextGenListResource
|
5
|
-
def initialize(path, client)
|
6
|
-
@path, @client = path, client
|
7
|
-
@submodule = :IpMessaging
|
8
|
-
end
|
9
|
-
end
|
10
|
-
|
11
|
-
class Credential < InstanceResource
|
12
|
-
def initialize(path, client, params={})
|
13
|
-
super
|
14
|
-
@submodule = :IpMessaging
|
15
|
-
resource :channels,
|
16
|
-
:users,
|
17
|
-
:roles
|
18
|
-
end
|
19
|
-
end
|
20
|
-
end
|
21
|
-
end
|
22
|
-
end
|
@@ -1,22 +0,0 @@
|
|
1
|
-
module Twilio
|
2
|
-
module REST
|
3
|
-
module IpMessaging
|
4
|
-
class Services < NextGenListResource
|
5
|
-
def initialize(path, client)
|
6
|
-
@path, @client = path, client
|
7
|
-
@submodule = :IpMessaging
|
8
|
-
end
|
9
|
-
end
|
10
|
-
|
11
|
-
class Service < InstanceResource
|
12
|
-
def initialize(path, client, params={})
|
13
|
-
super
|
14
|
-
@submodule = :IpMessaging
|
15
|
-
resource :channels,
|
16
|
-
:users,
|
17
|
-
:roles
|
18
|
-
end
|
19
|
-
end
|
20
|
-
end
|
21
|
-
end
|
22
|
-
end
|
@@ -1,100 +0,0 @@
|
|
1
|
-
require 'twilio-ruby/rest/base_client'
|
2
|
-
module Twilio
|
3
|
-
module REST
|
4
|
-
class IpMessagingClient < BaseClient
|
5
|
-
API_VERSION = 'v1'
|
6
|
-
|
7
|
-
attr_reader :services, :credentials
|
8
|
-
|
9
|
-
host 'ip-messaging.twilio.com'
|
10
|
-
|
11
|
-
##
|
12
|
-
# Instantiate a new HTTP Conversations client to talk to Twilio. The parameters
|
13
|
-
# +account_sid+, +auth_token+ are required, unless you have configured
|
14
|
-
# them already using the block configure syntax, and used to generate the
|
15
|
-
# HTTP basic auth header in each request. The +options+ parameter is a
|
16
|
-
# hash of connection configuration options. the following keys are
|
17
|
-
# supported:
|
18
|
-
#
|
19
|
-
# === <tt>host: 'ip-messaging.twilio.com'</tt>
|
20
|
-
#
|
21
|
-
# The domain to which you'd like the client to make HTTP requests. Useful
|
22
|
-
# for testing. Defaults to 'ip-messaging.twilio.com'.
|
23
|
-
#
|
24
|
-
# === <tt>port: 443</tt>
|
25
|
-
#
|
26
|
-
# The port on which to connect to the above domain. Defaults to 443 and
|
27
|
-
# should be left that way except in testing environments.
|
28
|
-
#
|
29
|
-
# === <tt>use_ssl: true</tt>
|
30
|
-
#
|
31
|
-
# Declare whether ssl should be used for connections to the above domain.
|
32
|
-
# Defaults to true and should be left alone except when testing.
|
33
|
-
#
|
34
|
-
# === <tt>ssl_verify_peer: true</tt>
|
35
|
-
#
|
36
|
-
# Declare whether to verify the host's ssl cert when setting up the
|
37
|
-
# connection to the above domain. Defaults to true, but can be turned off
|
38
|
-
# to avoid ssl certificate verification failures in environments without
|
39
|
-
# the necessary ca certificates.
|
40
|
-
#
|
41
|
-
# === <tt>ssl_ca_file: '/path/to/ca/file'</tt>
|
42
|
-
#
|
43
|
-
# Specify the path to the certificate authority bundle you'd like to use
|
44
|
-
# to verify Twilio's SSL certificate on each request. If not specified, a
|
45
|
-
# certificate bundle extraced from Firefox is packaged with the gem and
|
46
|
-
# used by default.
|
47
|
-
#
|
48
|
-
# === <tt>timeout: 30</tt>
|
49
|
-
#
|
50
|
-
# Set the time in seconds to wait before timing out the HTTP request.
|
51
|
-
# Defaults to 30 seconds. If you aren't fetching giant pages of call or
|
52
|
-
# SMS logs you can safely decrease this to something like 3 seconds or
|
53
|
-
# lower. In paricular if you are sending SMS you can set this to 1 second
|
54
|
-
# or less and swallow the exception if you don't care about the response.
|
55
|
-
#
|
56
|
-
# === <tt>proxy_addr: 'proxy.host.domain'</tt>
|
57
|
-
#
|
58
|
-
# The domain of a proxy through which you'd like the client to make HTTP
|
59
|
-
# requests. Defaults to nil.
|
60
|
-
#
|
61
|
-
# === <tt>proxy_port: 3128</tt>
|
62
|
-
#
|
63
|
-
# The port on which to connect to the above proxy. Defaults to nil.
|
64
|
-
#
|
65
|
-
# === <tt>proxy_user: 'username'</tt>
|
66
|
-
#
|
67
|
-
# The user name to use for authentication with the proxy. Defaults to nil.
|
68
|
-
#
|
69
|
-
# === <tt>proxy_pass: 'password'</tt>
|
70
|
-
#
|
71
|
-
# The password to use for authentication with the proxy. Defaults to nil.
|
72
|
-
#
|
73
|
-
# === <tt>retry_limit: 1</tt>
|
74
|
-
#
|
75
|
-
# The number of times to retry a request that has failed before throwing
|
76
|
-
# an exception. Defaults to one.
|
77
|
-
def inspect # :nodoc:
|
78
|
-
"<Twilio::REST::IpMessagingClient @account_sid=#{@account_sid}>"
|
79
|
-
end
|
80
|
-
|
81
|
-
protected
|
82
|
-
|
83
|
-
##
|
84
|
-
# Create subresource properties
|
85
|
-
def set_up_subresources # :doc:
|
86
|
-
@services = Twilio::REST::IpMessaging::Services.new "/#{API_VERSION}/Services", self
|
87
|
-
@credentials = Twilio::REST::IpMessaging::Credentials.new "/#{API_VERSION}/Credentials", self
|
88
|
-
end
|
89
|
-
|
90
|
-
##
|
91
|
-
# Builds up full request path
|
92
|
-
def build_full_path(path, params, method)
|
93
|
-
path = path.dup
|
94
|
-
path << "?#{url_encode(params)}" if method == :get && !params.empty?
|
95
|
-
path
|
96
|
-
end
|
97
|
-
|
98
|
-
end
|
99
|
-
end
|
100
|
-
end
|
@@ -1,61 +0,0 @@
|
|
1
|
-
require 'spec_helper'
|
2
|
-
|
3
|
-
describe Twilio::REST::Conversations::Conversations do
|
4
|
-
|
5
|
-
it 'creates an in_progress property' do
|
6
|
-
client = Twilio::REST::ConversationsClient.new 'otherSid', 'otherToken'
|
7
|
-
conversations = Twilio::REST::Conversations::Conversations.new '/v1/Conversations', client
|
8
|
-
expect(conversations).to respond_to(:in_progress)
|
9
|
-
end
|
10
|
-
|
11
|
-
it 'creates a completed property' do
|
12
|
-
client = Twilio::REST::ConversationsClient.new 'otherSid', 'otherToken'
|
13
|
-
conversations = Twilio::REST::Conversations::Conversations.new '/v1/Conversations', client
|
14
|
-
expect(conversations).to respond_to(:completed)
|
15
|
-
end
|
16
|
-
|
17
|
-
end
|
18
|
-
|
19
|
-
describe Twilio::REST::Conversations::InProgress do
|
20
|
-
it 'gets constructed by conversations' do
|
21
|
-
client = Twilio::REST::ConversationsClient.new 'otherSid', 'otherToken'
|
22
|
-
conversations = Twilio::REST::Conversations::Conversations.new '/v1/Conversations', client
|
23
|
-
expect(conversations.in_progress.instance_variable_get('@path')).to eq('/v1/Conversations/InProgress')
|
24
|
-
end
|
25
|
-
it 'uses Conversation as its instance class' do
|
26
|
-
client = Twilio::REST::ConversationsClient.new 'otherSid', 'otherToken'
|
27
|
-
conversations = Twilio::REST::Conversations::Conversations.new '/v1/Conversations', client
|
28
|
-
expect(conversations.in_progress.instance_variable_get('@instance_class')).to eq(Twilio::REST::Conversations::Conversation)
|
29
|
-
end
|
30
|
-
end
|
31
|
-
|
32
|
-
describe Twilio::REST::Conversations::Completed do
|
33
|
-
it 'gets constructed by conversations' do
|
34
|
-
client = Twilio::REST::ConversationsClient.new 'otherSid', 'otherToken'
|
35
|
-
conversations = Twilio::REST::Conversations::Conversations.new '/v1/Conversations', client
|
36
|
-
expect(conversations.completed.instance_variable_get('@path')).to eq('/v1/Conversations/Completed')
|
37
|
-
end
|
38
|
-
it 'uses Conversation as its instance class' do
|
39
|
-
client = Twilio::REST::ConversationsClient.new 'otherSid', 'otherToken'
|
40
|
-
conversations = Twilio::REST::Conversations::Conversations.new '/v1/Conversations', client
|
41
|
-
expect(conversations.completed.instance_variable_get('@instance_class')).to eq(Twilio::REST::Conversations::Conversation)
|
42
|
-
end
|
43
|
-
end
|
44
|
-
|
45
|
-
describe Twilio::REST::Conversations::Conversation do
|
46
|
-
it 'has correct path when fetched from /InProgress' do
|
47
|
-
client = Twilio::REST::ConversationsClient.new 'otherSid', 'otherToken'
|
48
|
-
conversation = client.conversations.in_progress.get('CA123')
|
49
|
-
expect(conversation.instance_variable_get('@path')).to eq('/v1/Conversations/CA123')
|
50
|
-
end
|
51
|
-
it 'has correct path when fetched from /Completed' do
|
52
|
-
client = Twilio::REST::ConversationsClient.new 'otherSid', 'otherToken'
|
53
|
-
conversation = client.conversations.completed.get('CA123')
|
54
|
-
expect(conversation.instance_variable_get('@path')).to eq('/v1/Conversations/CA123')
|
55
|
-
end
|
56
|
-
it 'sets up participants subresource' do
|
57
|
-
client = Twilio::REST::ConversationsClient.new 'otherSid', 'otherToken'
|
58
|
-
conversation = Twilio::REST::Conversations::Conversation.new '/v1/Conversations/CA123', client
|
59
|
-
expect(conversation).to respond_to(:participants)
|
60
|
-
end
|
61
|
-
end
|
@@ -1,13 +0,0 @@
|
|
1
|
-
require 'spec_helper'
|
2
|
-
|
3
|
-
describe Twilio::REST::ConversationsClient do
|
4
|
-
before do
|
5
|
-
@client = Twilio::REST::ConversationsClient.new('AC123', 'foobar')
|
6
|
-
end
|
7
|
-
|
8
|
-
it 'should set up an conversations resources object' do
|
9
|
-
expect(@client).to respond_to(:conversations)
|
10
|
-
expect(@client.conversations.instance_variable_get('@path')).to eq('/v1/Conversations')
|
11
|
-
end
|
12
|
-
|
13
|
-
end
|
@@ -1,21 +0,0 @@
|
|
1
|
-
require 'spec_helper'
|
2
|
-
|
3
|
-
describe Twilio::REST::IpMessaging::Channels do
|
4
|
-
it 'sets up a members resources object' do
|
5
|
-
client = Twilio::REST::IpMessagingClient.new 'otherSid', 'otherToken'
|
6
|
-
service = Twilio::REST::IpMessaging::Channel.new '/v1/Services/1/Channels/1', client
|
7
|
-
expect(service).to respond_to(:members)
|
8
|
-
expect(service.members.instance_variable_get('@path')).to eq(
|
9
|
-
'/v1/Services/1/Channels/1/Members'
|
10
|
-
)
|
11
|
-
end
|
12
|
-
|
13
|
-
it 'sets up a messages resources object' do
|
14
|
-
client = Twilio::REST::IpMessagingClient.new 'otherSid', 'otherToken'
|
15
|
-
service = Twilio::REST::IpMessaging::Channel.new '/v1/Services/1/Channels/1', client
|
16
|
-
expect(service).to respond_to(:messages)
|
17
|
-
expect(service.messages.instance_variable_get('@path')).to eq(
|
18
|
-
'/v1/Services/1/Channels/1/Messages'
|
19
|
-
)
|
20
|
-
end
|
21
|
-
end
|
@@ -1,30 +0,0 @@
|
|
1
|
-
require 'spec_helper'
|
2
|
-
|
3
|
-
describe Twilio::REST::IpMessaging::Services do
|
4
|
-
it 'sets up a channels resources object' do
|
5
|
-
client = Twilio::REST::IpMessagingClient.new 'otherSid', 'otherToken'
|
6
|
-
service = Twilio::REST::IpMessaging::Service.new '/v1/Services', client
|
7
|
-
expect(service).to respond_to(:channels)
|
8
|
-
expect(service.channels.instance_variable_get('@path')).to eq(
|
9
|
-
'/v1/Services/Channels'
|
10
|
-
)
|
11
|
-
end
|
12
|
-
|
13
|
-
it 'sets up a roles resources object' do
|
14
|
-
client = Twilio::REST::IpMessagingClient.new 'otherSid', 'otherToken'
|
15
|
-
service = Twilio::REST::IpMessaging::Service.new '/v1/Services', client
|
16
|
-
expect(service).to respond_to(:roles)
|
17
|
-
expect(service.roles.instance_variable_get('@path')).to eq(
|
18
|
-
'/v1/Services/Roles'
|
19
|
-
)
|
20
|
-
end
|
21
|
-
|
22
|
-
it 'sets up a users resources object' do
|
23
|
-
client = Twilio::REST::IpMessagingClient.new 'otherSid', 'otherToken'
|
24
|
-
service = Twilio::REST::IpMessaging::Service.new '/v1/Services', client
|
25
|
-
expect(service).to respond_to(:users)
|
26
|
-
expect(service.users.instance_variable_get('@path')).to eq(
|
27
|
-
'/v1/Services/Users'
|
28
|
-
)
|
29
|
-
end
|
30
|
-
end
|
@@ -1,21 +0,0 @@
|
|
1
|
-
require 'spec_helper'
|
2
|
-
|
3
|
-
describe Twilio::REST::IpMessagingClient do
|
4
|
-
before do
|
5
|
-
@client = Twilio::REST::IpMessagingClient.new('AC123', 'foobar')
|
6
|
-
end
|
7
|
-
|
8
|
-
it 'should set up a services resources object' do
|
9
|
-
expect(@client).to respond_to(:services)
|
10
|
-
expect(@client.services.instance_variable_get('@path')).to eq(
|
11
|
-
'/v1/Services'
|
12
|
-
)
|
13
|
-
end
|
14
|
-
|
15
|
-
it 'should set up a credentials resources object' do
|
16
|
-
expect(@client).to respond_to(:credentials)
|
17
|
-
expect(@client.credentials.instance_variable_get('@path')).to eq(
|
18
|
-
'/v1/Credentials'
|
19
|
-
)
|
20
|
-
end
|
21
|
-
end
|