/************************************************************************************ * * D++, A Lightweight C++ library for Discord * * SPDX-License-Identifier: Apache-2.0 * Copyright 2021 Craig Edwards and D++ contributors * (https://github.com/brainboxdotcc/DPP/graphs/contributors) * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * ************************************************************************************/ #pragma once #include #include #include #include #include #include namespace dpp { /** * @brief Possible types of preset filter lists */ enum automod_preset_type : uint8_t { /** * @brief Strong swearing */ amod_preset_profanity = 1, /** * @brief Sexual phrases and words */ amod_preset_sexual_content = 2, /** * @brief Racial and other slurs, hate speech */ amod_preset_slurs = 3, }; /** * @brief Action types to perform on filtering */ enum automod_action_type : uint8_t { /** * @brief Blocks the message and prevents it from being posted. * A custom explanation can be specified and shown to members whenever their message is blocked */ amod_action_block_message = 1, /** * @brief Send an alert to a given channel */ amod_action_send_alert = 2, /** * @brief timeout the user * @note Can only be set up for rules with trigger types of dpp::amod_type_keyword and dpp::amod_type_mention_spam */ amod_action_timeout = 3, }; /** * @brief Event types, only message send is currently supported */ enum automod_event_type : uint8_t { /** * @brief Trigger on message send or edit */ amod_message_send = 1, }; /** * @brief Types of moderation to trigger */ enum automod_trigger_type : uint8_t { /** * @brief Check if content contains words from a user defined list of keywords (max 6 of this type per guild) */ amod_type_keyword = 1, /** * @brief Harmful/malware links * @deprecated Removed by Discord */ amod_type_harmful_link = 2, /** * @brief Check if content represents generic spam (max 1 of this type per guild) */ amod_type_spam = 3, /** * @brief Check if content contains words from discord pre-defined wordsets (max 1 of this type per guild) */ amod_type_keyword_preset = 4, /** * @brief Check if content contains more mentions than allowed (max 1 of this type per guild) */ amod_type_mention_spam = 5, }; /** * @brief Metadata associated with an automod action. Different fields are relevant based on the value of dpp::automod_rule::trigger_type. */ struct DPP_EXPORT automod_metadata : public json_interface { protected: friend struct json_interface; /** * @brief Fill object properties from JSON * * @param j JSON to fill from * @return automod_metadata& Reference to self */ automod_metadata& fill_from_json_impl(nlohmann::json* j); /** * @brief Build a json for this object * * @return json JSON object */ virtual json to_json_impl(bool with_id = false) const; public: /** * @brief @brief Substrings which will be searched for in content (Maximum of 1000). * * Each keyword can be a phrase which contains multiple words. * All keywords are case insensitive and can be up to 60 characters. * * Wildcard symbols (`*`) can be used to customize how each keyword will be matched. * * **Examples for the `*` wildcard symbol:** * * Prefix - word must start with the keyword * * | keyword | matches | * |----------|-------------------------------------| * | cat* | catch, Catapult, CAttLE | * | the mat* | the matrix | * * Suffix - word must end with the keyword * * | keyword | matches | * |----------|--------------------------| * | *cat | wildcat, copyCat | * | *the mat | breathe mat | * * Anywhere - keyword can appear anywhere in the content * * | keyword | matches | * |-----------|-----------------------------| * | \*cat* | location, eduCation | * | \*the mat* | breathe matter | * * Whole Word - keyword is a full word or phrase and must be surrounded by whitespace at the beginning and end * * | keyword | matches | * |---------|-------------| * | cat | Cat | * | the mat | the mat | * */ std::vector keywords; /** * @brief Regular expression patterns which will be matched against content (Maximum of 10). * * Only Rust flavored regex is currently supported, which can be tested in online editors such as [Rustexp](https://rustexp.lpil.uk/). * Each regex pattern can be up to 260 characters. */ std::vector regex_patterns; /** * @brief Preset keyword list types to moderate * @see automod_preset_type */ std::vector presets; /** * @brief Substrings which should not trigger the rule (Maximum of 100 for the trigger type dpp::amod_type_keyword, Maximum of 1000 for the trigger type dpp::amod_type_keyword_preset). * * Each keyword can be a phrase which contains multiple words. * All keywords are case insensitive and can be up to 60 characters. * * Wildcard symbols (`*`) can be used to customize how each keyword will be matched. * * **Examples for the `*` wildcard symbol:** * * Prefix - word must start with the keyword * * | keyword | matches | * |----------|-------------------------------------| * | cat* | catch, Catapult, CAttLE | * | the mat* | the matrix | * * Suffix - word must end with the keyword * * | keyword | matches | * |----------|--------------------------| * | *cat | wildcat, copyCat | * | *the mat | breathe mat | * * Anywhere - keyword can appear anywhere in the content * * | keyword | matches | * |-----------|-----------------------------| * | \*cat* | location, eduCation | * | \*the mat* | breathe matter | * * Whole Word - keyword is a full word or phrase and must be surrounded by whitespace at the beginning and end * * | keyword | matches | * |---------|-------------| * | cat | Cat | * | the mat | the mat | * */ std::vector allow_list; /** * @brief Total number of unique role and user mentions allowed per message (Maximum of 50) */ uint8_t mention_total_limit; /** * @brief Whether to automatically detect mention raids */ bool mention_raid_protection_enabled; /** * @brief Construct a new automod metadata object */ automod_metadata(); /** * @brief Destroy the automod metadata object */ virtual ~automod_metadata(); }; /** * @brief Represents an automod action */ struct DPP_EXPORT automod_action : public json_interface { protected: friend struct json_interface; /** * @brief Fill object properties from JSON * * @param j JSON to fill from * @return automod_action& Reference to self */ automod_action& fill_from_json_impl(nlohmann::json* j); /** * @brief Build a json for this object * * @return json JSON object */ virtual json to_json_impl(bool with_id = false) const; public: /** * @brief Type of action to take */ automod_action_type type; /** * @brief Channel ID to which user content should be logged, for type dpp::amod_action_send_alert */ snowflake channel_id; /** * @brief Additional explanation that will be shown to members whenever their message is blocked. For type dpp::amod_action_block_message */ std::string custom_message; /** * @brief Timeout duration in seconds (Maximum of 2419200), for dpp::amod_action_timeout */ uint32_t duration_seconds; /** * @brief Construct a new automod action object */ automod_action(); /** * @brief Destroy the automod action object */ virtual ~automod_action(); }; /** * @brief Represents an automod rule */ class DPP_EXPORT automod_rule : public managed, public json_interface { protected: friend struct json_interface; /** * @brief Fill object properties from JSON * * @param j JSON to fill from * @return automod_rule& Reference to self */ automod_rule& fill_from_json_impl(nlohmann::json* j); /** * @brief Build a json string for this object * * @return json JSON object */ virtual json to_json_impl(bool with_id = false) const; public: /** * @brief the id of this rule */ snowflake id; /** * @brief the guild which this rule belongs to */ snowflake guild_id; /** * @brief the rule name */ std::string name; /** * @brief The user which first created this rule */ snowflake creator_id; /** * @brief The rule event type */ automod_event_type event_type; /** * @brief The rule trigger type */ automod_trigger_type trigger_type; /** * @brief The rule trigger metadata */ automod_metadata trigger_metadata; /** * @brief the actions which will execute when the rule is triggered */ std::vector actions; /** * @brief Whether the rule is enabled */ bool enabled; /** * @brief the role ids that should not be affected by the rule (Maximum of 20) */ std::vector exempt_roles; /** * @brief the channel ids that should not be affected by the rule (Maximum of 50) */ std::vector exempt_channels; /** * @brief Construct a new automod rule object */ automod_rule(); /** * @brief Destroy the automod rule object */ virtual ~automod_rule(); }; /** A group of automod rules. */ typedef std::unordered_map automod_rule_map; } // namespace dpp