osu/osu.Game/Online/Rooms/PlaylistItem.cs

126 lines
4.1 KiB
C#
Raw Normal View History

// 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.
2018-12-17 05:45:06 +00:00
#nullable enable
2020-02-13 09:48:28 +00:00
using System;
2018-12-17 05:45:06 +00:00
using System.Linq;
using JetBrains.Annotations;
2018-12-17 05:45:06 +00:00
using Newtonsoft.Json;
using osu.Framework.Bindables;
2018-12-17 05:45:06 +00:00
using osu.Game.Beatmaps;
using osu.Game.Online.API;
2021-10-21 07:43:46 +00:00
using osu.Game.Online.API.Requests.Responses;
2018-12-17 05:45:06 +00:00
2020-12-25 04:38:11 +00:00
namespace osu.Game.Online.Rooms
2018-12-17 05:45:06 +00:00
{
[JsonObject(MemberSerialization.OptIn)]
2020-02-13 09:48:28 +00:00
public class PlaylistItem : IEquatable<PlaylistItem>
2018-12-17 05:45:06 +00:00
{
[JsonProperty("id")]
public long ID { get; set; }
2018-12-17 05:45:06 +00:00
2021-11-25 12:41:03 +00:00
[JsonProperty("owner_id")]
public int OwnerID { get; set; }
2018-12-17 05:45:06 +00:00
[JsonProperty("ruleset_id")]
public int RulesetID { get; set; }
2021-02-17 07:44:39 +00:00
/// <summary>
/// Whether this <see cref="PlaylistItem"/> is still a valid selection for the <see cref="Room"/>.
/// </summary>
[JsonProperty("expired")]
public bool Expired { get; set; }
[JsonProperty("playlist_order")]
public ushort? PlaylistOrder { get; set; }
2021-12-03 11:05:25 +00:00
[JsonProperty("played_at")]
public DateTimeOffset? PlayedAt { get; set; }
2018-12-17 05:45:06 +00:00
[JsonProperty("allowed_mods")]
public APIMod[] AllowedMods { get; set; } = Array.Empty<APIMod>();
2019-12-11 05:10:35 +00:00
2018-12-17 05:45:06 +00:00
[JsonProperty("required_mods")]
public APIMod[] RequiredMods { get; set; } = Array.Empty<APIMod>();
2018-12-17 05:45:06 +00:00
/// <summary>
/// Used for deserialising from the API.
/// </summary>
[JsonProperty("beatmap")]
private APIBeatmap apiBeatmap
{
// This getter is required/used internally by JSON.NET during deserialisation to do default-value comparisons. It is never used during serialisation (see: ShouldSerializeapiBeatmap()).
// It will always return a null value on deserialisation, which JSON.NET will handle gracefully.
get => (APIBeatmap)Beatmap;
set => Beatmap = value;
}
2018-12-17 05:45:06 +00:00
/// <summary>
/// Used for serialising to the API.
/// </summary>
[JsonProperty("beatmap_id")]
private int onlineBeatmapId => Beatmap.OnlineID;
/// <summary>
/// A beatmap representing this playlist item.
/// In many cases, this will *not* contain any usable information apart from OnlineID.
/// </summary>
[JsonIgnore]
public IBeatmapInfo Beatmap { get; set; } = null!;
[JsonIgnore]
public IBindable<bool> Valid => valid;
private readonly Bindable<bool> valid = new BindableBool(true);
[JsonConstructor]
private PlaylistItem()
{
}
public PlaylistItem(IBeatmapInfo beatmap)
2018-12-17 05:45:06 +00:00
{
Beatmap = beatmap;
2018-12-17 05:45:06 +00:00
}
public void MarkInvalid() => valid.Value = false;
#region Newtonsoft.Json implicit ShouldSerialize() methods
// The properties in this region are used implicitly by Newtonsoft.Json to not serialise certain fields in some cases.
// They rely on being named exactly the same as the corresponding fields (casing included) and as such should NOT be renamed
// unless the fields are also renamed.
[UsedImplicitly]
2018-12-17 05:45:06 +00:00
public bool ShouldSerializeID() => false;
// ReSharper disable once IdentifierTypo
[UsedImplicitly]
2021-12-28 07:31:27 +00:00
public bool ShouldSerializeapiBeatmap() => false;
2020-02-13 09:48:28 +00:00
#endregion
public PlaylistItem With(IBeatmapInfo beatmap) => new PlaylistItem(beatmap)
{
ID = ID,
OwnerID = OwnerID,
RulesetID = RulesetID,
Expired = Expired,
PlaylistOrder = PlaylistOrder,
PlayedAt = PlayedAt,
AllowedMods = AllowedMods,
RequiredMods = RequiredMods,
valid = { Value = Valid.Value },
};
public bool Equals(PlaylistItem? other)
2021-10-29 07:23:10 +00:00
=> ID == other?.ID
&& Beatmap.OnlineID == other.Beatmap.OnlineID
2021-10-29 07:23:10 +00:00
&& RulesetID == other.RulesetID
&& Expired == other.Expired
&& AllowedMods.SequenceEqual(other.AllowedMods)
&& RequiredMods.SequenceEqual(other.RequiredMods);
2018-12-17 05:45:06 +00:00
}
}