mirror of
				https://github.com/Kareadita/Kavita.git
				synced 2025-11-04 03:27:05 -05:00 
			
		
		
		
	* Fixed an issue where reading list were not able to update their summary due to a duplicate title check. * Misc code smell cleanup * Updated .net dependencies and removed unneeded ones * Fixed an issue where removing a series from want to read list page wouldn't update the page correctly * Fixed age restriction not applied to Recommended page * Ensure that Genres and Tags are age restricted gated * Persons are now age gated as well * When you choose a cover, the new cover will properly be selected and will focus on it, in the cases there are many other covers available. * Fixed caching profiles * Added in a special hook when deleting a library to clear all series Relations before we delete
		
			
				
	
	
		
			113 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			113 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
using System.Threading.Tasks;
 | 
						|
using API.Data;
 | 
						|
using API.DTOs;
 | 
						|
using API.Extensions;
 | 
						|
using API.Helpers;
 | 
						|
using Microsoft.AspNetCore.Mvc;
 | 
						|
 | 
						|
namespace API.Controllers;
 | 
						|
 | 
						|
public class RecommendedController : BaseApiController
 | 
						|
{
 | 
						|
    private readonly IUnitOfWork _unitOfWork;
 | 
						|
 | 
						|
    public RecommendedController(IUnitOfWork unitOfWork)
 | 
						|
    {
 | 
						|
        _unitOfWork = unitOfWork;
 | 
						|
    }
 | 
						|
 | 
						|
 | 
						|
    /// <summary>
 | 
						|
    /// Quick Reads are series that should be readable in less than 10 in total and are not Ongoing in release.
 | 
						|
    /// </summary>
 | 
						|
    /// <param name="libraryId">Library to restrict series to</param>
 | 
						|
    /// <param name="userParams">Pagination</param>
 | 
						|
    /// <returns></returns>
 | 
						|
    [HttpGet("quick-reads")]
 | 
						|
    public async Task<ActionResult<PagedList<SeriesDto>>> GetQuickReads(int libraryId, [FromQuery] UserParams userParams)
 | 
						|
    {
 | 
						|
        var user = await _unitOfWork.UserRepository.GetUserByUsernameAsync(User.GetUsername());
 | 
						|
 | 
						|
        userParams ??= new UserParams();
 | 
						|
        var series = await _unitOfWork.SeriesRepository.GetQuickReads(user.Id, libraryId, userParams);
 | 
						|
 | 
						|
        Response.AddPaginationHeader(series.CurrentPage, series.PageSize, series.TotalCount, series.TotalPages);
 | 
						|
        return Ok(series);
 | 
						|
    }
 | 
						|
 | 
						|
    /// <summary>
 | 
						|
    /// Quick Catchup Reads are series that should be readable in less than 10 in total and are Ongoing in release.
 | 
						|
    /// </summary>
 | 
						|
    /// <param name="libraryId">Library to restrict series to</param>
 | 
						|
    /// <param name="userParams"></param>
 | 
						|
    /// <returns></returns>
 | 
						|
    [HttpGet("quick-catchup-reads")]
 | 
						|
    public async Task<ActionResult<PagedList<SeriesDto>>> GetQuickCatchupReads(int libraryId, [FromQuery] UserParams userParams)
 | 
						|
    {
 | 
						|
        var user = await _unitOfWork.UserRepository.GetUserByUsernameAsync(User.GetUsername());
 | 
						|
 | 
						|
        userParams ??= new UserParams();
 | 
						|
        var series = await _unitOfWork.SeriesRepository.GetQuickCatchupReads(user.Id, libraryId, userParams);
 | 
						|
 | 
						|
        Response.AddPaginationHeader(series.CurrentPage, series.PageSize, series.TotalCount, series.TotalPages);
 | 
						|
        return Ok(series);
 | 
						|
    }
 | 
						|
 | 
						|
    /// <summary>
 | 
						|
    /// Highly Rated based on other users ratings. Will pull series with ratings > 4.0, weighted by count of other users.
 | 
						|
    /// </summary>
 | 
						|
    /// <param name="libraryId">Library to restrict series to</param>
 | 
						|
    /// <param name="userParams">Pagination</param>
 | 
						|
    /// <returns></returns>
 | 
						|
    [HttpGet("highly-rated")]
 | 
						|
    public async Task<ActionResult<PagedList<SeriesDto>>> GetHighlyRated(int libraryId, [FromQuery] UserParams userParams)
 | 
						|
    {
 | 
						|
        var user = await _unitOfWork.UserRepository.GetUserByUsernameAsync(User.GetUsername());
 | 
						|
 | 
						|
        userParams ??= new UserParams();
 | 
						|
        var series = await _unitOfWork.SeriesRepository.GetHighlyRated(user.Id, libraryId, userParams);
 | 
						|
        await _unitOfWork.SeriesRepository.AddSeriesModifiers(user.Id, series);
 | 
						|
        Response.AddPaginationHeader(series.CurrentPage, series.PageSize, series.TotalCount, series.TotalPages);
 | 
						|
        return Ok(series);
 | 
						|
    }
 | 
						|
 | 
						|
    /// <summary>
 | 
						|
    /// Chooses a random genre and shows series that are in that without reading progress
 | 
						|
    /// </summary>
 | 
						|
    /// <param name="libraryId">Library to restrict series to</param>
 | 
						|
    /// <param name="genreId">Genre Id</param>
 | 
						|
    /// <param name="userParams">Pagination</param>
 | 
						|
    /// <returns></returns>
 | 
						|
    [HttpGet("more-in")]
 | 
						|
    public async Task<ActionResult<PagedList<SeriesDto>>> GetMoreIn(int libraryId, int genreId, [FromQuery] UserParams userParams)
 | 
						|
    {
 | 
						|
        var user = await _unitOfWork.UserRepository.GetUserByUsernameAsync(User.GetUsername());
 | 
						|
 | 
						|
        userParams ??= new UserParams();
 | 
						|
        var series = await _unitOfWork.SeriesRepository.GetMoreIn(user.Id, libraryId, genreId, userParams);
 | 
						|
        await _unitOfWork.SeriesRepository.AddSeriesModifiers(user.Id, series);
 | 
						|
 | 
						|
        Response.AddPaginationHeader(series.CurrentPage, series.PageSize, series.TotalCount, series.TotalPages);
 | 
						|
        return Ok(series);
 | 
						|
    }
 | 
						|
 | 
						|
    /// <summary>
 | 
						|
    /// Series that are fully read by the user in no particular order
 | 
						|
    /// </summary>
 | 
						|
    /// <param name="libraryId">Library to restrict series to</param>
 | 
						|
    /// <param name="userParams">Pagination</param>
 | 
						|
    /// <returns></returns>
 | 
						|
    [HttpGet("rediscover")]
 | 
						|
    public async Task<ActionResult<PagedList<SeriesDto>>> GetRediscover(int libraryId, [FromQuery] UserParams userParams)
 | 
						|
    {
 | 
						|
        var user = await _unitOfWork.UserRepository.GetUserByUsernameAsync(User.GetUsername());
 | 
						|
 | 
						|
        userParams ??= new UserParams();
 | 
						|
        var series = await _unitOfWork.SeriesRepository.GetRediscover(user.Id, libraryId, userParams);
 | 
						|
 | 
						|
        Response.AddPaginationHeader(series.CurrentPage, series.PageSize, series.TotalCount, series.TotalPages);
 | 
						|
        return Ok(series);
 | 
						|
    }
 | 
						|
 | 
						|
}
 |