osu/osu.Game/Online/Multiplayer/IMultiplayerRoomServer.cs

73 lines
3.4 KiB
C#
Raw Normal View History

2020-12-16 03:31:05 +00:00
// Copyright (c) ppy Pty Ltd <contact@ppy.sh>. Licensed under the MIT Licence.
// See the LICENCE file in the repository root for full licence text.
2021-02-01 08:54:56 +00:00
using System.Collections.Generic;
2020-12-16 03:31:05 +00:00
using System.Threading.Tasks;
2021-02-01 08:54:56 +00:00
using osu.Game.Online.API;
using osu.Game.Online.Rooms;
2020-12-16 03:31:05 +00:00
2020-12-25 04:38:11 +00:00
namespace osu.Game.Online.Multiplayer
2020-12-16 03:31:05 +00:00
{
/// <summary>
/// Interface for an in-room multiplayer server.
/// </summary>
public interface IMultiplayerRoomServer
{
/// <summary>
/// Request to leave the currently joined room.
/// </summary>
/// <exception cref="NotJoinedRoomException">If the user is not in a room.</exception>
Task LeaveRoom();
/// <summary>
/// Transfer the host of the currently joined room to another user in the room.
/// </summary>
/// <param name="userId">The new user which is to become host.</param>
/// <exception cref="NotHostException">A user other than the current host is attempting to transfer host.</exception>
/// <exception cref="NotJoinedRoomException">If the user is not in a room.</exception>
2020-12-16 11:04:28 +00:00
Task TransferHost(int userId);
2020-12-16 03:31:05 +00:00
/// <summary>
/// As the host, update the settings of the currently joined room.
/// </summary>
/// <param name="settings">The new settings to apply.</param>
/// <exception cref="NotHostException">A user other than the current host is attempting to transfer host.</exception>
/// <exception cref="NotJoinedRoomException">If the user is not in a room.</exception>
Task ChangeSettings(MultiplayerRoomSettings settings);
/// <summary>
/// Change the local user state in the currently joined room.
/// </summary>
/// <param name="newState">The proposed new state.</param>
/// <exception cref="InvalidStateChangeException">If the state change requested is not valid, given the previous state or room state.</exception>
/// <exception cref="NotJoinedRoomException">If the user is not in a room.</exception>
Task ChangeState(MultiplayerUserState newState);
/// <summary>
/// Change the local user's availability state of the current beatmap set in joined room.
/// </summary>
/// <param name="newBeatmapAvailability">The proposed new beatmap availability state.</param>
Task ChangeBeatmapAvailability(BeatmapAvailability newBeatmapAvailability);
2021-02-01 09:50:32 +00:00
/// <summary>
/// Change the local user's mods in the currently joined room.
/// </summary>
/// <param name="newMods">The proposed new mods, excluding any required by the room itself.</param>
2021-02-01 08:57:32 +00:00
Task ChangeUserMods(IEnumerable<APIMod> newMods);
2021-02-01 08:54:56 +00:00
/// <summary>
/// Send a match ruleset specific request.
/// </summary>
/// <param name="request">The request to send.</param>
Task SendMatchRulesetRequest(MatchRulesetUserRequest request);
2020-12-16 03:31:05 +00:00
/// <summary>
/// As the host of a room, start the match.
/// </summary>
/// <exception cref="NotHostException">A user other than the current host is attempting to start the game.</exception>
/// <exception cref="NotJoinedRoomException">If the user is not in a room.</exception>
/// <exception cref="InvalidStateException">If an attempt to start the game occurs when the game's (or users') state disallows it.</exception>
Task StartMatch();
}
}