Class: Twilio::REST::Insights::V1::CallContext::EventList
- Inherits:
-
ListResource
- Object
- ListResource
- Twilio::REST::Insights::V1::CallContext::EventList
- Defined in:
- lib/twilio-ruby/rest/insights/v1/call/event.rb
Instance Method Summary collapse
-
#each ⇒ Object
When passed a block, yields EventInstance records from the API.
-
#get_page(target_url) ⇒ Page
Retrieve a single page of EventInstance records from the API.
-
#initialize(version, call_sid: nil) ⇒ EventList
constructor
Initialize the EventList.
-
#list(edge: :unset, limit: nil, page_size: nil) ⇒ Array
Lists EventInstance records from the API as a list.
-
#page(edge: :unset, page_token: :unset, page_number: :unset, page_size: :unset) ⇒ Page
Retrieve a single page of EventInstance records from the API.
-
#stream(edge: :unset, limit: nil, page_size: nil) ⇒ Enumerable
Streams Instance records from the API as an Enumerable.
-
#to_s ⇒ Object
Provide a user friendly representation.
Constructor Details
#initialize(version, call_sid: nil) ⇒ EventList
Initialize the EventList
28 29 30 31 32 33 34 |
# File 'lib/twilio-ruby/rest/insights/v1/call/event.rb', line 28 def initialize(version, call_sid: nil) super(version) # Path Solution @solution = { call_sid: call_sid } @uri = "/Voice/#{@solution[:call_sid]}/Events" end |
Instance Method Details
#each ⇒ Object
When passed a block, yields EventInstance records from the API. This operation lazily loads records as efficiently as possible until the limit is reached.
82 83 84 85 86 87 88 89 90 |
# File 'lib/twilio-ruby/rest/insights/v1/call/event.rb', line 82 def each limits = @version.read_limits page = self.page(page_size: limits[:page_size], ) @version.stream(page, limit: limits[:limit], page_limit: limits[:page_limit]).each {|x| yield x} end |
#get_page(target_url) ⇒ Page
Retrieve a single page of EventInstance records from the API. Request is executed immediately.
121 122 123 124 125 126 127 |
# File 'lib/twilio-ruby/rest/insights/v1/call/event.rb', line 121 def get_page(target_url) response = @version.domain.request( 'GET', target_url ) EventPage.new(@version, response, @solution) end |
#list(edge: :unset, limit: nil, page_size: nil) ⇒ Array
Lists EventInstance records from the API as a list. Unlike stream(), this operation is eager and will load ‘limit` records into memory before returning.
48 49 50 51 52 53 54 |
# File 'lib/twilio-ruby/rest/insights/v1/call/event.rb', line 48 def list(edge: :unset, limit: nil, page_size: nil) self.stream( edge: edge, limit: limit, page_size: page_size ).entries end |
#page(edge: :unset, page_token: :unset, page_number: :unset, page_size: :unset) ⇒ Page
Retrieve a single page of EventInstance records from the API. Request is executed immediately.
100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 |
# File 'lib/twilio-ruby/rest/insights/v1/call/event.rb', line 100 def page(edge: :unset, page_token: :unset, page_number: :unset, page_size: :unset) params = Twilio::Values.of({ 'Edge' => edge, 'PageToken' => page_token, 'Page' => page_number, 'PageSize' => page_size, }) headers = Twilio::Values.of({}) response = @version.page('GET', @uri, params: params, headers: headers) EventPage.new(@version, response, @solution) end |
#stream(edge: :unset, limit: nil, page_size: nil) ⇒ Enumerable
Streams Instance records from the API as an Enumerable. This operation lazily loads records as efficiently as possible until the limit is reached.
68 69 70 71 72 73 74 75 76 |
# File 'lib/twilio-ruby/rest/insights/v1/call/event.rb', line 68 def stream(edge: :unset, limit: nil, page_size: nil) limits = @version.read_limits(limit, page_size) page = self.page( edge: edge, page_size: limits[:page_size], ) @version.stream(page, limit: limits[:limit], page_limit: limits[:page_limit]) end |
#to_s ⇒ Object
Provide a user friendly representation
132 133 134 |
# File 'lib/twilio-ruby/rest/insights/v1/call/event.rb', line 132 def to_s '#<Twilio.Insights.V1.EventList>' end |