Class: Twilio::REST::Taskrouter::V1::WorkspaceContext::WorkerInstance

Inherits:
InstanceResource
  • Object
show all
Defined in:
lib/twilio-ruby/rest/taskrouter/v1/workspace/worker.rb

Instance Method Summary collapse

Constructor Details

#initialize(version, payload, workspace_sid: nil, sid: nil) ⇒ WorkerInstance

Initialize the WorkerInstance

Parameters:

  • version (Version)

    Version that contains the resource

  • payload (Hash)

    payload that contains response from Twilio

  • account_sid (String)

    The SID of the Account that created this Worker resource.

  • sid (String) (defaults to: nil)

    The SID of the Call resource to fetch.



414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
# File 'lib/twilio-ruby/rest/taskrouter/v1/workspace/worker.rb', line 414

def initialize(version, payload , workspace_sid: nil, sid: nil)
    super(version)
    
    # Marshaled Properties
    @properties = { 
        'account_sid' => payload['account_sid'],
        'activity_name' => payload['activity_name'],
        'activity_sid' => payload['activity_sid'],
        'attributes' => payload['attributes'],
        'available' => payload['available'],
        'date_created' => Twilio.deserialize_iso8601_datetime(payload['date_created']),
        'date_status_changed' => Twilio.deserialize_iso8601_datetime(payload['date_status_changed']),
        'date_updated' => Twilio.deserialize_iso8601_datetime(payload['date_updated']),
        'friendly_name' => payload['friendly_name'],
        'sid' => payload['sid'],
        'workspace_sid' => payload['workspace_sid'],
        'url' => payload['url'],
        'links' => payload['links'],
    }

    # Context
    @instance_context = nil
    @params = { 'workspace_sid' => workspace_sid  || @properties['workspace_sid']  ,'sid' => sid  || @properties['sid']  , }
end

Instance Method Details

#account_sidString

Returns The SID of the [Account](www.twilio.com/docs/iam/api/account) that created the Worker resource.

Returns:



452
453
454
# File 'lib/twilio-ruby/rest/taskrouter/v1/workspace/worker.rb', line 452

def 
    @properties['account_sid']
end

#activity_nameString

Returns The ‘friendly_name` of the Worker’s current Activity.

Returns:

  • (String)

    The ‘friendly_name` of the Worker’s current Activity.



458
459
460
# File 'lib/twilio-ruby/rest/taskrouter/v1/workspace/worker.rb', line 458

def activity_name
    @properties['activity_name']
end

#activity_sidString

Returns The SID of the Worker’s current Activity.

Returns:

  • (String)

    The SID of the Worker’s current Activity.



464
465
466
# File 'lib/twilio-ruby/rest/taskrouter/v1/workspace/worker.rb', line 464

def activity_sid
    @properties['activity_sid']
end

#attributesString

Returns The JSON string that describes the Worker. For example: ‘{ "email": "[email protected]", "phone": "+5095551234" }`. Note If this property has been assigned a value, it will only be displayed in FETCH actions that return a single resource. Otherwise, this property will be null, even if it has a value. This data is passed to the `assignment_callback_url` when TaskRouter assigns a Task to the Worker.

Returns:

  • (String)

    The JSON string that describes the Worker. For example: ‘{ "email": "[email protected]", "phone": "+5095551234" }`. Note If this property has been assigned a value, it will only be displayed in FETCH actions that return a single resource. Otherwise, this property will be null, even if it has a value. This data is passed to the `assignment_callback_url` when TaskRouter assigns a Task to the Worker.



470
471
472
# File 'lib/twilio-ruby/rest/taskrouter/v1/workspace/worker.rb', line 470

def attributes
    @properties['attributes']
end

#availableBoolean

Returns Whether the Worker is available to perform tasks.

Returns:

  • (Boolean)

    Whether the Worker is available to perform tasks.



476
477
478
# File 'lib/twilio-ruby/rest/taskrouter/v1/workspace/worker.rb', line 476

def available
    @properties['available']
end

#contextWorkerContext

Generate an instance context for the instance, the context is capable of performing various actions. All instance actions are proxied to the context

Returns:



443
444
445
446
447
448
# File 'lib/twilio-ruby/rest/taskrouter/v1/workspace/worker.rb', line 443

def context
    unless @instance_context
        @instance_context = WorkerContext.new(@version , @params['workspace_sid'], @params['sid'])
    end
    @instance_context
end

#cumulative_statisticscumulative_statistics

Access the cumulative_statistics

Returns:



598
599
600
# File 'lib/twilio-ruby/rest/taskrouter/v1/workspace/worker.rb', line 598

def cumulative_statistics
    context.cumulative_statistics
end

#date_createdTime

Returns The date and time in GMT when the resource was created specified in [ISO 8601](en.wikipedia.org/wiki/ISO_8601) format.

Returns:



482
483
484
# File 'lib/twilio-ruby/rest/taskrouter/v1/workspace/worker.rb', line 482

def date_created
    @properties['date_created']
end

#date_status_changedTime

Returns The date and time in GMT of the last change to the Worker’s activity specified in [ISO 8601](en.wikipedia.org/wiki/ISO_8601) format. Used to calculate Workflow statistics.

Returns:

  • (Time)

    The date and time in GMT of the last change to the Worker’s activity specified in [ISO 8601](en.wikipedia.org/wiki/ISO_8601) format. Used to calculate Workflow statistics.



488
489
490
# File 'lib/twilio-ruby/rest/taskrouter/v1/workspace/worker.rb', line 488

def date_status_changed
    @properties['date_status_changed']
end

#date_updatedTime

Returns The date and time in GMT when the resource was last updated specified in [ISO 8601](en.wikipedia.org/wiki/ISO_8601) format.

Returns:



