Class: Discorb::StageChannel
- Inherits:
-
GuildChannel
- Object
- DiscordModel
- Channel
- GuildChannel
- Discorb::StageChannel
- Includes:
- Connectable
- Defined in:
- lib/discorb/channel.rb
Overview
Represents a stage channel.
Instance Attribute Summary collapse
-
#bitrate -> Integer
readonly
The bitrate of the voice channel.
-
#user_limit -> Integer
readonly
The user limit of the voice channel.
Attributes inherited from GuildChannel
#permission_overwrites, #position
Attributes inherited from Channel
Instance Method Summary collapse
-
#edit(name: :unset, position: :unset, bitrate: :unset, rtc_region: :unset, reason: nil) -> self
(also: #modify)
Edit the stage channel.
-
#fetch_stage_instance -> StageInstance?
Fetch a current stage instance.
- #stage_instance -> Object
-
#start(topic, public: false, reason: nil) -> Discorb::StageInstance
Start a stage instance.
Methods included from Connectable
Methods inherited from GuildChannel
#<=>, #==, #delete!, #guild, #inspect, #mention, #move, #parent, #to_s
Methods inherited from Channel
Methods inherited from DiscordModel
Instance Attribute Details
#bitrate -> Integer (readonly)
Returns The bitrate of the voice channel.
697 698 699 |
# File 'lib/discorb/channel.rb', line 697 def bitrate @bitrate end |
#user_limit -> Integer (readonly)
Returns The user limit of the voice channel.
699 700 701 |
# File 'lib/discorb/channel.rb', line 699 def user_limit @user_limit end |
Instance Method Details
#edit(name: :unset, position: :unset, bitrate: :unset, rtc_region: :unset, reason: nil) -> self Also known as: modify
This is an asynchronous method, it will return a Async::Task
object. Use Async::Task#wait
to get the result.
This method calls HTTP request.
The arguments of this method are defaultly set to :unset
. Specify value to set the value, if not don't specify or specify :unset
.
Edit the stage channel.
733 734 735 736 737 738 739 740 741 742 743 |
# File 'lib/discorb/channel.rb', line 733 def edit(name: :unset, position: :unset, bitrate: :unset, rtc_region: :unset, reason: nil) Async do payload = {} payload[:name] = name if name != :unset payload[:position] = position if position != :unset payload[:bitrate] = bitrate if bitrate != :unset payload[:rtc_region] = rtc_region if rtc_region != :unset @client.http.patch("/channels/#{@id}", payload, audit_log_reason: reason).wait self end end |
#fetch_stage_instance -> StageInstance?
This is an asynchronous method, it will return a Async::Task
object. Use Async::Task#wait
to get the result.
This method calls HTTP request.
Fetch a current stage instance.
773 774 775 776 777 778 779 780 781 |
# File 'lib/discorb/channel.rb', line 773 def fetch_stage_instance Async do _resp, data = @client.http.get("/stage-instances/#{@id}").wait rescue Discorb::NotFoundError nil else StageInstance.new(@client, data) end end |
#stage_instance -> Object
715 716 717 |
# File 'lib/discorb/channel.rb', line 715 def stage_instance @stage_instances[0] end |
#start(topic, public: false, reason: nil) -> Discorb::StageInstance
This is an asynchronous method, it will return a Async::Task
object. Use Async::Task#wait
to get the result.
This method calls HTTP request.
Start a stage instance.
758 759 760 761 762 763 |
# File 'lib/discorb/channel.rb', line 758 def start(topic, public: false, reason: nil) Async do _resp, data = @client.http.post("/stage-instances", { channel_id: @id, topic: topic, public: public ? 2 : 1 }, audit_log_reason: reason).wait StageInstance.new(@client, data) end end |