mirror of
https://github.com/diamondburned/arikawa.git
synced 2024-11-01 04:24:19 +00:00
acbed83ca7
* Add initial implementation for automoderator api * Move AutoModerationRuleID to snowflake.go and go generate * Combine a struct and document all the things * Add audit log reasons to modify and delete in automoderation * Update docstrings and change how data is passed in * Rename plurals to singulars and update data stuff * fixup * Update to use optional * Move params out of data * fixup and add types
88 lines
3.8 KiB
Go
88 lines
3.8 KiB
Go
package api
|
|
|
|
import (
|
|
"github.com/diamondburned/arikawa/v3/discord"
|
|
"github.com/diamondburned/arikawa/v3/utils/httputil"
|
|
"github.com/diamondburned/arikawa/v3/utils/json/option"
|
|
)
|
|
|
|
// ListAutoModerationRules gets a list of all rules currently configured for the guild. Returns a list of auto moderation rule objects for the given guild.
|
|
//
|
|
// This endpoint requires the MANAGE_GUILD permission.
|
|
func (c *Client) ListAutoModerationRules(guildID discord.GuildID) ([]discord.AutoModerationRule, error) {
|
|
var rules []discord.AutoModerationRule
|
|
return rules, c.RequestJSON(
|
|
&rules, "GET",
|
|
EndpointGuilds+guildID.String()+"/auto-moderation/rules",
|
|
)
|
|
}
|
|
|
|
// GetAutoModerationRule gets a single rule. Returns an auto moderation rule object.
|
|
//
|
|
// This endpoint requires the MANAGE_GUILD permission.
|
|
func (c *Client) GetAutoModerationRule(guildID discord.GuildID, ruleID discord.AutoModerationRuleID) (discord.AutoModerationRule, error) {
|
|
var rule discord.AutoModerationRule
|
|
return rule, c.RequestJSON(
|
|
&rule, "GET",
|
|
EndpointGuilds+guildID.String()+"/auto-moderation/rules/"+ruleID.String(),
|
|
)
|
|
}
|
|
|
|
// CreateAutoModerationRule creates a new rule. Returns an auto moderation rule on success. Fires an Auto Moderation Rule Create Gateway event.
|
|
//
|
|
// This endpoint requires the MANAGE_GUILD permission.
|
|
//
|
|
// This endpoint supports the X-Audit-Log-Reason header.
|
|
func (c *Client) CreateAutoModerationRule(guildID discord.GuildID, rule discord.AutoModerationRule) (*discord.AutoModerationRule, error) {
|
|
var ret *discord.AutoModerationRule
|
|
return ret, c.RequestJSON(&ret, "POST", EndpointGuilds+guildID.String()+"/auto-moderation/rules",
|
|
httputil.WithJSONBody(rule),
|
|
)
|
|
}
|
|
|
|
type ModifyAutoModerationRuleData struct {
|
|
// the rule name
|
|
Name option.String `json:"name,omitempty"`
|
|
// the event type
|
|
EventType option.Optional[discord.AutoModerationEventType] `json:"event_type,omitempty"`
|
|
// the trigger metadata
|
|
TriggerMetadata option.Optional[discord.AutoModerationTriggerMetadata] `json:"triggr_metadata,omitempty"`
|
|
// the actions which will execute when the rule is triggered
|
|
Actions option.Optional[[]discord.AutoModerationAction] `json:"actions,omitempty"`
|
|
// whether the rule is enabled
|
|
Enabled option.Bool `json:"enabled,omitempty"`
|
|
// the role ids that should not be affected by the rule (Maximum of 20)
|
|
ExemptRules option.Optional[[]discord.RoleID] `json:"exempt_roles,omitempty"`
|
|
// the channel ids that should not be affected by the rule (Maximum of 50)
|
|
ExemptChannels option.Optional[[]discord.ChannelID] `json:"exempt_channels,omitempty"`
|
|
AuditLogReason
|
|
}
|
|
|
|
// ModifyAutoModerationRule modifies an existing rule. Returns an auto moderation rule on success. Fires an Auto Moderation Rule Update Gateway event.
|
|
//
|
|
// Requires MANAGE_GUILD permissions.
|
|
//
|
|
// All parameters for this endpoint are optional.
|
|
//
|
|
// This endpoint supports the X-Audit-Log-Reason header.
|
|
func (c *Client) ModifyAutoModerationRule(GuildID discord.GuildID, RuleID discord.AutoModerationRuleID, data ModifyAutoModerationRuleData) (*discord.AutoModerationRule, error) {
|
|
var ret *discord.AutoModerationRule
|
|
return ret, c.RequestJSON(&ret, "PATCH", EndpointGuilds+GuildID.String()+"/auto-moderation/rules/"+RuleID.String(),
|
|
httputil.WithJSONBody(data),
|
|
httputil.WithHeaders(data.Header()),
|
|
)
|
|
}
|
|
|
|
type DeleteAutoModerationRuleData struct {
|
|
AuditLogReason `json:"-"`
|
|
}
|
|
|
|
// DeleteAutoModerationRule deletes a rule. Returns a 204 on success. Fires an Auto Moderation Rule Delete Gateway event.
|
|
//
|
|
// This endpoint requires the MANAGE_GUILD permission.
|
|
//
|
|
// This endpoint supports the X-Audit-Log-Reason header.
|
|
func (c *Client) DeleteAutoModerationRule(GuildID discord.GuildID, RuleID discord.AutoModerationRuleID, data DeleteAutoModerationRuleData) error {
|
|
return c.FastRequest("DELETE", EndpointGuilds+GuildID.String()+"/auto-moderation/rules/"+RuleID.String(), httputil.WithHeaders(data.Header()))
|
|
}
|