Class: Twilio::REST::Proxy::V1::ServiceContext::SessionList
- Inherits:
-
ListResource
- Object
- ListResource
- Twilio::REST::Proxy::V1::ServiceContext::SessionList
- Defined in:
- lib/twilio-ruby/rest/proxy/v1/service/session.rb
Overview
PLEASE NOTE that this class contains beta products that are subject to change. Use them with caution.
Instance Method Summary collapse
-
#create(unique_name: :unset, date_expiry: :unset, ttl: :unset, mode: :unset, status: :unset, participants: :unset) ⇒ SessionInstance
Retrieve a single page of SessionInstance records from the API.
-
#each ⇒ Object
When passed a block, yields SessionInstance records from the API.
-
#get_page(target_url) ⇒ Page
Retrieve a single page of SessionInstance records from the API.
-
#initialize(version, service_sid: nil) ⇒ SessionList
constructor
Initialize the SessionList.
-
#list(unique_name: :unset, status: :unset, limit: nil, page_size: nil) ⇒ Array
Lists SessionInstance records from the API as a list.
-
#page(unique_name: :unset, status: :unset, page_token: :unset, page_number: :unset, page_size: :unset) ⇒ Page
Retrieve a single page of SessionInstance records from the API.
-
#stream(unique_name: :unset, status: :unset, limit: nil, page_size: nil) ⇒ Enumerable
Streams SessionInstance records from the API as an Enumerable.
-
#to_s ⇒ Object
Provide a user friendly representation.
Constructor Details
#initialize(version, service_sid: nil) ⇒ SessionList
Initialize the SessionList
22 23 24 25 26 27 28 |
# File 'lib/twilio-ruby/rest/proxy/v1/service/session.rb', line 22 def initialize(version, service_sid: nil) super(version) # Path Solution @solution = {service_sid: service_sid} @uri = "/Services/#{@solution[:service_sid]}/Sessions" end |
Instance Method Details
#create(unique_name: :unset, date_expiry: :unset, ttl: :unset, mode: :unset, status: :unset, participants: :unset) ⇒ SessionInstance
Retrieve a single page of SessionInstance records from the API. Request is executed immediately.
140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 |
# File 'lib/twilio-ruby/rest/proxy/v1/service/session.rb', line 140 def create(unique_name: :unset, date_expiry: :unset, ttl: :unset, mode: :unset, status: :unset, participants: :unset) data = Twilio::Values.of({ 'UniqueName' => unique_name, 'DateExpiry' => Twilio.serialize_iso8601_datetime(date_expiry), 'Ttl' => ttl, 'Mode' => mode, 'Status' => status, 'Participants' => Twilio.serialize_list(participants) { |e| Twilio.serialize_object(e) }, }) payload = @version.create( 'POST', @uri, data: data ) SessionInstance.new(@version, payload, service_sid: @solution[:service_sid], ) end |
#each ⇒ Object
When passed a block, yields SessionInstance records from the API. This operation lazily loads records as efficiently as possible until the limit is reached.
74 75 76 77 78 79 80 81 82 |
# File 'lib/twilio-ruby/rest/proxy/v1/service/session.rb', line 74 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 SessionInstance records from the API. Request is executed immediately.
115 116 117 118 119 120 121 |
# File 'lib/twilio-ruby/rest/proxy/v1/service/session.rb', line 115 def get_page(target_url) response = @version.domain.request( 'GET', target_url ) SessionPage.new(@version, response, @solution) end |
#list(unique_name: :unset, status: :unset, limit: nil, page_size: nil) ⇒ Array
Lists SessionInstance records from the API as a list. Unlike stream(), this operation is eager and will load ‘limit` records into memory before returning.
44 45 46 |
# File 'lib/twilio-ruby/rest/proxy/v1/service/session.rb', line 44 def list(unique_name: :unset, status: :unset, limit: nil, page_size: nil) self.stream(unique_name: unique_name, status: status, limit: limit, page_size: page_size).entries end |
#page(unique_name: :unset, status: :unset, page_token: :unset, page_number: :unset, page_size: :unset) ⇒ Page
Retrieve a single page of SessionInstance records from the API. Request is executed immediately.
94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 |
# File 'lib/twilio-ruby/rest/proxy/v1/service/session.rb', line 94 def page(unique_name: :unset, status: :unset, page_token: :unset, page_number: :unset, page_size: :unset) params = Twilio::Values.of({ 'UniqueName' => unique_name, 'Status' => status, 'PageToken' => page_token, 'Page' => page_number, 'PageSize' => page_size, }) response = @version.page( 'GET', @uri, params ) SessionPage.new(@version, response, @solution) end |
#stream(unique_name: :unset, status: :unset, limit: nil, page_size: nil) ⇒ Enumerable
Streams SessionInstance records from the API as an Enumerable. This operation lazily loads records as efficiently as possible until the limit is reached.
62 63 64 65 66 67 68 |
# File 'lib/twilio-ruby/rest/proxy/v1/service/session.rb', line 62 def stream(unique_name: :unset, status: :unset, limit: nil, page_size: nil) limits = @version.read_limits(limit, page_size) page = self.page(unique_name: unique_name, status: status, 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
161 162 163 |
# File 'lib/twilio-ruby/rest/proxy/v1/service/session.rb', line 161 def to_s '#<Twilio.Proxy.V1.SessionList>' end |