Class: Discordrb::ApplicationCommand::Permission

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

Overview

An application command permission for a channel, member, or a role.

Constant Summary collapse

TYPES =

Map of permission types.

{
  role: 1,
  member: 2,
  channel: 3
}.freeze

Instance Attribute Summary collapse

Instance Method Summary collapse

Instance Attribute Details

#server_idInteger (readonly)

Returns the ID of the server this permission is for.

Returns:

  • (Integer)

    the ID of the server this permission is for.



531
532
533
# File 'lib/discordrb/data/interaction.rb', line 531

def server_id
  @server_id
end

#target_idInteger (readonly)

Returns the ID of the entity this permission is for.

Returns:

  • (Integer)

    the ID of the entity this permission is for.



528
529
530
# File 'lib/discordrb/data/interaction.rb', line 528

def target_id
  @target_id
end

#typeInteger (readonly)

Returns the type of this permission.

Returns:

  • (Integer)

    the type of this permission.

See Also:



525
526
527
# File 'lib/discordrb/data/interaction.rb', line 525

def type
  @type
end

Instance Method Details

#all_channels?true, false

Whether this permission is applied to every channel in the server.

Returns:

  • (true, false)


578
579
580
# File 'lib/discordrb/data/interaction.rb', line 578

def all_channels?
  @target_id == (@server_id - 1)
end

#allowed?true, false

Whether this permission has been allowed, e.g has a green check in the UI.

Returns:

  • (true, false)


546
547
548
# File 'lib/discordrb/data/interaction.rb', line 546

def allowed?
  @overwrite == true
end

#channel?true, false

Returns whether this permission is for a channel.

Returns:

  • (true, false)

    whether this permission is for a channel.



603
604
605
606
607
# File 'lib/discordrb/data/interaction.rb', line 603

TYPES.each do |name, value|
  define_method("#{name}?") do
    @type == value
  end
end

#command_idInteger?

Get the ID of the application command this permission is for.

Returns:

  • (Integer, nil)

    This will be nil if the permission is the default permission.



565
566
567
# File 'lib/discordrb/data/interaction.rb', line 565

def command_id
  @command_id unless default?
end

#default?true, false

Whether this permission is the default for all commands that don't contain explicit permission oerwrites.

Returns:

  • (true, false)


572
573
574
# File 'lib/discordrb/data/interaction.rb', line 572

def default?
  @command_id == @application_id
end

#denied?true, false

Whether this permission has been denied, e.g has a red X-mark in the UI.

Returns:

  • (true, false)


552
553
554
# File 'lib/discordrb/data/interaction.rb', line 552

def denied?
  @overwrite == false
end

#everyone?true, false

Whether this permission is applied to the everyone role in the server.

Returns:

  • (true, false)


558
559
560
# File 'lib/discordrb/data/interaction.rb', line 558

def everyone?
  @target_id == @server_id
end

#member?true, false

Returns whether this permission is for a member.

Returns:

  • (true, false)

    whether this permission is for a member.



603
604
605
606
607
# File 'lib/discordrb/data/interaction.rb', line 603

TYPES.each do |name, value|
  define_method("#{name}?") do
    @type == value
  end
end

#role?true, false

Returns whether this permission is for a role.

Returns:

  • (true, false)

    whether this permission is for a role.



603
604
605
606
607
# File 'lib/discordrb/data/interaction.rb', line 603

TYPES.each do |name, value|
  define_method("#{name}?") do
    @type == value
  end
end

#targetArray<Channel>, ... Also known as: targets

Get the user, role, or channel(s) that this permission targets.

Returns:



584
585
586
587
588
589
590
591
592
593
# File 'lib/discordrb/data/interaction.rb', line 584

def target
  case @type
  when TYPES[:role]
    @bot.server(@server_id).role(@target_id)
  when TYPES[:member]
    @bot.server(@server_id).member(@target_id)
  when TYPES[:channel]
    all_channels? ? @bot.server(@server_id).channels : [@bot.channel(@target_id)]
  end
end