2017-10-31 10:02:42 +01:00
|
|
|
// Copyright 2017 Citra Emulator Project
|
|
|
|
// Licensed under GPLv2 or any later version
|
|
|
|
// Refer to the license.txt file included.
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2018-10-27 15:40:15 +08:00
|
|
|
#include <atomic>
|
2017-10-31 10:02:42 +01:00
|
|
|
#include <functional>
|
|
|
|
#include <memory>
|
2017-11-07 21:51:11 +01:00
|
|
|
#include <mutex>
|
2017-10-31 10:02:42 +01:00
|
|
|
#include <set>
|
|
|
|
#include <thread>
|
|
|
|
#include "common/announce_multiplayer_room.h"
|
|
|
|
#include "common/common_types.h"
|
2017-11-10 19:37:26 +01:00
|
|
|
#include "common/thread.h"
|
2017-10-31 10:02:42 +01:00
|
|
|
|
2018-10-27 15:40:15 +08:00
|
|
|
namespace Network {
|
|
|
|
class Room;
|
|
|
|
}
|
|
|
|
|
2017-10-31 10:02:42 +01:00
|
|
|
namespace Core {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Instruments AnnounceMultiplayerRoom::Backend.
|
|
|
|
* Creates a thread that regularly updates the room information and submits them
|
|
|
|
* An async get of room information is also possible
|
|
|
|
*/
|
|
|
|
class AnnounceMultiplayerSession : NonCopyable {
|
|
|
|
public:
|
2017-11-07 21:51:11 +01:00
|
|
|
using CallbackHandle = std::shared_ptr<std::function<void(const Common::WebResult&)>>;
|
2017-10-31 10:02:42 +01:00
|
|
|
AnnounceMultiplayerSession();
|
|
|
|
~AnnounceMultiplayerSession();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Allows to bind a function that will get called if the announce encounters an error
|
|
|
|
* @param function The function that gets called
|
|
|
|
* @return A handle that can be used the unbind the function
|
|
|
|
*/
|
2017-11-07 21:51:11 +01:00
|
|
|
CallbackHandle BindErrorCallback(std::function<void(const Common::WebResult&)> function);
|
2017-10-31 10:02:42 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Unbind a function from the error callbacks
|
|
|
|
* @param handle The handle for the function that should get unbind
|
|
|
|
*/
|
2017-11-07 21:51:11 +01:00
|
|
|
void UnbindErrorCallback(CallbackHandle handle);
|
2017-10-31 10:02:42 +01:00
|
|
|
|
2019-04-19 22:55:49 +08:00
|
|
|
/**
|
|
|
|
* Registers a room to web services
|
|
|
|
* @return The result of the registration attempt.
|
|
|
|
*/
|
|
|
|
Common::WebResult Register();
|
2018-10-27 15:40:15 +08:00
|
|
|
|
2017-10-31 10:02:42 +01:00
|
|
|
/**
|
|
|
|
* Starts the announce of a room to web services
|
|
|
|
*/
|
|
|
|
void Start();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Stops the announce to web services
|
|
|
|
*/
|
|
|
|
void Stop();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns a list of all room information the backend got
|
|
|
|
* @param func A function that gets executed when the async get finished, e.g. a signal
|
|
|
|
* @return a list of rooms received from the web service
|
|
|
|
*/
|
2018-09-12 12:22:48 -04:00
|
|
|
AnnounceMultiplayerRoom::RoomList GetRoomList();
|
2017-10-31 10:02:42 +01:00
|
|
|
|
2019-04-20 10:42:20 +08:00
|
|
|
/**
|
|
|
|
* Whether the announce session is still running
|
|
|
|
*/
|
|
|
|
bool IsRunning() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Recreates the backend, updating the credentials.
|
|
|
|
* This can only be used when the announce session is not running.
|
|
|
|
*/
|
|
|
|
void UpdateCredentials();
|
|
|
|
|
2017-10-31 10:02:42 +01:00
|
|
|
private:
|
2017-11-10 19:37:26 +01:00
|
|
|
Common::Event shutdown_event;
|
2017-10-31 10:02:42 +01:00
|
|
|
std::mutex callback_mutex;
|
2017-11-07 21:51:11 +01:00
|
|
|
std::set<CallbackHandle> error_callbacks;
|
2017-10-31 10:02:42 +01:00
|
|
|
std::unique_ptr<std::thread> announce_multiplayer_thread;
|
|
|
|
|
2017-11-07 21:51:11 +01:00
|
|
|
/// Backend interface that logs fields
|
|
|
|
std::unique_ptr<AnnounceMultiplayerRoom::Backend> backend;
|
2017-10-31 10:02:42 +01:00
|
|
|
|
2018-10-27 15:40:15 +08:00
|
|
|
std::atomic_bool registered = false; ///< Whether the room has been registered
|
|
|
|
|
|
|
|
void UpdateBackendData(std::shared_ptr<Network::Room> room);
|
2017-10-31 10:02:42 +01:00
|
|
|
void AnnounceMultiplayerLoop();
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace Core
|