1
0
mirror of https://github.com/VCMP-SqMod/SqMod.git synced 2025-01-19 03:57:14 +01:00
SqMod/vendor/DPP/include/dpp/scheduled_event.h
Sandu Liviu Catalin cbd8f8b028 Add D++ library.
2023-03-23 20:20:44 +02:00

225 lines
6.5 KiB
C++

/************************************************************************************
*
* D++, A Lightweight C++ library for Discord
*
* 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 <dpp/export.h>
#include <dpp/snowflake.h>
#include <dpp/managed.h>
#include <dpp/user.h>
#include <dpp/guild.h>
#include <dpp/json_fwd.h>
#include <dpp/json_interface.h>
namespace dpp {
/**
* @brief Represents the privacy of an event
*/
enum event_privacy_level : uint8_t {
/// The event is visible to only guild members.
ep_guild_only = 2
};
/**
* @brief Event entity types
*/
enum event_entity_type : uint8_t {
/// A stage instance
eet_stage_instance = 1,
/// A voice channel
eet_voice = 2,
/// External to discord, or a text channel etc
eet_external = 3
};
/**
* @brief Event status types
*/
enum event_status : uint8_t {
/// Scheduled
es_scheduled = 1,
/// Active now
es_active = 2,
/// Completed
es_completed = 3,
/// Cancelled
es_cancelled = 4
};
/**
* @brief Entities for the event
*/
struct DPP_EXPORT event_entities {
/// location of the event
std::string location;
};
/**
* @brief Represents a guild member/user who has registered interest in an event
*
*/
struct DPP_EXPORT event_member {
/**
* @brief Event ID associated with
*/
snowflake guild_scheduled_event_id;
/**
* @brief User details of associated user
*
*/
dpp::user user;
/**
* @brief Member details of user on the associated guild
*/
dpp::guild_member member;
};
/**
* @brief A scheduled event
*/
struct DPP_EXPORT scheduled_event : public managed, public json_interface<scheduled_event> {
snowflake guild_id; //!< the guild id which the scheduled event belongs to
snowflake channel_id; //!< the channel id in which the scheduled event will be hosted, or null if scheduled entity type is EXTERNAL (may be empty)
snowflake creator_id; //!< Optional: the id of the user that created the scheduled event
std::string name; //!< the name of the scheduled event
std::string description; //!< Optional: the description of the scheduled event (1-1000 characters)
std::string image; //!< the image of the scheduled event (may be empty)
time_t scheduled_start_time; //!< the time the scheduled event will start
time_t scheduled_end_time; //!< the time the scheduled event will end, or null if the event does not have a scheduled time to end (may be empty)
event_privacy_level privacy_level; //!< the privacy level of the scheduled event
event_status status; //!< the status of the scheduled event
event_entity_type entity_type; //!< the type of hosting entity associated with a scheduled event, e.g. voice channel or stage channel
snowflake entity_id; //!< any additional id of the hosting entity associated with event, e.g. stage instance id) (may be empty)
event_entities entity_metadata; //!< the entity metadata for the scheduled event (may be empty)
user creator; //!< Optional: the creator of the scheduled event
uint32_t user_count; //!< Optional: the number of users subscribed to the scheduled event
/**
* @brief Create a scheduled_event object
*/
scheduled_event();
/**
* @brief Destroy the scheduled_event object
*/
~scheduled_event() = default;
/**
* @brief Set the name of the event
* Minimum length: 1, Maximum length: 100
* @param n event name
* @return scheduled_event& reference to self
* @throw dpp::length_error if length < 1
*/
scheduled_event& set_name(const std::string& n);
/**
* @brief Set the description of the event
* Minimum length: 1 (if set), Maximum length: 100
* @param d event description
* @return scheduled_event& reference to self
* @throw dpp::length_error if length < 1
*/
scheduled_event& set_description(const std::string& d);
/**
* @brief Clear the description of the event
* @return scheduled_event& reference to self
*/
scheduled_event& clear_description();
/**
* @brief Set the location of the event.
* Minimum length: 1, Maximum length: 1000
* @note Clears channel_id
* @param l event location
* @return scheduled_event& reference to self
* @throw dpp::length_error if length < 1
*/
scheduled_event& set_location(const std::string& l);
/**
* @brief Set the voice channel id of the event
* @note clears location
* @param c channel ID
* @return scheduled_event& reference to self
*/
scheduled_event& set_channel_id(snowflake c);
/**
* @brief Set the creator id of the event
* @param c creator user ID
* @return scheduled_event& reference to self
*/
scheduled_event& set_creator_id(snowflake c);
/**
* @brief Set the status of the event
* @param s status to set
* @return scheduled_event& reference to self
* @throw dpp::logic_exception if status change is not valid
*/
scheduled_event& set_status(event_status s);
/**
* @brief Set the start time of the event
* @param t starting time
* @return scheduled_event& reference to self
* @throw dpp::length_error if time is before now
*/
scheduled_event& set_start_time(time_t t);
/**
* @brief Set the end time of the event
* @param t ending time
* @return scheduled_event& reference to self
* @throw dpp::length_error if time is before now
*/
scheduled_event& set_end_time(time_t t);
/**
* @brief Serialise a scheduled_event object from json
*
* @return scheduled_event& a reference to self
*/
scheduled_event& fill_from_json(const nlohmann::json* j);
/**
* @brief Build json for this object
* @param with_id Include id field in json
*
* @return std::string Dumped json of this object
*/
virtual std::string build_json(bool with_id = false) const;
};
/**
* @brief A group of scheduled events
*/
typedef std::unordered_map<snowflake, scheduled_event> scheduled_event_map;
/**
* @brief A group of scheduled event members
*/
typedef std::unordered_map<snowflake, event_member> event_member_map;
};