aboutsummaryrefslogtreecommitdiff
path: root/Jellyfin.Api/Controllers
diff options
context:
space:
mode:
Diffstat (limited to 'Jellyfin.Api/Controllers')
-rw-r--r--Jellyfin.Api/Controllers/ActivityLogController.cs76
1 files changed, 67 insertions, 9 deletions
diff --git a/Jellyfin.Api/Controllers/ActivityLogController.cs b/Jellyfin.Api/Controllers/ActivityLogController.cs
index a19a203b5..d5f262773 100644
--- a/Jellyfin.Api/Controllers/ActivityLogController.cs
+++ b/Jellyfin.Api/Controllers/ActivityLogController.cs
@@ -1,13 +1,16 @@
using System;
+using System.Collections.Generic;
using System.Threading.Tasks;
-using Jellyfin.Api.Constants;
+using Jellyfin.Data.Enums;
using Jellyfin.Data.Queries;
+using Jellyfin.Database.Implementations.Enums;
using MediaBrowser.Common.Api;
using MediaBrowser.Model.Activity;
using MediaBrowser.Model.Querying;
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc;
+using Microsoft.Extensions.Logging;
namespace Jellyfin.Api.Controllers;
@@ -32,10 +35,19 @@ public class ActivityLogController : BaseJellyfinApiController
/// <summary>
/// Gets activity log entries.
/// </summary>
- /// <param name="startIndex">Optional. The record index to start at. All items with a lower index will be dropped from the results.</param>
- /// <param name="limit">Optional. The maximum number of records to return.</param>
- /// <param name="minDate">Optional. The minimum date. Format = ISO.</param>
- /// <param name="hasUserId">Optional. Filter log entries if it has user id, or not.</param>
+ /// <param name="startIndex">The record index to start at. All items with a lower index will be dropped from the results.</param>
+ /// <param name="limit">The maximum number of records to return.</param>
+ /// <param name="minDate">The minimum date.</param>
+ /// <param name="hasUserId">Filter log entries if it has user id, or not.</param>
+ /// <param name="name">Filter by name.</param>
+ /// <param name="overview">Filter by overview.</param>
+ /// <param name="shortOverview">Filter by short overview.</param>
+ /// <param name="type">Filter by type.</param>
+ /// <param name="itemId">Filter by item id.</param>
+ /// <param name="username">Filter by username.</param>
+ /// <param name="severity">Filter by log severity.</param>
+ /// <param name="sortBy">Specify one or more sort orders. Format: SortBy=Name,Type.</param>
+ /// <param name="sortOrder">Sort Order..</param>
/// <response code="200">Activity log returned.</response>
/// <returns>A <see cref="QueryResult{ActivityLogEntry}"/> containing the log entries.</returns>
[HttpGet("Entries")]
@@ -44,14 +56,60 @@ public class ActivityLogController : BaseJellyfinApiController
[FromQuery] int? startIndex,
[FromQuery] int? limit,
[FromQuery] DateTime? minDate,
- [FromQuery] bool? hasUserId)
+ [FromQuery] bool? hasUserId,
+ [FromQuery] string? name,
+ [FromQuery] string? overview,
+ [FromQuery] string? shortOverview,
+ [FromQuery] string? type,
+ [FromQuery] Guid? itemId,
+ [FromQuery] string? username,
+ [FromQuery] LogLevel? severity,
+ [FromQuery] ActivityLogSortBy[]? sortBy,
+ [FromQuery] SortOrder[]? sortOrder)
{
- return await _activityManager.GetPagedResultAsync(new ActivityLogQuery
+ var query = new ActivityLogQuery
{
Skip = startIndex,
Limit = limit,
MinDate = minDate,
- HasUserId = hasUserId
- }).ConfigureAwait(false);
+ HasUserId = hasUserId,
+ Name = name,
+ Overview = overview,
+ ShortOverview = shortOverview,
+ Type = type,
+ ItemId = itemId,
+ Username = username,
+ Severity = severity,
+ OrderBy = GetOrderBy(sortBy ?? [], sortOrder ?? []),
+ };
+
+ return await _activityManager.GetPagedResultAsync(query).ConfigureAwait(false);
+ }
+
+ private static (ActivityLogSortBy SortBy, SortOrder SortOrder)[] GetOrderBy(
+ IReadOnlyList<ActivityLogSortBy> sortBy,
+ IReadOnlyList<SortOrder> requestedSortOrder)
+ {
+ if (sortBy.Count == 0)
+ {
+ return [];
+ }
+
+ var result = new (ActivityLogSortBy, SortOrder)[sortBy.Count];
+ var i = 0;
+ for (; i < requestedSortOrder.Count; i++)
+ {
+ result[i] = (sortBy[i], requestedSortOrder[i]);
+ }
+
+ // Add remaining elements with the first specified SortOrder
+ // or the default one if no SortOrders are specified
+ var order = requestedSortOrder.Count > 0 ? requestedSortOrder[0] : SortOrder.Ascending;
+ for (; i < sortBy.Count; i++)
+ {
+ result[i] = (sortBy[i], order);
+ }
+
+ return result;
}
}