1
0
mirror of https://github.com/ppy/osu.git synced 2025-01-12 11:42:54 +08:00

Make Room.Password & Room.HasPassword non-bindable

This commit is contained in:
Dan Balasescu 2024-11-13 19:11:05 +09:00
parent 198681e644
commit ec5be6dbc3
No known key found for this signature in database
16 changed files with 80 additions and 48 deletions

View File

@ -24,7 +24,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
{
private readonly Room room = new Room
{
HasPassword = { Value = true }
Password = "*"
};
[Cached]

View File

@ -86,7 +86,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
{
Name = "Private room",
Status = new RoomStatusOpenPrivate(),
HasPassword = { Value = true },
Password = "*",
EndDate = { Value = DateTimeOffset.Now.AddDays(1) },
Type = MatchType.HeadToHead,
Playlist = { item3 },
@ -144,10 +144,10 @@ namespace osu.Game.Tests.Visual.Multiplayer
AddAssert("password icon hidden", () => Precision.AlmostEquals(0, drawableRoom.ChildrenOfType<DrawableRoom.PasswordProtectedIcon>().Single().Alpha));
AddStep("set password", () => room.Password.Value = "password");
AddStep("set password", () => room.Password = "password");
AddAssert("password icon visible", () => Precision.AlmostEquals(1, drawableRoom.ChildrenOfType<DrawableRoom.PasswordProtectedIcon>().Single().Alpha));
AddStep("unset password", () => room.Password.Value = string.Empty);
AddStep("unset password", () => room.Password = string.Empty);
AddAssert("password icon hidden", () => Precision.AlmostEquals(0, drawableRoom.ChildrenOfType<DrawableRoom.PasswordProtectedIcon>().Single().Alpha));
}

View File

@ -182,11 +182,11 @@ namespace osu.Game.Tests.Visual.Multiplayer
AddStep("filter public rooms", () => container.Filter.Value = new FilterCriteria { Permissions = RoomPermissionsFilter.Public });
AddUntilStep("private room hidden", () => container.Rooms.All(r => !r.Room.HasPassword.Value));
AddUntilStep("private room hidden", () => container.Rooms.All(r => !r.Room.HasPassword));
AddStep("filter private rooms", () => container.Filter.Value = new FilterCriteria { Permissions = RoomPermissionsFilter.Private });
AddUntilStep("public room hidden", () => container.Rooms.All(r => r.Room.HasPassword.Value));
AddUntilStep("public room hidden", () => container.Rooms.All(r => r.Room.HasPassword));
}
[Test]

View File

