Class: Twilio::REST::Taskrouter::V1::WorkspaceContext::WorkflowList
- Inherits:
-
ListResource
- Object
- ListResource
- Twilio::REST::Taskrouter::V1::WorkspaceContext::WorkflowList
- Defined in:
- lib/twilio-ruby/rest/taskrouter/v1/workspace/workflow.rb
Instance Method Summary collapse
-
#create(friendly_name: nil, configuration: nil, assignment_callback_url: :unset, fallback_assignment_callback_url: :unset, task_reservation_timeout: :unset) ⇒ WorkflowInstance
Retrieve a single page of WorkflowInstance records from the API.
-
#each ⇒ Object
When passed a block, yields WorkflowInstance records from the API.
-
#get_page(target_url) ⇒ Page
Retrieve a single page of WorkflowInstance records from the API.
-
#initialize(version, workspace_sid: nil) ⇒ WorkflowList
constructor
Initialize the WorkflowList.
-
#list(friendly_name: :unset, limit: nil, page_size: nil) ⇒ Array
Lists WorkflowInstance records from the API as a list.
-
#page(friendly_name: :unset, page_token: :unset, page_number: :unset, page_size: :unset) ⇒ Page
Retrieve a single page of WorkflowInstance records from the API.
-
#stream(friendly_name: :unset, limit: nil, page_size: nil) ⇒ Enumerable
Streams WorkflowInstance records from the API as an Enumerable.
-
#to_s ⇒ Object
Provide a user friendly representation.
Constructor Details
#initialize(version, workspace_sid: nil) ⇒ WorkflowList
Initialize the WorkflowList
18 19 20 21 22 23 24 |
# File 'lib/twilio-ruby/rest/taskrouter/v1/workspace/workflow.rb', line 18 def initialize(version, workspace_sid: nil) super(version) # Path Solution @solution = {workspace_sid: workspace_sid} @uri = "/Workspaces/#{@solution[:workspace_sid]}/Workflows" end |
Instance Method Details
#create(friendly_name: nil, configuration: nil, assignment_callback_url: :unset, fallback_assignment_callback_url: :unset, task_reservation_timeout: :unset) ⇒ WorkflowInstance
Retrieve a single page of WorkflowInstance records from the API. Request is executed immediately.
122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 |
# File 'lib/twilio-ruby/rest/taskrouter/v1/workspace/workflow.rb', line 122 def create(friendly_name: nil, configuration: nil, assignment_callback_url: :unset, fallback_assignment_callback_url: :unset, task_reservation_timeout: :unset) data = Twilio::Values.of({ 'FriendlyName' => friendly_name, 'Configuration' => configuration, 'AssignmentCallbackUrl' => assignment_callback_url, 'FallbackAssignmentCallbackUrl' => fallback_assignment_callback_url, 'TaskReservationTimeout' => task_reservation_timeout, }) payload = @version.create( 'POST', @uri, data: data ) WorkflowInstance.new(@version, payload, workspace_sid: @solution[:workspace_sid], ) end |
#each ⇒ Object
When passed a block, yields WorkflowInstance records from the API. This operation lazily loads records as efficiently as possible until the limit is reached.
66 67 68 69 70 71 72 73 74 |
# File 'lib/twilio-ruby/rest/taskrouter/v1/workspace/workflow.rb', line 66 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 WorkflowInstance records from the API. Request is executed immediately.
104 105 106 107 108 109 110 |
# File 'lib/twilio-ruby/rest/taskrouter/v1/workspace/workflow.rb', line 104 def get_page(target_url) response = @version.domain.request( 'GET', target_url ) WorkflowPage.new(@version, response, @solution) end |
#list(friendly_name: :unset, limit: nil, page_size: nil) ⇒ Array
Lists WorkflowInstance records from the API as a list. Unlike stream(), this operation is eager and will load ‘limit` records into memory before returning.
38 39 40 |
# File 'lib/twilio-ruby/rest/taskrouter/v1/workspace/workflow.rb', line 38 def list(friendly_name: :unset, limit: nil, page_size: nil) self.stream(friendly_name: friendly_name, limit: limit, page_size: page_size).entries end |
#page(friendly_name: :unset, page_token: :unset, page_number: :unset, page_size: :unset) ⇒ Page
Retrieve a single page of WorkflowInstance records from the API. Request is executed immediately.
84 85 86 87 88 89 90 91 92 93 94 95 96 97 |
# File 'lib/twilio-ruby/rest/taskrouter/v1/workspace/workflow.rb', line 84 def page(friendly_name: :unset, page_token: :unset, page_number: :unset, page_size: :unset) params = Twilio::Values.of({ 'FriendlyName' => friendly_name, 'PageToken' => page_token, 'Page' => page_number, 'PageSize' => page_size, }) response = @version.page( 'GET', @uri, params ) WorkflowPage.new(@version, response, @solution) end |
#stream(friendly_name: :unset, limit: nil, page_size: nil) ⇒ Enumerable
Streams WorkflowInstance records from the API as an Enumerable. This operation lazily loads records as efficiently as possible until the limit is reached.
54 55 56 57 58 59 60 |
# File 'lib/twilio-ruby/rest/taskrouter/v1/workspace/workflow.rb', line 54 def stream(friendly_name: :unset, limit: nil, page_size: nil) limits = @version.read_limits(limit, page_size) page = self.page(friendly_name: friendly_name, 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
142 143 144 |
# File 'lib/twilio-ruby/rest/taskrouter/v1/workspace/workflow.rb', line 142 def to_s '#<Twilio.Taskrouter.V1.WorkflowList>' end |