messagebird-rest 1.4.0 → 3.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (44) hide show
  1. checksums.yaml +5 -5
  2. data/README.md +56 -8
  3. data/lib/messagebird.rb +11 -6
  4. data/lib/messagebird/balance.rb +2 -0
  5. data/lib/messagebird/base.rb +12 -7
  6. data/lib/messagebird/call_flow.rb +22 -0
  7. data/lib/messagebird/call_flow/step.rb +9 -0
  8. data/lib/messagebird/callflow.rb +60 -0
  9. data/lib/messagebird/client.rb +342 -52
  10. data/lib/messagebird/contact.rb +11 -9
  11. data/lib/messagebird/contact_reference.rb +3 -1
  12. data/lib/messagebird/conversation.rb +44 -0
  13. data/lib/messagebird/conversation_channel.rb +18 -0
  14. data/lib/messagebird/conversation_client.rb +22 -0
  15. data/lib/messagebird/conversation_message.rb +10 -0
  16. data/lib/messagebird/conversation_webhook.rb +9 -0
  17. data/lib/messagebird/custom_details.rb +2 -0
  18. data/lib/messagebird/error.rb +2 -0
  19. data/lib/messagebird/group.rb +9 -7
  20. data/lib/messagebird/group_reference.rb +3 -1
  21. data/lib/messagebird/hlr.rb +8 -6
  22. data/lib/messagebird/http_client.rb +46 -29
  23. data/lib/messagebird/list.rb +5 -4
  24. data/lib/messagebird/lookup.rb +7 -5
  25. data/lib/messagebird/message.rb +9 -7
  26. data/lib/messagebird/message_reference.rb +3 -1
  27. data/lib/messagebird/number.rb +18 -0
  28. data/lib/messagebird/number_client.rb +22 -0
  29. data/lib/messagebird/recipient.rb +6 -3
  30. data/lib/messagebird/signed_request.rb +50 -0
  31. data/lib/messagebird/verify.rb +14 -7
  32. data/lib/messagebird/verify_email_message.rb +9 -0
  33. data/lib/messagebird/version.rb +7 -0
  34. data/lib/messagebird/voice/base.rb +16 -0
  35. data/lib/messagebird/voice/call.rb +22 -0
  36. data/lib/messagebird/voice/call_leg.rb +11 -0
  37. data/lib/messagebird/voice/call_leg_recording.rb +20 -0
  38. data/lib/messagebird/voice/client.rb +22 -0
  39. data/lib/messagebird/voice/list.rb +24 -0
  40. data/lib/messagebird/voice/transcription.rb +15 -0
  41. data/lib/messagebird/voice/webhook.rb +11 -0
  42. data/lib/messagebird/voice_client.rb +25 -0
  43. data/lib/messagebird/voicemessage.rb +8 -7
  44. metadata +59 -10
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  require 'messagebird/base'
2
4
  require 'messagebird/custom_details'
3
5
  require 'messagebird/group_reference'
@@ -5,11 +7,11 @@ require 'messagebird/message_reference'
5
7
 
6
8
  module MessageBird
7
9
  class Contact < MessageBird::Base
8
- attr_accessor :id, :href, :msisdn, :firstName, :lastName, :customDetails,
9
- :groups, :messages, :createdDatetime, :updatedDatetime
10
+ attr_accessor :id, :href, :msisdn, :first_name, :last_name
11
+ attr_reader :custom_details, :groups, :messages, :created_datetime, :updated_datetime
10
12
 
11
- def customDetails=(value)
12
- @customDetails = MessageBird::CustomDetails.new(value)
13
+ def custom_details=(value)
14
+ @custom_details = MessageBird::CustomDetails.new(value)
13
15
  end
14
16
 
15
17
  def groups=(value)
@@ -20,12 +22,12 @@ module MessageBird
20
22
  @messages = MessageBird::MessageReference.new(value)
21
23
  end
22
24
 
23
- def createdDatetime=(value)
24
- @createdDatetime = value_to_time(value)
25
+ def created_datetime=(value)
26
+ @created_datetime = value_to_time(value)
25
27
  end
26
28
 
27
- def updatedDatetime=(value)
28
- @updatedDatetime = value_to_time(value)
29
+ def updated_datetime=(value)
30
+ @updated_datetime = value_to_time(value)
29
31
  end
30
32
  end
31
- end
33
+ end
@@ -1,7 +1,9 @@
1
+ # frozen_string_literal: true
2
+
1
3
  require 'messagebird/base'
2
4
 
3
5
  module MessageBird
4
6
  class ContactReference < MessageBird::Base
5
- attr_accessor :href, :totalCount
7
+ attr_accessor :href, :total_count
6
8
  end
7
9
  end