@ -318,7 +318,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
createRoom(() => new Room
{
Name = "Test Room",
Password = { Value = "password" },
Password = "password",
Playlist =
{
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
@ -328,7 +328,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
}
});
AddUntilStep("room has password", () => multiplayerClient.ClientAPIRoom?.Password.Value == "password");
AddUntilStep("room has password", () => multiplayerClient.ClientAPIRoom?.Password == "password");
}
[Test]
@ -339,7 +339,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
roomManager.AddServerSideRoom(new Room
{
Name = "Test Room",
Password = { Value = "password" },
Password = "password",
Playlist =
{
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
@ -371,7 +371,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
createRoom(() => new Room
{
Name = "Test Room",
Password = { Value = "password" },
Password = "password",
Playlist =
{
new PlaylistItem(beatmaps.GetWorkingBeatmap(importedSet.Beatmaps.First(b => b.Ruleset.OnlineID == 0)).BeatmapInfo)
@ -382,7 +382,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
});
AddStep("change password", () => multiplayerClient.ChangeSettings(password: "password2"));
AddUntilStep("local password changed", () => multiplayerClient.ClientAPIRoom?.Password.Value == "password2");
AddUntilStep("local password changed", () => multiplayerClient.ClientAPIRoom?.Password == "password2");
}
[Test]

View File

@ -184,7 +184,7 @@ namespace osu.Game.Online.Multiplayer
Debug.Assert(room.RoomID != null);
// Join the server-side room.
var joinedRoom = await JoinRoom(room.RoomID.Value, password ?? room.Password.Value).ConfigureAwait(false);
var joinedRoom = await JoinRoom(room.RoomID.Value, password ?? room.Password).ConfigureAwait(false);
Debug.Assert(joinedRoom != null);
// Populate users.
@ -397,7 +397,7 @@ namespace osu.Game.Online.Multiplayer
switch (state)
{
case MultiplayerRoomState.Open:
APIRoom.Status = APIRoom.HasPassword.Value ? new RoomStatusOpenPrivate() : new RoomStatusOpen();
APIRoom.Status = APIRoom.HasPassword ? new RoomStatusOpenPrivate() : new RoomStatusOpen();
break;
case MultiplayerRoomState.Playing:
@ -842,7 +842,7 @@ namespace osu.Game.Online.Multiplayer
// Update a few properties of the room instantaneously.
Room.Settings = settings;
APIRoom.Name = Room.Settings.Name;
APIRoom.Password.Value = Room.Settings.Password;
APIRoom.Password = Room.Settings.Password;
APIRoom.Status = string.IsNullOrEmpty(Room.Settings.Password) ? new RoomStatusOpen() : new RoomStatusOpenPrivate();
APIRoom.Type = Room.Settings.MatchType;
APIRoom.QueueMode = Room.Settings.QueueMode;

View File

@ -46,7 +46,7 @@ namespace osu.Game.Online.Rooms
{
if (room.EndDate.Value != null && DateTimeOffset.Now >= room.EndDate.Value)
room.Status = new RoomStatusEnded();
else if (room.HasPassword.Value)
else if (room.HasPassword)
room.Status = new RoomStatusOpenPrivate();
else
room.Status = new RoomStatusOpen();

View File

@ -39,6 +39,35 @@ namespace osu.Game.Online.Rooms
set => SetField(ref name, value);
}
/// <summary>
/// Sets the room password. Will be <c>null</c> after the room is created.
/// </summary>
/// <remarks>
/// To check if the room has a password, use <see cref="HasPassword"/>.
/// </remarks>
public string? Password
{
get => password;
set
{
SetField(ref password, value);
HasPassword = !string.IsNullOrEmpty(value);
}
}
/// <summary>
/// Whether the room has a password.
/// </summary>
/// <remarks>
/// To set a password, use <see cref="Password"/>.
/// </remarks>
[JsonProperty("has_password")]
public bool HasPassword
{
get => hasPassword;
private set => SetField(ref hasPassword, value);
}
/// <summary>
/// The room host. Will be <c>null</c> while the room has not yet been created.
/// </summary>
@ -112,6 +141,12 @@ namespace osu.Game.Online.Rooms
[JsonProperty("name")]
private string name = string.Empty;
[JsonProperty("password")]
private string? password;
// Not serialised (internal use only).
private bool hasPassword;
[JsonProperty("host")]
private APIUser? host;
@ -172,9 +207,6 @@ namespace osu.Game.Online.Rooms
[JsonProperty("current_user_score")]
public readonly Bindable<PlaylistAggregateScore> UserScore = new Bindable<PlaylistAggregateScore>();
[JsonProperty("has_password")]
public readonly Bindable<bool> HasPassword = new Bindable<bool>();
[Cached]
[JsonProperty("recent_participants")]
public readonly BindableList<APIUser> RecentParticipants = new BindableList<APIUser>();
@ -185,10 +217,6 @@ namespace osu.Game.Online.Rooms
#region Properties only used for room creation request
[Cached(Name = nameof(Password))]
[JsonProperty("password")]
public readonly Bindable<string?> Password = new Bindable<string?>();
[Cached]
public readonly Bindable<TimeSpan?> Duration = new Bindable<TimeSpan?>();
@ -229,11 +257,6 @@ namespace osu.Game.Online.Rooms
[JsonProperty("auto_skip")]
public readonly Bindable<bool> AutoSkip = new Bindable<bool>();
public Room()
{
Password.BindValueChanged(p => HasPassword.Value = !string.IsNullOrEmpty(p.NewValue));
}
/// <summary>
/// Copies values from another <see cref="Room"/> into this one.
/// </summary>
@ -254,7 +277,7 @@ namespace osu.Game.Online.Rooms
ChannelId.Value = other.ChannelId.Value;
Status = other.Status;
Availability = other.Availability;
HasPassword.Value = other.HasPassword.Value;
HasPassword = other.HasPassword;
Type = other.Type;
MaxParticipants.Value = other.MaxParticipants.Value;
ParticipantCount.Value = other.ParticipantCount.Value;

View File

@ -259,12 +259,10 @@ namespace osu.Game.Screens.OnlinePlay.Lounge.Components
wrapper.FadeInFromZero(200);
hasPassword.BindTo(Room.HasPassword);
hasPassword.BindValueChanged(v => passwordIcon.Alpha = v.NewValue ? 1 : 0, true);
updateRoomName();
updateRoomCategory();
updateRoomType();
updateRoomHasPassword();
};
SelectedItem.BindValueChanged(item => background.Beatmap.Value = item.NewValue?.Beatmap, true);
@ -285,6 +283,10 @@ namespace osu.Game.Screens.OnlinePlay.Lounge.Components
case nameof(Room.Type):
updateRoomType();
break;
case nameof(Room.HasPassword):
updateRoomHasPassword();
break;
}
}
@ -308,6 +310,12 @@ namespace osu.Game.Screens.OnlinePlay.Lounge.Components
endDateInfo.Alpha = Room.Type == MatchType.Playlists ? 1 : 0;
}
private void updateRoomHasPassword()
{
if (passwordIcon != null)
passwordIcon.Alpha = Room.HasPassword ? 1 : 0;
}
protected override IReadOnlyDependencyContainer CreateChildDependencies(IReadOnlyDependencyContainer parent)
{
return new CachedModelDependencyContainer<Room>(base.CreateChildDependencies(parent))

View File

@ -101,10 +101,10 @@ namespace osu.Game.Screens.OnlinePlay.Lounge.Components
return true;
case RoomPermissionsFilter.Public:
return !room.Room.HasPassword.Value;
return !room.Room.HasPassword;
case RoomPermissionsFilter.Private:
return room.Room.HasPassword.Value;
return room.Room.HasPassword;
default:
throw new ArgumentOutOfRangeException(nameof(accessType), accessType, $"Unsupported {nameof(RoomPermissionsFilter)} in filter");

View File

@ -185,7 +185,7 @@ namespace osu.Game.Screens.OnlinePlay.Lounge
return true;
}
if (Room.HasPassword.Value)
if (Room.HasPassword)
{
this.ShowPopover();
return true;

View File

@ -351,7 +351,6 @@ namespace osu.Game.Screens.OnlinePlay.Multiplayer.Match
TypePicker.Current.BindValueChanged(type => typeLabel.Text = type.NewValue.GetLocalisableDescription(), true);
MaxParticipants.BindValueChanged(count => MaxParticipantsField.Text = count.NewValue?.ToString(), true);
Password.BindValueChanged(password => PasswordTextBox.Text = password.NewValue ?? string.Empty, true);
AutoStartDuration.BindValueChanged(duration => startModeDropdown.Current.Value = (StartMode)(int)duration.NewValue.TotalSeconds, true);
AutoSkip.BindValueChanged(autoSkip => AutoSkipCheckbox.Current.Value = autoSkip.NewValue, true);
@ -377,6 +376,7 @@ namespace osu.Game.Screens.OnlinePlay.Multiplayer.Match
updateRoomName();
updateRoomType();
updateRoomQueueMode();
updateRoomPassword();
}
private void onRoomPropertyChanged(object? sender, PropertyChangedEventArgs e)
@ -394,6 +394,10 @@ namespace osu.Game.Screens.OnlinePlay.Multiplayer.Match
case nameof(Room.QueueMode):
updateRoomQueueMode();
break;
case nameof(Room.Password):
updateRoomPassword();
break;
}
}
@ -406,6 +410,9 @@ namespace osu.Game.Screens.OnlinePlay.Multiplayer.Match
private void updateRoomQueueMode()
=> QueueModeDropdown.Current.Value = room.QueueMode;
private void updateRoomPassword()
=> PasswordTextBox.Text = room.Password ?? string.Empty;
protected override void Update()
{
base.Update();
@ -449,7 +456,7 @@ namespace osu.Game.Screens.OnlinePlay.Multiplayer.Match
{
room.Name = NameField.Text;
room.Type = TypePicker.Current.Value;
room.Password.Value = PasswordTextBox.Current.Value;
room.Password = PasswordTextBox.Current.Value;
room.QueueMode = QueueModeDropdown.Current.Value;
room.AutoStartDuration.Value = autoStartDuration;
room.AutoSkip.Value = AutoSkipCheckbox.Current.Value;

View File

@ -19,7 +19,7 @@ namespace osu.Game.Screens.OnlinePlay.Multiplayer
private MultiplayerClient multiplayerClient { get; set; } = null!;
public override void CreateRoom(Room room, Action<Room>? onSuccess = null, Action<string>? onError = null)
=> base.CreateRoom(room, r => joinMultiplayerRoom(r, r.Password.Value, onSuccess, onError), onError);
=> base.CreateRoom(room, r => joinMultiplayerRoom(r, r.Password, onSuccess, onError), onError);
public override void JoinRoom(Room room, string? password = null, Action<Room>? onSuccess = null, Action<string>? onError = null)
{

View File

@ -45,9 +45,6 @@ namespace osu.Game.Screens.OnlinePlay
[Resolved(typeof(Room))]
protected Bindable<DateTimeOffset?> EndDate { get; private set; } = null!;
[Resolved(typeof(Room))]
public Bindable<string> Password { get; private set; } = null!;
[Resolved(typeof(Room))]
protected Bindable<TimeSpan?> Duration { get; private set; } = null!;

View File

@ -216,7 +216,7 @@ namespace osu.Game.Tests.Visual.Multiplayer
ServerAPIRoom = roomManager.ServerSideRooms.Single(r => r.RoomID == roomId);
if (password != ServerAPIRoom.Password.Value)
if (password != ServerAPIRoom.Password)
throw new InvalidOperationException("Invalid password.");
lastPlaylistItemId = ServerAPIRoom.Playlist.Max(item => item.ID);

View File

@ -39,7 +39,7 @@ namespace osu.Game.Tests.Visual.OnlinePlay
};
if (withPassword)
room.Password.Value = @"password";
room.Password = @"password";
if (ruleset != null)
{

View File

@ -51,8 +51,7 @@ namespace osu.Game.Tests.Visual.OnlinePlay
var apiRoom = cloneRoom(createRoomRequest.Room);
// Passwords are explicitly not copied between rooms.
apiRoom.HasPassword.Value = !string.IsNullOrEmpty(createRoomRequest.Room.Password.Value);
apiRoom.Password.Value = createRoomRequest.Room.Password.Value;
apiRoom.Password = createRoomRequest.Room.Password;
AddServerSideRoom(apiRoom, localUser);
@ -66,7 +65,7 @@ namespace osu.Game.Tests.Visual.OnlinePlay
{
var room = ServerSideRooms.Single(r => r.RoomID == joinRoomRequest.Room.RoomID);
if (joinRoomRequest.Password != room.Password.Value)
if (joinRoomRequest.Password != room.Password)
{
joinRoomRequest.TriggerFailure(new InvalidOperationException("Invalid password."));
return true;
@ -278,9 +277,7 @@ namespace osu.Game.Tests.Visual.OnlinePlay
var responseRoom = cloneRoom(room);
// Password is hidden from the response, and is only propagated via HasPassword.
bool hadPassword = responseRoom.HasPassword.Value;
responseRoom.Password.Value = null;
responseRoom.HasPassword.Value = hadPassword;
responseRoom.Password = responseRoom.HasPassword ? Guid.NewGuid().ToString() : null;
if (!withParticipants)
responseRoom.RecentParticipants.Clear();