mirror of
https://github.com/Kareadita/Kavita.git
synced 2025-05-24 00:52:23 -04:00
93 lines
2.9 KiB
C#
93 lines
2.9 KiB
C#
using System;
|
|
using System.Threading.Tasks;
|
|
using API.Constants;
|
|
using API.Data;
|
|
using API.DTOs.Account;
|
|
using API.DTOs.License;
|
|
using API.Entities.Enums;
|
|
using API.Extensions;
|
|
using API.Services;
|
|
using API.Services.Plus;
|
|
using Kavita.Common;
|
|
using Microsoft.AspNetCore.Authorization;
|
|
using Microsoft.AspNetCore.Mvc;
|
|
using Microsoft.Extensions.Logging;
|
|
|
|
namespace API.Controllers;
|
|
|
|
#nullable enable
|
|
|
|
public class LicenseController : BaseApiController
|
|
{
|
|
private readonly IUnitOfWork _unitOfWork;
|
|
private readonly ILogger<LicenseController> _logger;
|
|
private readonly ILicenseService _licenseService;
|
|
private readonly ILocalizationService _localizationService;
|
|
|
|
public LicenseController(IUnitOfWork unitOfWork, ILogger<LicenseController> logger,
|
|
ILicenseService licenseService, ILocalizationService localizationService)
|
|
{
|
|
_unitOfWork = unitOfWork;
|
|
_logger = logger;
|
|
_licenseService = licenseService;
|
|
_localizationService = localizationService;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Checks if the user's license is valid or not
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
[HttpGet("valid-license")]
|
|
[ResponseCache(CacheProfileName = ResponseCacheProfiles.LicenseCache)]
|
|
public async Task<ActionResult<bool>> HasValidLicense(bool forceCheck = false)
|
|
{
|
|
return Ok(await _licenseService.HasActiveLicense(forceCheck));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Has any license
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
[Authorize("RequireAdminRole")]
|
|
[HttpGet("has-license")]
|
|
[ResponseCache(CacheProfileName = ResponseCacheProfiles.LicenseCache)]
|
|
public async Task<ActionResult<bool>> HasLicense()
|
|
{
|
|
return Ok(!string.IsNullOrEmpty(
|
|
(await _unitOfWork.SettingsRepository.GetSettingAsync(ServerSettingKey.LicenseKey)).Value));
|
|
}
|
|
|
|
[Authorize("RequireAdminRole")]
|
|
[HttpDelete]
|
|
[ResponseCache(CacheProfileName = ResponseCacheProfiles.LicenseCache)]
|
|
public async Task<ActionResult> RemoveLicense()
|
|
{
|
|
_logger.LogInformation("Removing license on file for Server");
|
|
var setting = await _unitOfWork.SettingsRepository.GetSettingAsync(ServerSettingKey.LicenseKey);
|
|
setting.Value = null;
|
|
_unitOfWork.SettingsRepository.Update(setting);
|
|
await _unitOfWork.CommitAsync();
|
|
return Ok();
|
|
}
|
|
|
|
/// <summary>
|
|
/// Updates server license
|
|
/// </summary>
|
|
/// <remarks>Caches the result</remarks>
|
|
/// <returns></returns>
|
|
[Authorize("RequireAdminRole")]
|
|
[HttpPost]
|
|
public async Task<ActionResult> UpdateLicense(UpdateLicenseDto dto)
|
|
{
|
|
try
|
|
{
|
|
await _licenseService.AddLicense(dto.License.Trim(), dto.Email.Trim());
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
return BadRequest(await _localizationService.Translate(User.GetUserId(), ex.Message));
|
|
}
|
|
return Ok();
|
|
}
|
|
}
|