Class: Rubycord::Webhooks::Client
- Inherits:
-
Object
- Object
- Rubycord::Webhooks::Client
- Defined in:
- lib/rubycord/webhooks/client.rb
Overview
A client for a particular webhook added to a Discord channel.
Instance Method Summary collapse
-
#delete(reason: nil) ⇒ RestClient::Response
Delete this webhook.
-
#delete_message(message_id) ⇒ RestClient::Response
Delete a message created by this webhook.
-
#edit_message(message_id, builder: nil, content: nil, embeds: nil, allowed_mentions: nil) {|builder| ... } ⇒ RestClient::Response
Edit a message from this webhook.
-
#execute(builder = nil, wait = false, components = nil) {|builder| ... } ⇒ RestClient::Response
Executes the webhook this client points to with the given data.
-
#initialize(url: nil, id: nil, token: nil) ⇒ Client
constructor
Create a new webhook.
-
#modify(name: nil, avatar: nil, channel_id: nil) ⇒ RestClient::Response
Modify this webhook’s properties.
Constructor Details
#initialize(url: nil, id: nil, token: nil) ⇒ Client
Create a new webhook
15 16 17 |
# File 'lib/rubycord/webhooks/client.rb', line 15 def initialize(url: nil, id: nil, token: nil) @url = url || generate_url(id, token) end |
Instance Method Details
#delete(reason: nil) ⇒ RestClient::Response
Note:
This is permanent and cannot be undone.
Delete this webhook.
70 71 72 |
# File 'lib/rubycord/webhooks/client.rb', line 70 def delete(reason: nil) RestClient.delete(@url, "X-Audit-Log-Reason": reason) end |
#delete_message(message_id) ⇒ RestClient::Response
Delete a message created by this webhook.
102 103 104 |
# File 'lib/rubycord/webhooks/client.rb', line 102 def () RestClient.delete("#{@url}/messages/#{}") end |
#edit_message(message_id, builder: nil, content: nil, embeds: nil, allowed_mentions: nil) {|builder| ... } ⇒ RestClient::Response
Note:
Not all builder options are available when editing.
Edit a message from this webhook.
90 91 92 93 94 95 96 97 |
# File 'lib/rubycord/webhooks/client.rb', line 90 def (, builder: nil, content: nil, embeds: nil, allowed_mentions: nil) builder ||= Builder.new yield builder if block_given? data = builder.to_json_hash.merge({content: content, embeds: , allowed_mentions: allowed_mentions}.compact) RestClient.patch("#{@url}/messages/#{}", data.compact.to_json, content_type: :json) end |
#execute(builder = nil, wait = false, components = nil) {|builder| ... } ⇒ RestClient::Response
Executes the webhook this client points to with the given data.
39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 |
# File 'lib/rubycord/webhooks/client.rb', line 39 def execute(builder = nil, wait = false, components = nil) raise TypeError, "builder needs to be nil or like a Rubycord::Webhooks::Builder!" if !(builder.respond_to?(:file) && builder.respond_to?(:to_multipart_hash)) && !builder.respond_to?(:to_json_hash) && !builder.nil? builder ||= Builder.new view = View.new yield(builder, view) if block_given? components ||= view if builder.file post_multipart(builder, components, wait) else post_json(builder, components, wait) end end |
#modify(name: nil, avatar: nil, channel_id: nil) ⇒ RestClient::Response
Modify this webhook’s properties.
62 63 64 |
# File 'lib/rubycord/webhooks/client.rb', line 62 def modify(name: nil, avatar: nil, channel_id: nil) RestClient.patch(@url, {name: name, avatar: avatarise(avatar), channel_id: channel_id}.compact.to_json, content_type: :json) end |