Class: Twilio::REST::Video::V1::RoomContext

Inherits:
InstanceContext show all
Defined in:
lib/twilio-ruby/rest/video/v1/room.rb,
lib/twilio-ruby/rest/video/v1/room/recording.rb,
lib/twilio-ruby/rest/video/v1/room/room_participant.rb,
lib/twilio-ruby/rest/video/v1/room/room_recording_rule.rb,
lib/twilio-ruby/rest/video/v1/room/room_participant/room_participant_subscribe_rule.rb,
lib/twilio-ruby/rest/video/v1/room/room_participant/room_participant_published_track.rb,
lib/twilio-ruby/rest/video/v1/room/room_participant/room_participant_subscribed_track.rb

Defined Under Namespace

Classes: ParticipantContext, ParticipantInstance, ParticipantList, ParticipantPage, RecordingRulesInstance, RecordingRulesList, RecordingRulesPage, RoomRecordingContext, RoomRecordingInstance, RoomRecordingList, RoomRecordingPage

Instance Method Summary collapse

Constructor Details

#initialize(version, sid) ⇒ RoomContext

Initialize the RoomContext

Parameters:

  • version (Version)

    Version that contains the resource

  • sid (String)

    The SID of the Room resource to fetch.



256
257
258
259
260
261
262
263
264
265
266
267
# File 'lib/twilio-ruby/rest/video/v1/room.rb', line 256

def initialize(version, sid)
  super(version)

  # Path Solution
  @solution = {sid: sid, }
  @uri = "/Rooms/#{@solution[:sid]}"

  # Dependents
  @recordings = nil
  @participants = nil
  @recording_rules = nil
end

Instance Method Details

#fetchRoomInstance

Fetch the RoomInstance

Returns:



272
273
274
275
276
# File 'lib/twilio-ruby/rest/video/v1/room.rb', line 272

def fetch
  payload = @version.fetch('GET', @uri)

  RoomInstance.new(@version, payload, sid: @solution[:sid], )
end

#inspectObject

Provide a detailed, user friendly representation



348
349
350
351
# File 'lib/twilio-ruby/rest/video/v1/room.rb', line 348

def inspect
  context = @solution.map {|k, v| "#{k}: #{v}"}.join(',')
  "#<Twilio.Video.V1.RoomContext #{context}>"
end

#participants(sid = :unset) ⇒ ParticipantList, ParticipantContext

Access the participants

Returns:

Raises:

  • (ArgumentError)


313
314
315
316
317
318
319
320
321
322
323
324
325
# File 'lib/twilio-ruby/rest/video/v1/room.rb', line 313

def participants(sid=:unset)
  raise ArgumentError, 'sid cannot be nil' if sid.nil?

  if sid != :unset
    return ParticipantContext.new(@version, @solution[:sid], sid, )
  end

  unless @participants
    @participants = ParticipantList.new(@version, room_sid: @solution[:sid], )
  end

  @participants
end

#recording_rulesRecordingRulesList, RecordingRulesContext

Access the recording_rules

Returns:



331
332
333
334
335
336
337
# File 'lib/twilio-ruby/rest/video/v1/room.rb', line 331

def recording_rules
  unless @recording_rules
    @recording_rules = RecordingRulesList.new(@version, room_sid: @solution[:sid], )
  end

  @recording_rules
end

#recordings(sid = :unset) ⇒ RoomRecordingList, RoomRecordingContext

Access the recordings

Returns:

Raises:

  • (ArgumentError)


295
296
297
298
299
300
301
302
303
304
305
306
307
# File 'lib/twilio-ruby/rest/video/v1/room.rb', line 295

def recordings(sid=:unset)
  raise ArgumentError, 'sid cannot be nil' if sid.nil?

  if sid != :unset
    return RoomRecordingContext.new(@version, @solution[:sid], sid, )
  end

  unless @recordings
    @recordings = RoomRecordingList.new(@version, room_sid: @solution[:sid], )
  end

  @recordings
end

#to_sObject

Provide a user friendly representation



341
342
343
344
# File 'lib/twilio-ruby/rest/video/v1/room.rb', line 341

def to_s
  context = @solution.map {|k, v| "#{k}: #{v}"}.join(',')
  "#<Twilio.Video.V1.RoomContext #{context}>"
end

#update(status: nil) ⇒ RoomInstance

Update the RoomInstance

Parameters:

  • status (room.RoomStatus) (defaults to: nil)

    The new status of the resource. Set to ‘completed` to end the room.

Returns:



283
284
285
286
287
288
289
# File 'lib/twilio-ruby/rest/video/v1/room.rb', line 283

def update(status: nil)
  data = Twilio::Values.of({'Status' => status, })

  payload = @version.update('POST', @uri, data: data)

  RoomInstance.new(@version, payload, sid: @solution[:sid], )
end