| 
									
										
										
										
											2021-12-25 20:27:52 +01:00
										 |  |  | // Copyright 2017 Citra Emulator Project
 | 
					
						
							|  |  |  | // Licensed under GPLv2 or any later version
 | 
					
						
							|  |  |  | // Refer to the license.txt file included.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <array>
 | 
					
						
							|  |  |  | #include <functional>
 | 
					
						
							|  |  |  | #include <string>
 | 
					
						
							|  |  |  | #include <vector>
 | 
					
						
							|  |  |  | #include "common/common_types.h"
 | 
					
						
							|  |  |  | #include "web_service/web_result.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace AnnounceMultiplayerRoom { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | using MacAddress = std::array<u8, 6>; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-07-15 21:11:09 +02:00
										 |  |  | struct Member { | 
					
						
							|  |  |  |     std::string username; | 
					
						
							|  |  |  |     std::string nickname; | 
					
						
							|  |  |  |     std::string display_name; | 
					
						
							|  |  |  |     std::string avatar_url; | 
					
						
							|  |  |  |     MacAddress mac_address; | 
					
						
							|  |  |  |     std::string game_name; | 
					
						
							|  |  |  |     u64 game_id; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct RoomInformation { | 
					
						
							|  |  |  |     std::string name;           ///< Name of the server
 | 
					
						
							|  |  |  |     std::string description;    ///< Server description
 | 
					
						
							|  |  |  |     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
 | 
					
						
							|  |  |  |     std::string host_username;  ///< Forum username of the host
 | 
					
						
							|  |  |  |     bool enable_yuzu_mods;      ///< Allow yuzu Moderators to moderate on this room
 | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct GameInfo { | 
					
						
							|  |  |  |     std::string name{""}; | 
					
						
							|  |  |  |     u64 id{0}; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-25 20:27:52 +01:00
										 |  |  | struct Room { | 
					
						
							| 
									
										
										
										
											2022-07-15 21:11:09 +02:00
										 |  |  |     RoomInformation information; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-25 20:27:52 +01:00
										 |  |  |     std::string id; | 
					
						
							|  |  |  |     std::string verify_UID; ///< UID used for verification
 | 
					
						
							|  |  |  |     std::string ip; | 
					
						
							|  |  |  |     u32 net_version; | 
					
						
							|  |  |  |     bool has_password; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     std::vector<Member> members; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | using RoomList = std::vector<Room>; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * A AnnounceMultiplayerRoom interface class. A backend to submit/get to/from a web service should | 
					
						
							|  |  |  |  * implement this interface. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | class Backend { | 
					
						
							|  |  |  | public: | 
					
						
							|  |  |  |     virtual ~Backend() = default; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Sets the Information that gets used for the announce | 
					
						
							|  |  |  |      * @param uid The Id of the room | 
					
						
							|  |  |  |      * @param name The name of the room | 
					
						
							|  |  |  |      * @param description The room description | 
					
						
							|  |  |  |      * @param port The port of the room | 
					
						
							|  |  |  |      * @param net_version The version of the libNetwork that gets used | 
					
						
							|  |  |  |      * @param has_password True if the room is passowrd protected | 
					
						
							|  |  |  |      * @param preferred_game The preferred game of the room | 
					
						
							|  |  |  |      * @param preferred_game_id The title id of the preferred game | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     virtual void SetRoomInformation(const std::string& name, const std::string& description, | 
					
						
							|  |  |  |                                     const u16 port, const u32 max_player, const u32 net_version, | 
					
						
							|  |  |  |                                     const bool has_password, const std::string& preferred_game, | 
					
						
							|  |  |  |                                     const u64 preferred_game_id) = 0; | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Adds a player information to the data that gets announced | 
					
						
							|  |  |  |      * @param nickname The nickname of the player | 
					
						
							|  |  |  |      * @param mac_address The MAC Address of the player | 
					
						
							|  |  |  |      * @param game_id The title id of the game the player plays | 
					
						
							|  |  |  |      * @param game_name The name of the game the player plays | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2022-07-15 21:11:09 +02:00
										 |  |  |     virtual void AddPlayer(const Member& member) = 0; | 
					
						
							| 
									
										
										
										
											2021-12-25 20:27:52 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Updates the data in the announce service. Re-register the room when required. | 
					
						
							|  |  |  |      * @result The result of the update attempt | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     virtual WebService::WebResult Update() = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Registers the data in the announce service | 
					
						
							|  |  |  |      * @result The result of the register attempt. When the result code is Success, A global Guid of | 
					
						
							|  |  |  |      * the room which may be used for verification will be in the result's returned_data. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     virtual WebService::WebResult Register() = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Empties the stored players | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     virtual void ClearPlayers() = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Get the room information from the announce service | 
					
						
							|  |  |  |      * @result A list of all rooms the announce service has | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     virtual RoomList GetRoomList() = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Sends a delete message to the announce service | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     virtual void Delete() = 0; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Empty implementation of AnnounceMultiplayerRoom interface that drops all data. Used when a | 
					
						
							|  |  |  |  * functional backend implementation is not available. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | class NullBackend : public Backend { | 
					
						
							|  |  |  | public: | 
					
						
							|  |  |  |     ~NullBackend() = default; | 
					
						
							|  |  |  |     void SetRoomInformation(const std::string& /*name*/, const std::string& /*description*/, | 
					
						
							|  |  |  |                             const u16 /*port*/, const u32 /*max_player*/, const u32 /*net_version*/, | 
					
						
							|  |  |  |                             const bool /*has_password*/, const std::string& /*preferred_game*/, | 
					
						
							|  |  |  |                             const u64 /*preferred_game_id*/) override {} | 
					
						
							| 
									
										
										
										
											2022-07-15 21:11:09 +02:00
										 |  |  |     void AddPlayer(const Member& /*member*/) override {} | 
					
						
							| 
									
										
										
										
											2021-12-25 20:27:52 +01:00
										 |  |  |     WebService::WebResult Update() override { | 
					
						
							|  |  |  |         return WebService::WebResult{WebService::WebResult::Code::NoWebservice, | 
					
						
							| 
									
										
										
										
											2022-07-07 04:12:12 +02:00
										 |  |  |                                      "WebService is missing", ""}; | 
					
						
							| 
									
										
										
										
											2021-12-25 20:27:52 +01:00
										 |  |  |     } | 
					
						
							|  |  |  |     WebService::WebResult Register() override { | 
					
						
							|  |  |  |         return WebService::WebResult{WebService::WebResult::Code::NoWebservice, | 
					
						
							| 
									
										
										
										
											2022-07-07 04:12:12 +02:00
										 |  |  |                                      "WebService is missing", ""}; | 
					
						
							| 
									
										
										
										
											2021-12-25 20:27:52 +01:00
										 |  |  |     } | 
					
						
							|  |  |  |     void ClearPlayers() override {} | 
					
						
							|  |  |  |     RoomList GetRoomList() override { | 
					
						
							|  |  |  |         return RoomList{}; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void Delete() override {} | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } // namespace AnnounceMultiplayerRoom
 |