summaryrefslogtreecommitdiff
path: root/discord
diff options
context:
space:
mode:
authorouwou <26526779+ouwou@users.noreply.github.com>2021-05-09 01:22:37 -0400
committerouwou <26526779+ouwou@users.noreply.github.com>2021-05-09 01:22:37 -0400
commitbf26e49f2c7868f5bfdeea30db9e0fb3a7af440d (patch)
tree28bd5c547db16a903d59863452ea79e5e44f7f8d /discord
parenta781cc76a01d56244fd6caeb23ab67caf2424819 (diff)
parent925405826a23527a17b6a5ce1917dcd5507c0b38 (diff)
downloadabaddon-portaudio-bf26e49f2c7868f5bfdeea30db9e0fb3a7af440d.tar.gz
abaddon-portaudio-bf26e49f2c7868f5bfdeea30db9e0fb3a7af440d.zip
Merge branch 'master' into friends
Diffstat (limited to 'discord')
-rw-r--r--discord/discord.cpp15
-rw-r--r--discord/discord.hpp6
-rw-r--r--discord/objects.cpp6
-rw-r--r--discord/objects.hpp11
4 files changed, 37 insertions, 1 deletions
diff --git a/discord/discord.cpp b/discord/discord.cpp
index 1869a59..21e2780 100644
--- a/discord/discord.cpp
+++ b/discord/discord.cpp
@@ -1042,6 +1042,9 @@ void DiscordClient::HandleGatewayMessage(std::string str) {
case GatewayEvent::RELATIONSHIP_REMOVE: {
HandleGatewayRelationshipRemove(m);
} break;
+ case GatewayEvent::RELATIONSHIP_ADD: {
+ HandleGatewayRelationshipAdd(m);
+ } break;
}
} break;
default:
@@ -1489,6 +1492,13 @@ void DiscordClient::HandleGatewayRelationshipRemove(const GatewayMessage &msg) {
m_signal_relationship_remove.emit(data.ID, data.Type);
}
+void DiscordClient::HandleGatewayRelationshipAdd(const GatewayMessage &msg) {
+ RelationshipAddData data = msg.Data;
+ m_store.SetUser(data.ID, data.User);
+ m_user_relationships[data.ID] = data.Type;
+ m_signal_relationship_add.emit(std::move(data));
+}
+
void DiscordClient::HandleGatewayReadySupplemental(const GatewayMessage &msg) {
ReadySupplementalData data = msg.Data;
for (const auto &p : data.MergedPresences.Friends) {
@@ -1825,6 +1835,7 @@ void DiscordClient::LoadEventMap() {
m_event_map["GUILD_JOIN_REQUEST_UPDATE"] = GatewayEvent::GUILD_JOIN_REQUEST_UPDATE;
m_event_map["GUILD_JOIN_REQUEST_DELETE"] = GatewayEvent::GUILD_JOIN_REQUEST_DELETE;
m_event_map["RELATIONSHIP_REMOVE"] = GatewayEvent::RELATIONSHIP_REMOVE;
+ m_event_map["RELATIONSHIP_ADD"] = GatewayEvent::RELATIONSHIP_ADD;
}
DiscordClient::type_signal_gateway_ready DiscordClient::signal_gateway_ready() {
@@ -1951,6 +1962,10 @@ DiscordClient::type_signal_relationship_remove DiscordClient::signal_relationshi
return m_signal_relationship_remove;
}
+DiscordClient::type_signal_relationship_add DiscordClient::signal_relationship_add() {
+ return m_signal_relationship_add;
+}
+
DiscordClient::type_signal_message_sent DiscordClient::signal_message_sent() {
return m_signal_message_sent;
}
diff --git a/discord/discord.hpp b/discord/discord.hpp
index ee0a8f3..a8d1503 100644
--- a/discord/discord.hpp
+++ b/discord/discord.hpp
@@ -224,6 +224,7 @@ private:
void HandleGatewayGuildJoinRequestUpdate(const GatewayMessage &msg);
void HandleGatewayGuildJoinRequestDelete(const GatewayMessage &msg);
void HandleGatewayRelationshipRemove(const GatewayMessage &msg);
+ void HandleGatewayRelationshipAdd(const GatewayMessage &msg);
void HandleGatewayReadySupplemental(const GatewayMessage &msg);
void HandleGatewayReconnect(const GatewayMessage &msg);
void HandleGatewayInvalidSession(const GatewayMessage &msg);
@@ -316,9 +317,10 @@ public:
typedef sigc::signal<void, GuildJoinRequestUpdateData> type_signal_guild_join_request_update;
typedef sigc::signal<void, GuildJoinRequestDeleteData> type_signal_guild_join_request_delete;
typedef sigc::signal<void, Snowflake, RelationshipType> type_signal_relationship_remove;
+ typedef sigc::signal<void, RelationshipAddData> type_signal_relationship_add;
typedef sigc::signal<void, Message> type_signal_message_sent;
typedef sigc::signal<void, std::string /* nonce */, float /* retry_after */> type_signal_message_send_fail; // retry after param will be 0 if it failed for a reason that isnt slowmode
- typedef sigc::signal<void, bool, GatewayCloseCode> type_signal_disconnected; // bool true if reconnecting
+ typedef sigc::signal<void, bool, GatewayCloseCode> type_signal_disconnected; // bool true if reconnecting
typedef sigc::signal<void> type_signal_connected;
type_signal_gateway_ready signal_gateway_ready();
@@ -350,6 +352,7 @@ public:
type_signal_guild_join_request_update signal_guild_join_request_update();
type_signal_guild_join_request_delete signal_guild_join_request_delete();
type_signal_relationship_remove signal_relationship_remove();
+ type_signal_relationship_add signal_relationship_add();
type_signal_message_sent signal_message_sent();
type_signal_message_send_fail signal_message_send_fail();
type_signal_disconnected signal_disconnected();
@@ -385,6 +388,7 @@ protected:
type_signal_guild_join_request_update m_signal_guild_join_request_update;
type_signal_guild_join_request_delete m_signal_guild_join_request_delete;
type_signal_relationship_remove m_signal_relationship_remove;
+ type_signal_relationship_add m_signal_relationship_add;
type_signal_message_sent m_signal_message_sent;
type_signal_message_send_fail m_signal_message_send_fail;
type_signal_disconnected m_signal_disconnected;
diff --git a/discord/objects.cpp b/discord/objects.cpp
index 9db6cf8..0d4ab16 100644
--- a/discord/objects.cpp
+++ b/discord/objects.cpp
@@ -457,3 +457,9 @@ void from_json(const nlohmann::json &j, RelationshipRemoveData &m) {
JS_D("id", m.ID);
JS_D("type", m.Type);
}
+
+void from_json(const nlohmann::json &j, RelationshipAddData &m) {
+ JS_D("id", m.ID);
+ JS_D("type", m.Type);
+ JS_D("user", m.User);
+}
diff --git a/discord/objects.hpp b/discord/objects.hpp
index 2c6ac4c..56191df 100644
--- a/discord/objects.hpp
+++ b/discord/objects.hpp
@@ -69,6 +69,7 @@ enum class GatewayEvent : int {
GUILD_JOIN_REQUEST_UPDATE,
GUILD_JOIN_REQUEST_DELETE,
RELATIONSHIP_REMOVE,
+ RELATIONSHIP_ADD,
};
enum class GatewayCloseCode : uint16_t {
@@ -634,3 +635,13 @@ struct RelationshipRemoveData {
friend void from_json(const nlohmann::json &j, RelationshipRemoveData &m);
};
+
+struct RelationshipAddData {
+ Snowflake ID;
+ // Nickname; same deal as the other comment somewhere else
+ RelationshipType Type;
+ UserData User;
+ // std::optional<bool> ShouldNotify; // i guess if the client should send a notification. not worth caring about
+
+ friend void from_json(const nlohmann::json &j, RelationshipAddData &m);
+};