Class: Discordrb::Channel

Inherits:
Object
  • Object
show all
Defined in:
lib/discordrb/data.rb

Overview

A Discord channel, including data like the topic

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(data, bot, server = nil) ⇒ Channel

Returns a new instance of Channel.



332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
# File 'lib/discordrb/data.rb', line 332

def initialize(data, bot, server = nil)
  @bot = bot

  # data is a sometimes a Hash and othertimes an array of Hashes, you only want the last one if it's an array
  data = data[-1] if data.is_a?(Array)

  @id = data['id'].to_i
  @type = data['type'] || 'text'
  @topic = data['topic']
  @position = data['position']

  @is_private = data['is_private']
  if @is_private
    @recipient = User.new(data['recipient'], bot)
    @name = @recipient.username
  else
    @name = data['name']
    @server = bot.server(data['guild_id'].to_i)
    @server ||= server
  end

  # Populate permission overwrites
  @permission_overwrites = {}
  return unless data['permission_overwrites']
  data['permission_overwrites'].each do |element|
    role_id = element['id'].to_i
    deny = Permissions.new(element['deny'])
    allow = Permissions.new(element['allow'])
    @permission_overwrites[role_id] = OpenStruct.new
    @permission_overwrites[role_id].deny = deny
    @permission_overwrites[role_id].allow = allow
  end
end

Instance Attribute Details

#idObject (readonly)

Returns the value of attribute id.



326
327
328
# File 'lib/discordrb/data.rb', line 326

def id
  @id
end

#is_privateObject (readonly)

Returns the value of attribute is_private.



326
327
328
# File 'lib/discordrb/data.rb', line 326

def is_private
  @is_private
end

#nameObject

Returns the value of attribute name.



326
327
328
# File 'lib/discordrb/data.rb', line 326

def name
  @name
end

#permission_overwritesObject (readonly)

Returns the value of attribute permission_overwrites.



326
327
328
# File 'lib/discordrb/data.rb', line 326

def permission_overwrites
  @permission_overwrites
end

#positionObject

Returns the value of attribute position.



326
327
328
# File 'lib/discordrb/data.rb', line 326

def position
  @position
end

#recipientObject (readonly)

Returns the value of attribute recipient.



326
327
328
# File 'lib/discordrb/data.rb', line 326

def recipient
  @recipient
end

#serverObject (readonly)

Returns the value of attribute server.



326
327
328
# File 'lib/discordrb/data.rb', line 326

def server
  @server
end

#topicObject

Returns the value of attribute topic.



326
327
328
# File 'lib/discordrb/data.rb', line 326

def topic
  @topic
end

#typeObject (readonly)

Returns the value of attribute type.



326
327
328
# File 'lib/discordrb/data.rb', line 326

def type
  @type
end

Instance Method Details

#==(other) ⇒ Object

ID based comparison



367
368
369
# File 'lib/discordrb/data.rb', line 367

def ==(other)
  Discordrb.id_compare(@id, other)
end

#await(key, attributes = {}, &block) ⇒ Object

Add an await for a message in this channel



427
428
429
# File 'lib/discordrb/data.rb', line 427

def await(key, attributes = {}, &block)
  @bot.add_await(key, Discordrb::Events::MessageEvent, { in: @id }.merge(attributes), &block)
end

#deleteObject



379
380
381
# File 'lib/discordrb/data.rb', line 379

def delete
  API.delete_channel(@bot.token, @id)
end

#history(amount, before_id = nil, after_id = nil) ⇒ Object



417
418
419
420
# File 'lib/discordrb/data.rb', line 417

def history(amount, before_id = nil, after_id = nil)
  logs = API.channel_log(@bot.token, @id, amount, before_id, after_id)
  JSON.parse(logs).map { |message| Message.new(message, @bot) }
end

#make_invite(max_age = 0, max_uses = 0, temporary = false, xkcd = false) ⇒ Object Also known as: invite



431
432
433
434
# File 'lib/discordrb/data.rb', line 431

def make_invite(max_age = 0, max_uses = 0, temporary = false, xkcd = false)
  response = API.create_invite(@bot.token, @id, max_age, max_uses, temporary, xkcd)
  Invite.new(JSON.parse(response), @bot)
end

#private?Boolean

Returns:

  • (Boolean)


328
329
330
# File 'lib/discordrb/data.rb', line 328

def private?
  @server.nil?
end

#send_file(file) ⇒ Object



375
376
377
# File 'lib/discordrb/data.rb', line 375

def send_file(file)
  @bot.send_file(@id, file)
end

#send_message(content) ⇒ Object Also known as: send, message



371
372
373
# File 'lib/discordrb/data.rb', line 371

def send_message(content)
  @bot.send_message(@id, content)
end

#start_typingObject

Starts typing, which displays the typing indicator on the client for five seconds. If you want to keep typing you'll have to resend this every five seconds. (An abstraction for this will eventually be coming)



439
440
441
# File 'lib/discordrb/data.rb', line 439

def start_typing
  API.start_typing(@bot.token, @id)
end

#update_from(other) ⇒ Object



398
399
400
401
402
403
404
# File 'lib/discordrb/data.rb', line 398

def update_from(other)
  @topic = other.topic
  @name = other.name
  @is_private = other.is_private
  @recipient = other.recipient
  @permission_overwrites = other.permission_overwrites
end

#update_overwrites(overwrites) ⇒ Object



422
423
424
# File 'lib/discordrb/data.rb', line 422

def update_overwrites(overwrites)
  @permission_overwrites = overwrites
end

#usersObject

List of users currently in a channel



407
408
409
410
411
412
413
414
415
# File 'lib/discordrb/data.rb', line 407

def users
  if @type == 'text'
    @server.members.select { |u| u.status != :offline }
  else
    @server.members.select do |user|
      user.voice_channel.id == @id if user.voice_channel
    end
  end
end