1
0
mirror of https://github.com/VCMP-SqMod/SqMod.git synced 2025-01-19 12:07:13 +01:00
SqMod/module/Library/DPP/Role.hpp

296 lines
16 KiB
C++
Raw Normal View History

2021-09-12 17:53:57 +03:00
#pragma once
// ------------------------------------------------------------------------------------------------
#include "Core/Utility.hpp"
// ------------------------------------------------------------------------------------------------
#include <chrono>
// ------------------------------------------------------------------------------------------------
#include <dpp/dpp.h>
// ------------------------------------------------------------------------------------------------
namespace SqMod {
/* ------------------------------------------------------------------------------------------------
* Represents a role within a DpGuild.
*/
struct DpRole
{
using Ptr = std::unique_ptr< dpp::role >;
/* --------------------------------------------------------------------------------------------
* Referenced role instance.
*/
Ptr mPtr{nullptr};
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Whether the referenced pointer is owned.
2021-09-12 17:53:57 +03:00
*/
bool mOwned{false};
/* --------------------------------------------------------------------------------------------
* Default constructor.
*/
DpRole() noexcept = default;
/* --------------------------------------------------------------------------------------------
* Explicit constructor.
*/
explicit DpRole(Ptr::pointer ptr, bool owned = false) noexcept
: mPtr(ptr), mOwned(owned)
{ }
/* --------------------------------------------------------------------------------------------
* Explicit constructor.
*/
explicit DpRole(const Ptr::element_type & o) noexcept
: DpRole(new Ptr::element_type(o), true)
{ }
/* --------------------------------------------------------------------------------------------
* Move constructor.
*/
explicit DpRole(Ptr::element_type && o) noexcept
: DpRole(new Ptr::element_type(std::forward< Ptr::element_type >(o)), true)
{ }
/* --------------------------------------------------------------------------------------------
* Copy constructor (disabled).
*/
DpRole(const DpRole & o) = delete;
/* --------------------------------------------------------------------------------------------
* Move constructor.
*/
DpRole(DpRole && o) noexcept = default;
/* --------------------------------------------------------------------------------------------
* Destructor.
*/
~DpRole() noexcept
{
// Do we own this to try delete it?
if (!mOwned && mPtr) [[maybe_unused]] auto p = mPtr.release();
}
/* --------------------------------------------------------------------------------------------
* Copy assignment operator (disabled).
*/
DpRole & operator = (const DpRole & o) = delete;
/* --------------------------------------------------------------------------------------------
* Move assignment operator.
*/
DpRole & operator = (DpRole && o) noexcept
{
if (this != &o) {
// Do we own this to try delete it?
if (!mOwned && mPtr) [[maybe_unused]] auto p = mPtr.release();
// Transfer members values
mPtr = std::move(o.mPtr);
mOwned = o.mOwned;
}
return *this;
}
/* --------------------------------------------------------------------------------------------
* Validate the managed handle.
*/
void Validate() const { if (!mPtr) STHROWF("Invalid discord role handle"); }
/* --------------------------------------------------------------------------------------------
* Validate the managed handle and retrieve a const reference to it.
*/
SQMOD_NODISCARD Ptr::element_type & Valid() const { Validate(); return *mPtr; }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether a valid instance is managed.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool IsValid() const { return static_cast< bool >(mPtr); }
/* --------------------------------------------------------------------------------------------
* Retrieve role name.
*/
SQMOD_NODISCARD const std::string & GetName() const { return Valid().name; }
/* --------------------------------------------------------------------------------------------
* Retrieve the role guild id.
*/
SQMOD_NODISCARD dpp::snowflake GetGuildID() const { return Valid().guild_id; }
/* --------------------------------------------------------------------------------------------
* Retrieve the role colour.
*/
SQMOD_NODISCARD SQInteger GetColour() const { return static_cast< SQInteger >(Valid().colour); }
/* --------------------------------------------------------------------------------------------
* Retrieve the role position.
*/
SQMOD_NODISCARD SQInteger GetPosition() const { return static_cast< SQInteger >(Valid().position); }
/* --------------------------------------------------------------------------------------------
* Retrieve the role permissions bitmask values from SqDiscordRolePermissions.
*/
SQMOD_NODISCARD SQInteger GetPermissions() const { return static_cast< SQInteger >(Valid().permissions); }
/* --------------------------------------------------------------------------------------------
* Retrieve the role flags from SqDiscordRoleFlags.
*/
SQMOD_NODISCARD SQInteger GetFlags() const { return static_cast< SQInteger >(Valid().flags); }
/* --------------------------------------------------------------------------------------------
* Retrieve the role integration id if any (e.g. role is a bot's role created when it was invited).
*/
SQMOD_NODISCARD dpp::snowflake GetIntegrationID() const { return Valid().integration_id; }
/* --------------------------------------------------------------------------------------------
* Retrieve the role bot id if any (e.g. role is a bot's role created when it was invited).
*/
SQMOD_NODISCARD dpp::snowflake GetBotID() const { return Valid().bot_id; }
/* --------------------------------------------------------------------------------------------
* Build a JSON string from this object.
*/
SQMOD_NODISCARD std::string BuildJSON() const { return Valid().build_json(); }
/* --------------------------------------------------------------------------------------------
* Build a JSON string from this object. If [with_id] is True then ID is to be included in the JSON.
*/
SQMOD_NODISCARD std::string BuildJSON_(bool with_id) const { return Valid().build_json(with_id); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role is hoisted.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool IsHoisted() const { return Valid().is_hoisted(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role is mentionable.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool IsMentionable() const { return Valid().is_mentionable(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role is managed (belongs to a bot or application).
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool IsManaged() const { return Valid().is_managed(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role has create instant invite permission.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool CanCreateInstantInvite() const { return Valid().has_create_instant_invite(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role has the kick members permission.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool CanKickMembers() const { return Valid().has_kick_members(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role has the ban members permission.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool CanBanMembers() const { return Valid().has_ban_members(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role has the administrator permission.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool IsAdministrator() const { return Valid().has_administrator(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role has the manage channels permission.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool CanManageChannels() const { return Valid().has_manage_channels(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role has the manage guild permission.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool CanManageGuild() const { return Valid().has_manage_guild(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role has the add reactions permission.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool CanAddReactions() const { return Valid().has_add_reactions(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role has the view audit log permission.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool CanViewAuditLog() const { return Valid().has_view_audit_log(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role has the priority speaker permission.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool IsPrioritySpeaker() const { return Valid().has_priority_speaker(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role has the stream permission.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool CanStream() const { return Valid().has_stream(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role has the view channel permission.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool CanViewChannel() const { return Valid().has_view_channel(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role has the send messages permission.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool CanSendMessages() const { return Valid().has_send_messages(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role has the send TTS messages permission.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool CanSendTtsMessages() const { return Valid().has_send_tts_messages(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role has the manage messages permission.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool CanManageMessages() const { return Valid().has_manage_messages(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role has the embed links permission.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool CanEmbedLinks() const { return Valid().has_embed_links(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role has the attach files permission.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool CanAttachFiles() const { return Valid().has_attach_files(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role has the read message history permission.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool CanReadMessageHistory() const { return Valid().has_read_message_history(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role has the mention \@everyone and \@here permission.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool CanMentionEveryone() const { return Valid().has_mention_everyone(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role has the use external emojis permission.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool CanUseExternalEmojis() const { return Valid().has_use_external_emojis(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role has the view guild insights permission.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool CanViewGuildInsights() const { return Valid().has_view_guild_insights(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role has the connect voice permission.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool CanConnect() const { return Valid().has_connect(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role has the speak permission.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool CanSpeak() const { return Valid().has_speak(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role has the mute members permission.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool CanMuteMembers() const { return Valid().has_mute_members(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role has the deafen members permission.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool CanDeafenMembers() const { return Valid().has_deafen_members(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role has the move members permission.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool CanMoveMembers() const { return Valid().has_move_members(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role has use voice activity detection permission.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool CanUseVAT() const { return Valid().has_use_vad(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role has the change nickname permission.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool CanChangeNickname() const { return Valid().has_change_nickname(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role has the manage nicknames permission.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool CanManageNicknames() const { return Valid().has_manage_nicknames(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role has the manage roles permission.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool CanManageRoles() const { return Valid().has_manage_roles(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role has the manage webhooks permission.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool CanManageWebhooks() const { return Valid().has_manage_webhooks(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role has the manage emojis permission.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool CanManageEmojis() const { return Valid().has_manage_emojis(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role has the use slash commands permission.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool CanUseSlashCommands() const { return Valid().has_use_slash_commands(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role has the request to speak permission.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool HasRequestToSpeak() const { return Valid().has_request_to_speak(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role has the manage threads permission.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool CanManageThreads() const { return Valid().has_manage_threads(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role has the use public threads permission.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool HasUsePublicThreads() const { return Valid().has_use_public_threads(); }
/* --------------------------------------------------------------------------------------------
2021-09-12 18:51:16 +03:00
* Check whether the role has the use private threads permission.
2021-09-12 17:53:57 +03:00
*/
SQMOD_NODISCARD bool HasUsePrivateThreads() const { return Valid().has_use_private_threads(); }
};
} // Namespace:: SqMod