Class: Twilio::REST::FlexApi::V1::InteractionContext::InteractionChannelInstance

Inherits:
InstanceResource
  • Object
show all
Defined in:
lib/twilio-ruby/rest/flex_api/v1/interaction/interaction_channel.rb

Instance Method Summary collapse

Constructor Details

#initialize(version, payload, interaction_sid: nil, sid: nil) ⇒ InteractionChannelInstance

Initialize the InteractionChannelInstance

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 InteractionChannel resource.

  • sid (String) (defaults to: nil)

    The SID of the Call resource to fetch.



284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
# File 'lib/twilio-ruby/rest/flex_api/v1/interaction/interaction_channel.rb', line 284

def initialize(version, payload , interaction_sid: nil, sid: nil)
    super(version)
    
    # Marshaled Properties
    @properties = { 
        'sid' => payload['sid'],
        'interaction_sid' => payload['interaction_sid'],
        'type' => payload['type'],
        'status' => payload['status'],
        'error_code' => payload['error_code'] == nil ? payload['error_code'] : payload['error_code'].to_i,
        'error_message' => payload['error_message'],
        'url' => payload['url'],
        'links' => payload['links'],
    }

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

Instance Method Details

#contextInteractionChannelContext

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

Returns:



308
309
310
311
312
313
# File 'lib/twilio-ruby/rest/flex_api/v1/interaction/interaction_channel.rb', line 308

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

#error_codeString

Returns The Twilio error code for a failed channel.

Returns:

  • (String)

    The Twilio error code for a failed channel.



341
342
343
# File 'lib/twilio-ruby/rest/flex_api/v1/interaction/interaction_channel.rb', line 341

def error_code
    @properties['error_code']
end

#error_messageString

Returns The error message for a failed channel.

Returns:

  • (String)

    The error message for a failed channel.



347
348
349
# File 'lib/twilio-ruby/rest/flex_api/v1/interaction/interaction_channel.rb', line 347

def error_message
    @properties['error_message']
end

#fetchInteractionChannelInstance

Fetch the InteractionChannelInstance

Returns:



366
367
368
369
# File 'lib/twilio-ruby/rest/flex_api/v1/interaction/interaction_channel.rb', line 366

def fetch

    context.fetch
end

#inspectObject

Provide a detailed, user friendly representation



410
411
412
413
# File 'lib/twilio-ruby/rest/flex_api/v1/interaction/interaction_channel.rb', line 410

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

#interaction_sidString

Returns The unique string created by Twilio to identify an Interaction resource, prefixed with KD.

Returns:

  • (String)

    The unique string created by Twilio to identify an Interaction resource, prefixed with KD.



323
324
325
# File 'lib/twilio-ruby/rest/flex_api/v1/interaction/interaction_channel.rb', line 323

def interaction_sid
    @properties['interaction_sid']
end

#invitesinvites

Access the invites

Returns:



390
391
392
# File 'lib/twilio-ruby/rest/flex_api/v1/interaction/interaction_channel.rb', line 390

def invites
    context.invites
end

Returns:

  • (Hash)


359
360
361
# File 'lib/twilio-ruby/rest/flex_api/v1/interaction/interaction_channel.rb', line 359

def links
    @properties['links']
end

#participantsparticipants

Access the participants

Returns:



397
398
399
# File 'lib/twilio-ruby/rest/flex_api/v1/interaction/interaction_channel.rb', line 397

def participants
    context.participants
end

#sidString

Returns The unique string created by Twilio to identify an Interaction Channel resource, prefixed with UO.

Returns:

  • (String)

    The unique string created by Twilio to identify an Interaction Channel resource, prefixed with UO.



317
318
319
# File 'lib/twilio-ruby/rest/flex_api/v1/interaction/interaction_channel.rb', line 317

def sid
    @properties['sid']
end

#statusChannelStatus

Returns:

  • (ChannelStatus)


335
336
337
# File 'lib/twilio-ruby/rest/flex_api/v1/interaction/interaction_channel.rb', line 335

def status
    @properties['status']
end

#to_sObject

Provide a user friendly representation



403
404
405
406
# File 'lib/twilio-ruby/rest/flex_api/v1/interaction/interaction_channel.rb', line 403

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

#typeType

Returns:

  • (Type)


329
330
331
# File 'lib/twilio-ruby/rest/flex_api/v1/interaction/interaction_channel.rb', line 329

def type
    @properties['type']
end

#update(status: nil, routing: :unset) ⇒ InteractionChannelInstance

Update the InteractionChannelInstance

Parameters:

  • status (UpdateChannelStatus) (defaults to: nil)
  • routing (Object) (defaults to: :unset)

    It changes the state of associated tasks. Routing status is required, When the channel status is set to ‘inactive`. Allowed Value for routing status is `closed`. Otherwise Optional, if not specified, all tasks will be set to `wrapping`.

Returns:



376
377
378
379
380
381
382
383
384
385
# File 'lib/twilio-ruby/rest/flex_api/v1/interaction/interaction_channel.rb', line 376

def update(
    status: nil, 
    routing: :unset
)

    context.update(
        status: status, 
        routing: routing, 
    )
end

#urlString

Returns:

  • (String)


353
354
355
# File 'lib/twilio-ruby/rest/flex_api/v1/interaction/interaction_channel.rb', line 353

def url
    @properties['url']
end