// Copyright (c) ppy Pty Ltd . Licensed under the MIT Licence. // See the LICENCE file in the repository root for full licence text. using System.Threading.Tasks; namespace osu.Game.Online.RealtimeMultiplayer { /// /// An interface defining the spectator server instance. /// public interface IMultiplayerServer { /// /// Request to join a multiplayer room. /// /// The databased room ID. /// If the user is already in the requested (or another) room. Task JoinRoom(long roomId); /// /// Request to leave the currently joined room. /// /// If the user is not in a room. Task LeaveRoom(); /// /// Transfer the host of the currently joined room to another user in the room. /// /// The new user which is to become host. /// A user other than the current host is attempting to transfer host. /// If the user is not in a room. Task TransferHost(long userId); /// /// As the host, update the settings of the currently joined room. /// /// The new settings to apply. /// A user other than the current host is attempting to transfer host. /// If the user is not in a room. Task ChangeSettings(MultiplayerRoomSettings settings); /// /// Change the local user state in the currently joined room. /// /// The proposed new state. /// If the state change requested is not valid, given the previous state or room state. /// If the user is not in a room. Task ChangeState(MultiplayerUserState newState); /// /// As the host of a room, start the match. /// /// A user other than the current host is attempting to start the game. /// If the user is not in a room. Task StartMatch(); } }