From 6115edd8921f0559b69811ec7f0001c7b382394a Mon Sep 17 00:00:00 2001 From: Craig Edwards Date: Mon, 23 Sep 2024 09:20:33 +0000 Subject: [PATCH 1/3] feat: message forwarding --- include/dpp/message.h | 32 ++++++++++++++++++++++++++++++-- src/dpp/message.cpp | 10 +++++++++- 2 files changed, 39 insertions(+), 3 deletions(-) diff --git a/include/dpp/message.h b/include/dpp/message.h index 60588e11a8..44640af8d8 100644 --- a/include/dpp/message.h +++ b/include/dpp/message.h @@ -2011,6 +2011,24 @@ namespace cache_policy { }; /** + * @brief Message Reference type + */ +enum DPP_EXPORT message_ref_type : uint8_t { + /** + * A reply or crosspost + */ + mrt_default = 0, + /** + * A forwarded message + */ + mrt_forward = 1, +}; + +template struct message_snapshot { + std::vector messages; +}; + + /** * @brief Represents messages sent and received on Discord */ struct DPP_EXPORT message : public managed, json_interface { @@ -2140,6 +2158,10 @@ struct DPP_EXPORT message : public managed, json_interface { * @brief Reference to another message, e.g. a reply */ struct message_ref { + /** + * @brief Message reference type, set to 1 to forward a message + */ + message_ref_type type{mrt_default}; /** * @brief ID of the originating message. */ @@ -2162,10 +2184,15 @@ struct DPP_EXPORT message : public managed, json_interface { bool fail_if_not_exists; } message_reference; + /** + * @brief Message snapshots for a forwarded message + */ + message_snapshot message_snapshots; + /** * @brief Reference to an interaction */ - struct message_interaction_struct{ + struct message_interaction_struct { /** * @brief ID of the interaction. */ @@ -2342,9 +2369,10 @@ struct DPP_EXPORT message : public managed, json_interface { * @param _guild_id guild id to reply to (optional) * @param _channel_id channel id to reply to (optional) * @param fail_if_not_exists true if the message send should fail if these values are invalid (optional) + * @param type Type of reference * @return message& reference to self */ - message& set_reference(snowflake _message_id, snowflake _guild_id = 0, snowflake _channel_id = 0, bool fail_if_not_exists = false); + message& set_reference(snowflake _message_id, snowflake _guild_id = 0, snowflake _channel_id = 0, bool fail_if_not_exists = false, message_ref_type type = mrt_default); /** * @brief Set the allowed mentions object for pings on the message diff --git a/src/dpp/message.cpp b/src/dpp/message.cpp index 6d416f0abb..d31661f0eb 100644 --- a/src/dpp/message.cpp +++ b/src/dpp/message.cpp @@ -677,11 +677,12 @@ message::message(class cluster* o) : message() { owner = o; } -message& message::set_reference(snowflake _message_id, snowflake _guild_id, snowflake _channel_id, bool fail_if_not_exists) { +message& message::set_reference(snowflake _message_id, snowflake _guild_id, snowflake _channel_id, bool fail_if_not_exists, message_ref_type type) { message_reference.channel_id = _channel_id; message_reference.guild_id = _guild_id; message_reference.message_id = _message_id; message_reference.fail_if_not_exists = fail_if_not_exists; + message_reference.type = type; return *this; } @@ -1408,10 +1409,17 @@ message& message::fill_from_json(json* d, cache_policy_t cp) { } if (d->find("message_reference") != d->end()) { json& mr = (*d)["message_reference"]; + message_reference.type = (message_ref_type)int8_not_null(&mr, "type"); message_reference.channel_id = snowflake_not_null(&mr, "channel_id"); message_reference.guild_id = snowflake_not_null(&mr, "guild_id"); message_reference.message_id = snowflake_not_null(&mr, "message_id"); message_reference.fail_if_not_exists = bool_not_null(&mr, "fail_if_not_exists"); + + if (message_reference.type == mrt_forward) { + for (auto& e : (*d)["message_snapshots"]) { + message_snapshots.messages.emplace_back(message().fill_from_json(e["message"], cp)); + } + } } if (auto it = d->find("poll"); it != d->end()) { from_json(*it, attached_poll.emplace()); From 78d8d119722333742fde218f7b628db4869725bc Mon Sep 17 00:00:00 2001 From: Craig Edwards Date: Mon, 23 Sep 2024 09:21:51 +0000 Subject: [PATCH 2/3] fix: forgot pointer --- src/dpp/message.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/dpp/message.cpp b/src/dpp/message.cpp index d31661f0eb..044bbcddc9 100644 --- a/src/dpp/message.cpp +++ b/src/dpp/message.cpp @@ -1417,7 +1417,7 @@ message& message::fill_from_json(json* d, cache_policy_t cp) { if (message_reference.type == mrt_forward) { for (auto& e : (*d)["message_snapshots"]) { - message_snapshots.messages.emplace_back(message().fill_from_json(e["message"], cp)); + message_snapshots.messages.emplace_back(message().fill_from_json(&(e["message"]), cp)); } } } From 8773feed0f7c97e9b39e98f83517878869b68798 Mon Sep 17 00:00:00 2001 From: Craig Edwards Date: Mon, 23 Sep 2024 10:34:53 +0000 Subject: [PATCH 3/3] fix: send type when building message --- src/dpp/message.cpp | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/dpp/message.cpp b/src/dpp/message.cpp index 044bbcddc9..8c7efa1fe4 100644 --- a/src/dpp/message.cpp +++ b/src/dpp/message.cpp @@ -1120,6 +1120,7 @@ json message::to_json(bool with_id, bool is_interaction_response) const { /* Populate message reference */ if (message_reference.channel_id || message_reference.guild_id || message_reference.message_id) { j["message_reference"] = json::object(); + j["message_reference"]["type"] = static_cast(message_reference.type); if (message_reference.channel_id) { j["message_reference"]["channel_id"] = std::to_string(message_reference.channel_id); } @@ -1409,7 +1410,7 @@ message& message::fill_from_json(json* d, cache_policy_t cp) { } if (d->find("message_reference") != d->end()) { json& mr = (*d)["message_reference"]; - message_reference.type = (message_ref_type)int8_not_null(&mr, "type"); + message_reference.type = static_cast(int8_not_null(&mr, "type")); message_reference.channel_id = snowflake_not_null(&mr, "channel_id"); message_reference.guild_id = snowflake_not_null(&mr, "guild_id"); message_reference.message_id = snowflake_not_null(&mr, "message_id");