Merge pull request #762 from diamante0018/develop
[Discord]: Add invites
This commit is contained in:
commit
62578b4e23
@ -10,6 +10,12 @@ namespace Components
|
|||||||
|
|
||||||
bool Discord::Initialized_;
|
bool Discord::Initialized_;
|
||||||
|
|
||||||
|
static unsigned int GetDiscordNonce()
|
||||||
|
{
|
||||||
|
static auto nonce = Utils::Cryptography::Rand::GenerateInt();
|
||||||
|
return nonce;
|
||||||
|
}
|
||||||
|
|
||||||
static void Ready([[maybe_unused]] const DiscordUser* request)
|
static void Ready([[maybe_unused]] const DiscordUser* request)
|
||||||
{
|
{
|
||||||
ZeroMemory(&DiscordPresence, sizeof(DiscordPresence));
|
ZeroMemory(&DiscordPresence, sizeof(DiscordPresence));
|
||||||
@ -21,6 +27,11 @@ namespace Components
|
|||||||
Discord_UpdatePresence(&DiscordPresence);
|
Discord_UpdatePresence(&DiscordPresence);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void JoinGame(const char* joinSecret)
|
||||||
|
{
|
||||||
|
Game::Cbuf_AddText(0, Utils::String::VA("connect %s\n", joinSecret));
|
||||||
|
}
|
||||||
|
|
||||||
static void Errored(const int errorCode, const char* message)
|
static void Errored(const int errorCode, const char* message)
|
||||||
{
|
{
|
||||||
Logger::Print(Game::CON_CHANNEL_ERROR, "Discord: Error (%i): %s\n", errorCode, message);
|
Logger::Print(Game::CON_CHANNEL_ERROR, "Discord: Error (%i): %s\n", errorCode, message);
|
||||||
@ -75,7 +86,12 @@ namespace Components
|
|||||||
DiscordPresence.state = hostNameBuffer;
|
DiscordPresence.state = hostNameBuffer;
|
||||||
}
|
}
|
||||||
|
|
||||||
DiscordPresence.partySize = 0;
|
std::hash<Network::Address> hashFn;
|
||||||
|
const auto address = Party::Target();
|
||||||
|
|
||||||
|
DiscordPresence.partyId = Utils::String::VA("%zu", hashFn(address) ^ GetDiscordNonce());
|
||||||
|
DiscordPresence.joinSecret = address.getCString();
|
||||||
|
DiscordPresence.partySize = Game::cgArray[0].snap->numClients;
|
||||||
DiscordPresence.partyMax = Party::GetMaxClients();
|
DiscordPresence.partyMax = Party::GetMaxClients();
|
||||||
|
|
||||||
if (!DiscordPresence.startTimestamp)
|
if (!DiscordPresence.startTimestamp)
|
||||||
@ -100,7 +116,7 @@ namespace Components
|
|||||||
handlers.ready = Ready;
|
handlers.ready = Ready;
|
||||||
handlers.errored = Errored;
|
handlers.errored = Errored;
|
||||||
handlers.disconnected = Errored;
|
handlers.disconnected = Errored;
|
||||||
handlers.joinGame = nullptr;
|
handlers.joinGame = JoinGame;
|
||||||
handlers.spectateGame = nullptr;
|
handlers.spectateGame = nullptr;
|
||||||
handlers.joinRequest = nullptr;
|
handlers.joinRequest = nullptr;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user