aboutsummaryrefslogtreecommitdiff
path: root/Jellyfin.Api/Controllers/SuggestionsController.cs
blob: d7c81a3ab631980b18e16a8c9269863c40a438ad (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
using System;
using System.ComponentModel.DataAnnotations;
using System.Linq;
using Jellyfin.Api.Extensions;
using Jellyfin.Api.Helpers;
using Jellyfin.Data.Enums;
using MediaBrowser.Controller.Dto;
using MediaBrowser.Controller.Entities;
using MediaBrowser.Controller.Library;
using MediaBrowser.Model.Dto;
using MediaBrowser.Model.Querying;
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc;

namespace Jellyfin.Api.Controllers
{
    /// <summary>
    /// The suggestions controller.
    /// </summary>
    [Route("")]
    public class SuggestionsController : BaseJellyfinApiController
    {
        private readonly IDtoService _dtoService;
        private readonly IUserManager _userManager;
        private readonly ILibraryManager _libraryManager;

        /// <summary>
        /// Initializes a new instance of the <see cref="SuggestionsController"/> class.
        /// </summary>
        /// <param name="dtoService">Instance of the <see cref="IDtoService"/> interface.</param>
        /// <param name="userManager">Instance of the <see cref="IUserManager"/> interface.</param>
        /// <param name="libraryManager">Instance of the <see cref="ILibraryManager"/> interface.</param>
        public SuggestionsController(
            IDtoService dtoService,
            IUserManager userManager,
            ILibraryManager libraryManager)
        {
            _dtoService = dtoService;
            _userManager = userManager;
            _libraryManager = libraryManager;
        }

        /// <summary>
        /// Gets suggestions.
        /// </summary>
        /// <param name="userId">The user id.</param>
        /// <param name="mediaType">The media types.</param>
        /// <param name="type">The type.</param>
        /// <param name="startIndex">Optional. The start index.</param>
        /// <param name="limit">Optional. The limit.</param>
        /// <param name="enableTotalRecordCount">Whether to enable the total record count.</param>
        /// <response code="200">Suggestions returned.</response>
        /// <returns>A <see cref="QueryResult{BaseItemDto}"/> with the suggestions.</returns>
        [HttpGet("Users/{userId}/Suggestions")]
        [ProducesResponseType(StatusCodes.Status200OK)]
        public ActionResult<QueryResult<BaseItemDto>> GetSuggestions(
            [FromRoute, Required] Guid userId,
            [FromQuery] string? mediaType,
            [FromQuery] string? type,
            [FromQuery] int? startIndex,
            [FromQuery] int? limit,
            [FromQuery] bool enableTotalRecordCount = false)
        {
            var user = !userId.Equals(Guid.Empty) ? _userManager.GetUserById(userId) : null;

            var dtoOptions = new DtoOptions().AddClientFields(Request);
            var result = _libraryManager.GetItemsResult(new InternalItemsQuery(user)
            {
                OrderBy = new[] { ItemSortBy.Random }.Select(i => new ValueTuple<string, SortOrder>(i, SortOrder.Descending)).ToArray(),
                MediaTypes = RequestHelpers.Split(mediaType!, ',', true),
                IncludeItemTypes = RequestHelpers.Split(type!, ',', true),
                IsVirtualItem = false,
                StartIndex = startIndex,
                Limit = limit,
                DtoOptions = dtoOptions,
                EnableTotalRecordCount = enableTotalRecordCount,
                Recursive = true
            });

            var dtoList = _dtoService.GetBaseItemDtos(result.Items, dtoOptions, user);

            return new QueryResult<BaseItemDto>
            {
                TotalRecordCount = result.TotalRecordCount,
                Items = dtoList
            };
        }
    }
}