494
495
496
# File 'lib/twilio-ruby/rest/taskrouter/v1/workspace/worker.rb', line 494

def date_updated
    @properties['date_updated']
end

#delete(if_match: :unset) ⇒ Boolean

Delete the WorkerInstance

Parameters:

  • if_match (String) (defaults to: :unset)

    The If-Match HTTP request header

Returns:

  • (Boolean)

    True if delete succeeds, false otherwise



532
533
534
535
536
537
538
539
# File 'lib/twilio-ruby/rest/taskrouter/v1/workspace/worker.rb', line 532

def delete(
    if_match: :unset
)

    context.delete(
        if_match: if_match, 
    )
end

#fetchWorkerInstance

Fetch the WorkerInstance

Returns:



544
545
546
547
# File 'lib/twilio-ruby/rest/taskrouter/v1/workspace/worker.rb', line 544

def fetch

    context.fetch
end

#friendly_nameString

Returns The string that you assigned to describe the resource. Friendly names are case insensitive, and unique within the TaskRouter Workspace.

Returns:

  • (String)

    The string that you assigned to describe the resource. Friendly names are case insensitive, and unique within the TaskRouter Workspace.



500
501
502
# File 'lib/twilio-ruby/rest/taskrouter/v1/workspace/worker.rb', line 500

def friendly_name
    @properties['friendly_name']
end

#inspectObject

Provide a detailed, user friendly representation



618
619
620
621
# File 'lib/twilio-ruby/rest/taskrouter/v1/workspace/worker.rb', line 618

def inspect
    values = @properties.map{|k, v| "#{k}: #{v}"}.join(" ")
    "<Twilio.Taskrouter.V1.WorkerInstance #{values}>"
end

Returns The URLs of related resources.

Returns:

  • (Hash)

    The URLs of related resources.



524
525
526
# File 'lib/twilio-ruby/rest/taskrouter/v1/workspace/worker.rb', line 524

def links
    @properties['links']
end

#real_time_statisticsreal_time_statistics

Access the real_time_statistics

Returns:



584
585
586
# File 'lib/twilio-ruby/rest/taskrouter/v1/workspace/worker.rb', line 584

def real_time_statistics
    context.real_time_statistics
end

#reservationsreservations

Access the reservations

Returns:



577
578
579
# File 'lib/twilio-ruby/rest/taskrouter/v1/workspace/worker.rb', line 577

def reservations
    context.reservations
end

#sidString

Returns The unique string that we created to identify the Worker resource.

Returns:

  • (String)

    The unique string that we created to identify the Worker resource.



506
507
508
# File 'lib/twilio-ruby/rest/taskrouter/v1/workspace/worker.rb', line 506

def sid
    @properties['sid']
end

#statisticsstatistics

Access the statistics

Returns:



591
592
593
# File 'lib/twilio-ruby/rest/taskrouter/v1/workspace/worker.rb', line 591

def statistics
    context.statistics
end

#to_sObject

Provide a user friendly representation



611
612
613
614
# File 'lib/twilio-ruby/rest/taskrouter/v1/workspace/worker.rb', line 611

def to_s
    values = @params.map{|k, v| "#{k}: #{v}"}.join(" ")
    "<Twilio.Taskrouter.V1.WorkerInstance #{values}>"
end

#update(activity_sid: :unset, attributes: :unset, friendly_name: :unset, reject_pending_reservations: :unset, if_match: :unset) ⇒ WorkerInstance

Update the WorkerInstance

Parameters:

  • activity_sid (String) (defaults to: :unset)

    The SID of a valid Activity that will describe the Worker’s initial state. See [Activities](www.twilio.com/docs/taskrouter/api/activity) for more information.

  • attributes (String) (defaults to: :unset)

    The JSON string that describes the Worker. For example: ‘{ \"email\": \"[email protected]\", \"phone\": \"+5095551234\" }`. This data is passed to the `assignment_callback_url` when TaskRouter assigns a Task to the Worker. Defaults to {}.

  • friendly_name (String) (defaults to: :unset)

    A descriptive string that you create to describe the Worker. It can be up to 64 characters long.

  • reject_pending_reservations (Boolean) (defaults to: :unset)

    Whether to reject the Worker’s pending reservations. This option is only valid if the Worker’s new [Activity](www.twilio.com/docs/taskrouter/api/activity) resource has its ‘availability` property set to `False`.

  • if_match (String) (defaults to: :unset)

    The If-Match HTTP request header

Returns:



557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
# File 'lib/twilio-ruby/rest/taskrouter/v1/workspace/worker.rb', line 557

def update(
    activity_sid: :unset, 
    attributes: :unset, 
    friendly_name: :unset, 
    reject_pending_reservations: :unset, 
    if_match: :unset
)

    context.update(
        activity_sid: activity_sid, 
        attributes: attributes, 
        friendly_name: friendly_name, 
        reject_pending_reservations: reject_pending_reservations, 
        if_match: if_match, 
    )
end

#urlString

Returns The absolute URL of the Worker resource.

Returns:

  • (String)

    The absolute URL of the Worker resource.



518
519
520
# File 'lib/twilio-ruby/rest/taskrouter/v1/workspace/worker.rb', line 518

def url
    @properties['url']
end

#worker_channelsworker_channels

Access the worker_channels

Returns:



605
606
607
# File 'lib/twilio-ruby/rest/taskrouter/v1/workspace/worker.rb', line 605

def worker_channels
    context.worker_channels
end

#workspace_sidString

Returns The SID of the Workspace that contains the Worker.

Returns:

  • (String)

    The SID of the Workspace that contains the Worker.



512
513
514
# File 'lib/twilio-ruby/rest/taskrouter/v1/workspace/worker.rb', line 512

def workspace_sid
    @properties['workspace_sid']
end