mirror of
https://github.com/ppy/osu.git
synced 2024-11-14 14:27:25 +08:00
7b47215657
Them being together always bothered me and led to the abject failure that is `APIUser` and its sprawl. Now that I'm about to add a flag that is unique to `/me` for verification purposes, I'm not repeating the errors of the past by adding yet another flag to `APIUser` that is never present outside of a single usage context.
48 lines
1.5 KiB
C#
48 lines
1.5 KiB
C#
// 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.
|
|
|
|
using osu.Game.Online.API.Requests.Responses;
|
|
using osu.Game.Rulesets;
|
|
|
|
namespace osu.Game.Online.API.Requests
|
|
{
|
|
public class GetUserRequest : APIRequest<APIUser>
|
|
{
|
|
public readonly string Lookup;
|
|
public readonly IRulesetInfo? Ruleset;
|
|
private readonly LookupType lookupType;
|
|
|
|
/// <summary>
|
|
/// Gets a user from their ID.
|
|
/// </summary>
|
|
/// <param name="userId">The user to get.</param>
|
|
/// <param name="ruleset">The ruleset to get the user's info for.</param>
|
|
public GetUserRequest(long? userId = null, IRulesetInfo? ruleset = null)
|
|
{
|
|
Lookup = userId.ToString()!;
|
|
lookupType = LookupType.Id;
|
|
Ruleset = ruleset;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets a user from their username.
|
|
/// </summary>
|
|
/// <param name="username">The user to get.</param>
|
|
/// <param name="ruleset">The ruleset to get the user's info for.</param>
|
|
public GetUserRequest(string username, IRulesetInfo? ruleset = null)
|
|
{
|
|
Lookup = username;
|
|
lookupType = LookupType.Username;
|
|
Ruleset = ruleset;
|
|
}
|
|
|
|
protected override string Target => $@"users/{Lookup}/{Ruleset?.ShortName}?key={lookupType.ToString().ToLowerInvariant()}";
|
|
|
|
private enum LookupType
|
|
{
|
|
Id,
|
|
Username
|
|
}
|
|
}
|
|
}
|