2017-07-07 12:34:15 -07:00
|
|
|
// Copyright 2017 Citra Emulator Project
|
|
|
|
// Licensed under GPLv2 or any later version
|
|
|
|
// Refer to the license.txt file included.
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2017-07-08 07:47:24 -07:00
|
|
|
#include <array>
|
2017-07-07 12:34:15 -07:00
|
|
|
#include <memory>
|
|
|
|
#include <string>
|
2017-08-19 10:14:33 -07:00
|
|
|
#include <vector>
|
2017-07-07 12:34:15 -07:00
|
|
|
#include "common/common_types.h"
|
2018-10-27 00:35:01 -07:00
|
|
|
#include "network/verify_user.h"
|
2017-07-07 12:34:15 -07:00
|
|
|
|
|
|
|
namespace Network {
|
|
|
|
|
2018-09-30 18:53:20 -07:00
|
|
|
constexpr u32 network_version = 4; ///< The version of this Room and RoomMember
|
2017-07-14 00:20:39 -07:00
|
|
|
|
2017-11-19 10:52:37 -08:00
|
|
|
constexpr u16 DefaultRoomPort = 24872;
|
|
|
|
|
|
|
|
constexpr u32 MaxMessageSize = 500;
|
|
|
|
|
|
|
|
/// Maximum number of concurrent connections allowed to this room.
|
|
|
|
static constexpr u32 MaxConcurrentConnections = 254;
|
|
|
|
|
2018-09-06 13:03:28 -07:00
|
|
|
constexpr std::size_t NumChannels = 1; // Number of channels used for the connection
|
2017-07-07 12:34:15 -07:00
|
|
|
|
|
|
|
struct RoomInformation {
|
2017-11-19 10:52:37 -08:00
|
|
|
std::string name; ///< Name of the server
|
2018-04-30 00:40:51 -07:00
|
|
|
std::string description; ///< Server description
|
2017-11-19 10:52:37 -08:00
|
|
|
u32 member_slots; ///< Maximum number of members in this room
|
|
|
|
u16 port; ///< The port of this room
|
|
|
|
std::string preferred_game; ///< Game to advertise that you want to play
|
|
|
|
u64 preferred_game_id; ///< Title ID for the advertised game
|
2017-07-07 12:34:15 -07:00
|
|
|
};
|
|
|
|
|
2017-08-19 10:14:33 -07:00
|
|
|
struct GameInfo {
|
|
|
|
std::string name{""};
|
|
|
|
u64 id{0};
|
|
|
|
};
|
|
|
|
|
2017-07-09 06:06:02 -07:00
|
|
|
using MacAddress = std::array<u8, 6>;
|
2017-07-08 07:47:24 -07:00
|
|
|
/// A special MAC address that tells the room we're joining to assign us a MAC address
|
|
|
|
/// automatically.
|
2017-07-26 12:06:40 -07:00
|
|
|
constexpr MacAddress NoPreferredMac = {0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF};
|
2017-07-08 07:47:24 -07:00
|
|
|
|
2017-07-09 06:06:02 -07:00
|
|
|
// 802.11 broadcast MAC address
|
|
|
|
constexpr MacAddress BroadcastMac = {0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF};
|
|
|
|
|
2017-07-08 06:24:47 -07:00
|
|
|
// The different types of messages that can be sent. The first byte of each packet defines the type
|
2017-07-15 12:24:11 -07:00
|
|
|
enum RoomMessageTypes : u8 {
|
2017-07-08 06:24:47 -07:00
|
|
|
IdJoinRequest = 1,
|
|
|
|
IdJoinSuccess,
|
|
|
|
IdRoomInformation,
|
2017-08-19 10:14:33 -07:00
|
|
|
IdSetGameInfo,
|
2017-07-08 06:24:47 -07:00
|
|
|
IdWifiPacket,
|
|
|
|
IdChatMessage,
|
|
|
|
IdNameCollision,
|
2017-07-14 00:20:39 -07:00
|
|
|
IdMacCollision,
|
|
|
|
IdVersionMismatch,
|
2017-11-19 10:52:37 -08:00
|
|
|
IdWrongPassword,
|
2018-04-20 00:34:37 -07:00
|
|
|
IdCloseRoom,
|
|
|
|
IdRoomIsFull,
|
2018-10-31 08:07:03 -07:00
|
|
|
IdConsoleIdCollision,
|
2017-07-08 06:24:47 -07:00
|
|
|
};
|
|
|
|
|
2017-07-07 12:34:15 -07:00
|
|
|
/// This is what a server [person creating a server] would use.
|
|
|
|
class Room final {
|
|
|
|
public:
|
|
|
|
enum class State : u8 {
|
|
|
|
Open, ///< The room is open and ready to accept connections.
|
|
|
|
Closed, ///< The room is not opened and can not accept connections.
|
|
|
|
};
|
|
|
|
|
2017-08-19 10:14:33 -07:00
|
|
|
struct Member {
|
2018-10-27 00:35:01 -07:00
|
|
|
std::string nickname; ///< The nickname of the member.
|
|
|
|
std::string username; ///< The web services username of the member. Can be empty.
|
|
|
|
std::string display_name; ///< The web services display name of the member. Can be empty.
|
|
|
|
std::string avatar_url; ///< Url to the member's avatar. Can be empty.
|
|
|
|
GameInfo game_info; ///< The current game of the member
|
|
|
|
MacAddress mac_address; ///< The assigned mac address of the member.
|
2017-08-19 10:14:33 -07:00
|
|
|
};
|
|
|
|
|
2017-07-07 12:34:15 -07:00
|
|
|
Room();
|
|
|
|
~Room();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the current state of the room.
|
|
|
|
*/
|
|
|
|
State GetState() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gets the room information of the room.
|
|
|
|
*/
|
|
|
|
const RoomInformation& GetRoomInformation() const;
|
|
|
|
|
2018-10-27 00:35:01 -07:00
|
|
|
/**
|
|
|
|
* Gets the verify UID of this room.
|
|
|
|
*/
|
|
|
|
std::string GetVerifyUID() const;
|
|
|
|
|
2017-08-19 10:14:33 -07:00
|
|
|
/**
|
|
|
|
* Gets a list of the mbmers connected to the room.
|
|
|
|
*/
|
|
|
|
std::vector<Member> GetRoomMemberList() const;
|
|
|
|
|
2017-11-19 10:52:37 -08:00
|
|
|
/**
|
|
|
|
* Checks if the room is password protected
|
|
|
|
*/
|
|
|
|
bool HasPassword() const;
|
|
|
|
|
2017-07-07 12:34:15 -07:00
|
|
|
/**
|
|
|
|
* Creates the socket for this room. Will bind to default address if
|
|
|
|
* server is empty string.
|
|
|
|
*/
|
2018-04-30 00:40:51 -07:00
|
|
|
bool Create(const std::string& name, const std::string& description = "",
|
|
|
|
const std::string& server = "", u16 server_port = DefaultRoomPort,
|
|
|
|
const std::string& password = "",
|
2017-11-19 10:52:37 -08:00
|
|
|
const u32 max_connections = MaxConcurrentConnections,
|
2018-10-27 00:35:01 -07:00
|
|
|
const std::string& preferred_game = "", u64 preferred_game_id = 0,
|
|
|
|
std::unique_ptr<VerifyUser::Backend> verify_backend = nullptr);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the verification GUID of the room.
|
|
|
|
*/
|
|
|
|
void SetVerifyUID(const std::string& uid);
|
2017-07-07 12:34:15 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Destroys the socket
|
|
|
|
*/
|
|
|
|
void Destroy();
|
|
|
|
|
|
|
|
private:
|
|
|
|
class RoomImpl;
|
|
|
|
std::unique_ptr<RoomImpl> room_impl;
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace Network
|