@@ -0,0 +1,44 @@
1
+ # frozen_string_literal: true
2
+
3
+ require 'messagebird/base'
4
+ require 'messagebird/contact'
5
+ require 'messagebird/conversation_channel'
6
+
7
+ module MessageBird
8
+ class Conversation < MessageBird::Base
9
+ attr_accessor :id, :status, :last_used_channel_id, :contact_id
10
+ attr_reader :contact, :channels, :messages, :created_datetime,
11
+ :updated_datetime, :last_received_datetime
12
+
13
+ CONVERSATION_STATUS_ACTIVE = 'active'
14
+ CONVERSATION_STATUS_ARCHIVED = 'archived'
15
+ WEBHOOK_EVENT_CONVERSATION_CREATED = 'conversation.created'
16
+ WEBHOOK_EVENT_CONVERSATION_UPDATED = 'conversation.updated'
17
+ WEBHOOK_EVENT_MESSAGE_CREATED = 'message.created'
18
+ WEBHOOK_EVENT_MESSAGE_UPDATED = 'message.updated'
19
+
20
+ def contact=(value)
21
+ @contact = Contact.new(value)
22
+ end
23
+
24
+ def channels=(json)
25
+ @channels = json.map { |c| MessageBird::ConversationChannel.new(c) }
26
+ end
27
+
28
+ def messages=(value)
29
+ @messages = MessageBird::MessageReference.new(value)
30
+ end
31
+
32
+ def created_datetime=(value)
33
+ @created_datetime = value_to_time(value)
34
+ end
35
+
36
+ def updated_datetime=(value)
37
+ @updated_datetime = value_to_time(value)
38
+ end
39
+
40
+ def last_received_datetime=(value)
41
+ @last_received_datetime = value_to_time(value)
42
+ end
43
+ end
44
+ end
@@ -0,0 +1,18 @@
1
+ # frozen_string_literal: true
2
+
3
+ require 'messagebird/base'
4
+
5
+ module MessageBird
6
+ class ConversationChannel < MessageBird::Base
7
+ attr_accessor :id, :name, :platform_id, :status
8
+ attr_reader :created_datetime, :updated_datetime
9
+
10
+ def created_datetime=(value)
11
+ @created_datetime = value_to_time(value)
12
+ end
13
+
14
+ def updated_datetime=(value)
15
+ @updated_datetime = value_to_time(value)
16
+ end
17
+ end
18
+ end
@@ -0,0 +1,22 @@
1
+ # frozen_string_literal: true
2
+
3
+ require 'net/https'
4
+ require 'uri'
5
+ require 'json'
6
+ require 'messagebird/http_client'
7
+
8
+ module MessageBird
9
+ class ConversationClient < HttpClient
10
+ ENDPOINT = 'https://conversations.messagebird.com/v1/'
11
+
12
+ def prepare_request(request, params = {})
13
+ request['Content-Type'] = 'application/json'
14
+ request.body = params.to_json
15
+ request
16
+ end
17
+ end
18
+
19
+ def endpoint
20
+ ENDPOINT
21
+ end
22
+ end
@@ -0,0 +1,10 @@
1
+ # frozen_string_literal: true
2
+
3
+ require 'messagebird/base'
4
+
5
+ module MessageBird
6
+ class ConversationMessage < MessageBird::Base
7
+ attr_accessor :id, :conversation_id, :channel_id, :direction, :status,
8
+ :type, :content, :created_datetime, :updated_datetime, :fallback
9
+ end
10
+ end
@@ -0,0 +1,9 @@
1
+ # frozen_string_literal: true
2
+
3
+ require 'messagebird/base'
4
+
5
+ module MessageBird
6
+ class ConversationWebhook < MessageBird::Base
7
+ attr_accessor :id, :events, :channel_id, :url, :status, :created_datetime, :updated_datetime
8
+ end
9
+ end
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  require 'messagebird/base'
2
4
 
3
5
  module MessageBird
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  require 'messagebird/base'
2
4
 
3
5
  module MessageBird
@@ -1,21 +1,23 @@
1
+ # frozen_string_literal: true
2
+
1
3
  require 'messagebird/base'
2
4
  require 'messagebird/contact_reference'
3
5
 
4
6
  module MessageBird
5
7
  class Group < MessageBird::Base
6
- attr_accessor :id, :href, :name, :contacts, :createdDatetime,
7
- :updatedDatetime
8
+ attr_accessor :id, :href, :name
9
+ attr_reader :contacts, :created_datetime, :updated_datetime
8
10
 
9
11
  def contacts=(value)
10
12
  @contacts = MessageBird::ContactReference.new(value)
11
13
  end
12
14
 
13
- def createdDatetime=(value)
14
- @createdDatetime = value_to_time(value)
15
+ def created_datetime=(value)
16
+ @created_datetime = value_to_time(value)
15
17
  end
