mirror of
				https://github.com/Kareadita/Kavita.git
				synced 2025-10-26 08:12:28 -04:00 
			
		
		
		
	* Fixes filter application # Fixed: - Fixed: Fixed an issue where pagination would not reset on filter application (develop) * Fixing up code * code fixes * When no user exists for an api key in Plugin controller, throw 401. * Cleaned up the code to remove the extra variable and make use of what we had already. * Fixed the broken build from last PR * Fixed a few places the code didn't get updated Co-authored-by: Joseph Milazzo <joseph.v.milazzo@gmail.com>
		
			
				
	
	
		
			47 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			47 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| using System.Threading.Tasks;
 | |
| using API.Data;
 | |
| using API.DTOs;
 | |
| using API.Services;
 | |
| using Microsoft.AspNetCore.Mvc;
 | |
| using Microsoft.Extensions.Logging;
 | |
| 
 | |
| namespace API.Controllers
 | |
| {
 | |
|     public class PluginController : BaseApiController
 | |
|     {
 | |
|         private readonly IUnitOfWork _unitOfWork;
 | |
|         private readonly ITokenService _tokenService;
 | |
|         private readonly ILogger<PluginController> _logger;
 | |
| 
 | |
|         public PluginController(IUnitOfWork unitOfWork, ITokenService tokenService, ILogger<PluginController> logger)
 | |
|         {
 | |
|             _unitOfWork = unitOfWork;
 | |
|             _tokenService = tokenService;
 | |
|             _logger = logger;
 | |
|         }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// Authenticate with the Server given an apiKey. This will log you in by returning the user object and the JWT token.
 | |
|         /// </summary>
 | |
|         /// <param name="apiKey"></param>
 | |
|         /// <param name="pluginName">Name of the Plugin</param>
 | |
|         /// <returns></returns>
 | |
|         [HttpPost("authenticate")]
 | |
|         public async Task<ActionResult<UserDto>> Authenticate(string apiKey, string pluginName)
 | |
|         {
 | |
|             // NOTE: In order to log information about plugins, we need some Plugin Description information for each request
 | |
|             // Should log into access table so we can tell the user
 | |
|             var userId = await _unitOfWork.UserRepository.GetUserIdByApiKeyAsync(apiKey);
 | |
|             if (userId <= 0) return Unauthorized();
 | |
|             var user = await _unitOfWork.UserRepository.GetUserByIdAsync(userId);
 | |
|             _logger.LogInformation("Plugin {PluginName} has authenticated with {UserName} ({UserId})'s API Key", pluginName, user.UserName, userId);
 | |
|             return new UserDto
 | |
|             {
 | |
|                 Username = user.UserName,
 | |
|                 Token = await _tokenService.CreateToken(user),
 | |
|                 ApiKey = user.ApiKey,
 | |
|             };
 | |
|         }
 | |
|     }
 | |
| }
 |