2022-10-27 05:55:24 +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.
|
|
|
|
|
|
|
|
using System.Net.Http;
|
|
|
|
using osu.Framework.IO.Network;
|
|
|
|
using osu.Game.Online.API.Requests.Responses;
|
|
|
|
|
|
|
|
namespace osu.Game.Online.API.Requests
|
|
|
|
{
|
2022-11-12 14:35:21 +00:00
|
|
|
/// <summary>
|
|
|
|
/// A request which should be sent occasionally while interested in chat and online state.
|
|
|
|
///
|
|
|
|
/// This will:
|
|
|
|
/// - Mark the user as "online" (for 10 minutes since the last invocation).
|
|
|
|
/// - Return any silences since the last invocation (if either <see cref="SinceMessageId"/> or <see cref="SinceSilenceId"/> is not null).
|
|
|
|
///
|
|
|
|
/// For silence handling, a <see cref="SinceMessageId"/> should be provided as soon as a message is received by the client.
|
|
|
|
/// From that point forward, <see cref="SinceSilenceId"/> should be preferred after the first <see cref="ChatSilence"/>
|
|
|
|
/// arrives in a response from the ack request. Specifying both parameters will prioritise the latter.
|
|
|
|
/// </summary>
|
2022-10-27 05:55:24 +00:00
|
|
|
public class ChatAckRequest : APIRequest<ChatAckResponse>
|
|
|
|
{
|
2022-11-12 14:32:05 +00:00
|
|
|
public long? SinceMessageId;
|
2022-11-02 08:13:14 +00:00
|
|
|
public uint? SinceSilenceId;
|
|
|
|
|
2022-10-27 05:55:24 +00:00
|
|
|
protected override WebRequest CreateWebRequest()
|
|
|
|
{
|
|
|
|
var req = base.CreateWebRequest();
|
|
|
|
req.Method = HttpMethod.Post;
|
2022-11-12 14:32:05 +00:00
|
|
|
if (SinceMessageId != null)
|
|
|
|
req.AddParameter(@"since", SinceMessageId.ToString());
|
2022-11-02 08:13:14 +00:00
|
|
|
if (SinceSilenceId != null)
|
|
|
|
req.AddParameter(@"history_since", SinceSilenceId.Value.ToString());
|
2022-10-27 05:55:24 +00:00
|
|
|
return req;
|
|
|
|
}
|
|
|
|
|
|
|
|
protected override string Target => "chat/ack";
|
|
|
|
}
|
|
|
|
}
|