16
18
 
17
- def updatedDatetime=(value)
18
- @updatedDatetime = value_to_time(value)
19
+ def updated_datetime=(value)
20
+ @updated_datetime = value_to_time(value)
19
21
  end
20
22
  end
21
- end
23
+ end
@@ -1,7 +1,9 @@
1
+ # frozen_string_literal: true
2
+
1
3
  require 'messagebird/base'
2
4
 
3
5
  module MessageBird
4
6
  class GroupReference < MessageBird::Base
5
- attr_accessor :href, :totalCount
7
+ attr_accessor :href, :total_count
6
8
  end
7
9
  end
@@ -1,18 +1,20 @@
1
+ # frozen_string_literal: true
2
+
1
3
  require 'time'
2
4
 
3
5
  require 'messagebird/base'
4
6
 
5
7
  module MessageBird
6
8
  class HLR < MessageBird::Base
7
- attr_accessor :id, :href, :msisdn, :network, :reference, :status,
8
- :details, :createdDatetime, :statusDatetime
9
+ attr_accessor :id, :href, :msisdn, :network, :reference, :status, :details
10
+ attr_reader :created_datetime, :status_datetime
9
11
 
10
- def createdDatetime=(value)
11
- @createdDatetime = value_to_time(value)
12
+ def created_datetime=(value)
13
+ @created_datetime = value_to_time(value)
12
14
  end
13
15
 
14
- def statusDatetime=(value)
15
- @statusDatetime = value_to_time(value)
16
+ def status_datetime=(value)
17
+ @status_datetime = value_to_time(value)
16
18
  end
17
19
  end
18
20
  end
@@ -1,28 +1,42 @@
1
+ # frozen_string_literal: true
2
+
1
3
  require 'net/https'
2
4
  require 'uri'
3
5
 
4
6
  module MessageBird
5
-
6
- class InvalidPhoneNumberException < TypeError; end
7
+ class ServerException < StandardError; end
7
8
  class InvalidResponseException < StandardError; end
8
9
  class MethodNotAllowedException < ArgumentError; end
9
10
 
10
11
  class HttpClient
11
-
12
12
  attr_reader :access_key
13
13
 
14
+ VALID_RESPONSE_CODES = [200, 201, 202, 204, 401, 404, 405, 422].freeze
15
+ ENDPOINT = 'https://rest.messagebird.com/'
16
+ SUBMIT_METHODS = [:patch, :post, :put].freeze
17
+ ALLOWED_METHODS = SUBMIT_METHODS.dup + [:get, :delete].freeze
18
+
14
19
  def initialize(access_key)
15
20
  @access_key = access_key
16
21
  end
17
22
 
18
- def request(method, path, params={}, check_json=true)
19
- uri = URI.join(ENDPOINT, '/', path)
23
+ def endpoint
24
+ ENDPOINT
25
+ end
20
26
 
21
- # Set up the HTTP object.
27
+ def build_http_client(uri)
22
28
  http = Net::HTTP.new(uri.host, uri.port)
23
- http.use_ssl = true
29
+ http.use_ssl = true
24
30
 
25
- request = prepare_request(method, uri, params)
31
+ http.set_debug_output($stdout) unless ENV['DEBUG_MB_HTTP_CLIENT'].nil?
32
+
33
+ http
34
+ end
35
+
36
+ def request(method, path, params = {}, check_json = true)
37
+ uri = URI.join(endpoint, path)
38
+ http = build_http_client(uri)
39
+ request = build_request(method, uri, params)
26
40
 
27
41
  # Execute the request and fetch the response.
28
42
  response = http.request(request)
@@ -33,24 +47,33 @@ module MessageBird
33
47
  response.body
34
48
  end
35
49
 
36
- def prepare_request(method, uri, params={})
50
+ def request_block(method, path, params = {}, &block)
51
+ uri = URI.join(endpoint, path)
52
+ http = build_http_client(uri)
53
+ request = build_request(method, uri, params)
54
+
55
+ http.request(request, block)
56
+ end
57
+
58
+ def prepare_request(request, params = {})
59
+ request.set_form_data(params)
60
+
61
+ request
62
+ end
63
+
64
+ def build_request(method, uri, params = {})
37
65
  # Construct the HTTP request.
38
- case method
39
- when :delete
40
- request = Net::HTTP::Delete.new(uri.request_uri)
41
- when :get
42
- request = Net::HTTP::Get.new(uri.request_uri)
43
- when :post
44
- request = Net::HTTP::Post.new(uri.request_uri)
45
- else
46
- raise MethodNotAllowedException
47
- end
66
+ raise MethodNotAllowedException unless ALLOWED_METHODS.include?(method)
67
+
68
+ request = Class.const_get("Net::HTTP::#{method.to_s.capitalize}").new(uri.request_uri)
48
69
 
