mirror of
https://github.com/Lime3DS/Lime3DS.git
synced 2025-01-18 01:14:20 +01:00
9d062d63da
Based on the `roles` payload in the JWT, the rooms will now give mod permission to Citra Community Moderators. To notify the client of its permissions, a new response, IdJoinSuccessAsMod is added, and there's now a new RoomMember::State called Moderator.
47 lines
1.2 KiB
C++
47 lines
1.2 KiB
C++
// Copyright 2018 Citra Emulator Project
|
|
// Licensed under GPLv2 or any later version
|
|
// Refer to the license.txt file included.
|
|
|
|
#pragma once
|
|
|
|
#include <string>
|
|
#include "common/logging/log.h"
|
|
|
|
namespace Network::VerifyUser {
|
|
|
|
struct UserData {
|
|
std::string username;
|
|
std::string display_name;
|
|
std::string avatar_url;
|
|
bool moderator = false; ///< Whether the user is a Citra Moderator.
|
|
};
|
|
|
|
/**
|
|
* A backend used for verifying users and loading user data.
|
|
*/
|
|
class Backend {
|
|
public:
|
|
virtual ~Backend();
|
|
|
|
/**
|
|
* Verifies the given token and loads the information into a UserData struct.
|
|
* @param verify_UID A GUID that may be used for verification.
|
|
* @param token A token that contains user data and verification data. The format and content is
|
|
* decided by backends.
|
|
*/
|
|
virtual UserData LoadUserData(const std::string& verify_UID, const std::string& token) = 0;
|
|
};
|
|
|
|
/**
|
|
* A null backend where the token is ignored.
|
|
* No verification is performed here and the function returns an empty UserData.
|
|
*/
|
|
class NullBackend final : public Backend {
|
|
public:
|
|
~NullBackend();
|
|
|
|
UserData LoadUserData(const std::string& verify_UID, const std::string& token) override;
|
|
};
|
|
|
|
} // namespace Network::VerifyUser
|