ActivityLogController.cs 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. using System;
  2. using System.Threading.Tasks;
  3. using Jellyfin.Api.Constants;
  4. using Jellyfin.Data.Queries;
  5. using MediaBrowser.Model.Activity;
  6. using MediaBrowser.Model.Querying;
  7. using Microsoft.AspNetCore.Authorization;
  8. using Microsoft.AspNetCore.Http;
  9. using Microsoft.AspNetCore.Mvc;
  10. namespace Jellyfin.Api.Controllers;
  11. /// <summary>
  12. /// Activity log controller.
  13. /// </summary>
  14. [Route("System/ActivityLog")]
  15. [Authorize(Policy = Policies.RequiresElevation)]
  16. public class ActivityLogController : BaseJellyfinApiController
  17. {
  18. private readonly IActivityManager _activityManager;
  19. /// <summary>
  20. /// Initializes a new instance of the <see cref="ActivityLogController"/> class.
  21. /// </summary>
  22. /// <param name="activityManager">Instance of <see cref="IActivityManager"/> interface.</param>
  23. public ActivityLogController(IActivityManager activityManager)
  24. {
  25. _activityManager = activityManager;
  26. }
  27. /// <summary>
  28. /// Gets activity log entries.
  29. /// </summary>
  30. /// <param name="startIndex">Optional. The record index to start at. All items with a lower index will be dropped from the results.</param>
  31. /// <param name="limit">Optional. The maximum number of records to return.</param>
  32. /// <param name="minDate">Optional. The minimum date. Format = ISO.</param>
  33. /// <param name="hasUserId">Optional. Filter log entries if it has user id, or not.</param>
  34. /// <response code="200">Activity log returned.</response>
  35. /// <returns>A <see cref="QueryResult{ActivityLogEntry}"/> containing the log entries.</returns>
  36. [HttpGet("Entries")]
  37. [ProducesResponseType(StatusCodes.Status200OK)]
  38. public async Task<ActionResult<QueryResult<ActivityLogEntry>>> GetLogEntries(
  39. [FromQuery] int? startIndex,
  40. [FromQuery] int? limit,
  41. [FromQuery] DateTime? minDate,
  42. [FromQuery] bool? hasUserId)
  43. {
  44. return await _activityManager.GetPagedResultAsync(new ActivityLogQuery
  45. {
  46. Skip = startIndex,
  47. Limit = limit,
  48. MinDate = minDate,
  49. HasUserId = hasUserId
  50. }).ConfigureAwait(false);
  51. }
  52. }