49
70
  request['Accept'] = 'application/json'
50
71
  request['Authorization'] = "AccessKey #{@access_key}"
51
- request['User-Agent'] = "MessageBird/ApiClient/#{CLIENT_VERSION} Ruby/#{RUBY_VERSION}"
72
+ request['User-Agent'] = "MessageBird/ApiClient/#{Version::STRING} Ruby/#{RUBY_VERSION}"
52
73
 
53
- request.set_form_data(params) if method == :post && !params.empty?
74
+ if SUBMIT_METHODS.include?(method) && !params.empty?
75
+ prepare_request(request, params)
76
+ end
54
77
 
55
78
  request
56
79
  end
@@ -58,11 +81,7 @@ module MessageBird
58
81
  # Throw an exception if the response code is not one we expect from the
59
82
  # MessageBird API.
60
83
  def assert_valid_response_code(code)
61
- # InvalidPhoneNumberException does not make a lot of sense here, but it's
62
- # needed to maintain backwards compatibility. See issue:
63
- # https://github.com/messagebird/ruby-rest-api/issues/17
64
- expected_codes = [200, 201, 204, 401, 404, 405, 422]
65
- raise InvalidPhoneNumberException, 'Unknown response from server' unless expected_codes.include? code
84
+ raise ServerException, 'Unknown response from server' unless VALID_RESPONSE_CODES.include? code
66
85
  end
67
86
 
68
87
  # Throw an exception if the response's content type is not JSON. This only
@@ -72,7 +91,5 @@ module MessageBird
72
91
  # for equality: some API's may append the charset to this header.
73
92
  raise InvalidResponseException, 'Response is not JSON' unless content_type.start_with? 'application/json'
74
93
  end
75
-
76
94
  end
77
-
78
- end
95
+ end
@@ -1,8 +1,10 @@
1
+ # frozen_string_literal: true
2
+
1
3
  require 'messagebird/base'
2
4
 
3
5
  class List < MessageBird::Base
4
-
5
- attr_accessor :offset, :limit, :count, :totalCount, :links, :items
6
+ attr_accessor :offset, :limit, :count, :total_count, :links
7
+ attr_reader :items
6
8
 
7
9
  # type will be used to create objects for the items, e.g.
8
10
  # List.new(Contact, {}).
@@ -19,5 +21,4 @@ class List < MessageBird::Base
19
21
  def [](index)
20
22
  @items[index]
21
23
  end
22
-
23
- end
24
+ end
@@ -1,18 +1,20 @@
1
+ # frozen_string_literal: true
2
+
1
3
  require 'time'
2
4
 
3
5
  require 'messagebird/base'
4
6
 
5
7
  module MessageBird
6
8
  class Lookup < MessageBird::Base
7
- attr_accessor :href, :countryCode, :countryPrefix, :phoneNumber, :type
9
+ attr_accessor :href, :country_code, :country_prefix, :phone_number, :type
8
10
  attr_reader :formats, :hlr
9
11
 
10
- def formats=(newFormats)
11
- @formats = Formats.new(newFormats)
12
+ def formats=(new_formats)
13
+ @formats = Formats.new(new_formats)
12
14
  end
13
15
 
14
- def hlr=(newHLR)
15
- @hlr = HLR.new(newHLR)
16
+ def hlr=(new_hlr)
17
+ @hlr = HLR.new(new_hlr)
16
18
  end
17
19
  end
18
20
 
@@ -1,18 +1,20 @@
1
+ # frozen_string_literal: true
2
+
1
3
  require 'messagebird/base'
2
4
  require 'messagebird/recipient'
3
5
 
4
6
  module MessageBird
5
7
  class Message < MessageBird::Base
6
- attr_accessor :id, :href, :direction, :type, :originator, :body,
7
- :reference, :validity, :gateway, :typeDetails, :datacoding,
8
- :mclass, :scheduledDatetime, :createdDatetime, :recipients
8
+ attr_accessor :id, :href, :direction, :type, :originator, :body, :reference,
9
+ :validity, :gateway, :typeDetails, :datacoding, :mclass
10
+ attr_reader :scheduled_date_time, :created_datetime, :recipients
9
11
 
10
- def scheduledDatetime=(value)
11
- @scheduledDatetime = value_to_time(value)
12
+ def scheduled_date_time=(value)
13
+ @scheduled_date_time = value_to_time(value)
12
14
  end
13
15
 
14
- def createdDatetime=(value)
15
- @createdDatetime = value_to_time(value)
16
+ def created_datetime=(value)
17
+ @created_datetime = value_to_time(value)
16
18
  end
17
19
 
18
20
  def recipients=(json)