jellyfin/Jellyfin.Api/Controllers/TimeSyncController.cs

34 lines
1.1 KiB
C#
Raw Normal View History

2020-11-21 08:26:03 -05:00
using System;
2020-07-15 10:15:17 -04:00
using MediaBrowser.Model.SyncPlay;
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc;
2023-01-31 06:18:10 -05:00
namespace Jellyfin.Api.Controllers;
/// <summary>
/// The time sync controller.
/// </summary>
[Route("")]
public class TimeSyncController : BaseJellyfinApiController
2020-07-15 10:15:17 -04:00
{
/// <summary>
2023-01-31 06:18:10 -05:00
/// Gets the current UTC time.
2020-07-15 10:15:17 -04:00
/// </summary>
2023-01-31 06:18:10 -05:00
/// <response code="200">Time returned.</response>
/// <returns>An <see cref="UtcTimeResponse"/> to sync the client and server time.</returns>
[HttpGet("GetUtcTime")]
[ProducesResponseType(statusCode: StatusCodes.Status200OK)]
public ActionResult<UtcTimeResponse> GetUtcTime()
2020-07-15 10:15:17 -04:00
{
2023-01-31 06:18:10 -05:00
// Important to keep the following line at the beginning
var requestReceptionTime = DateTime.UtcNow;
2020-07-15 10:15:17 -04:00
2023-01-31 06:18:10 -05:00
// Important to keep the following line at the end
var responseTransmissionTime = DateTime.UtcNow;
2020-07-15 10:15:17 -04:00
2023-01-31 06:18:10 -05:00
// Implementing NTP on such a high level results in this useless
// information being sent. On the other hand it enables future additions.
return new UtcTimeResponse(requestReceptionTime, responseTransmissionTime);
2020-07-15 10:15:17 -04:00
}
}