mirror of
				https://github.com/Kareadita/Kavita.git
				synced 2025-10-26 00:02:29 -04:00 
			
		
		
		
	* Ensure that after we assign a role to a user, we show it immediately * Cached libraryType api as that is not going to change in a viewing session. Moved some components around to tighten bundles. * Cleaned up more TODOs * Refactored Configuration to use getter and setters so that the interface is a lot cleaner. Updated HashUtil to use JWT Secret instead of Machine name (as docker machine name is random each boot).
		
			
				
	
	
		
			136 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			136 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| using System;
 | |
| using System.Collections.Generic;
 | |
| using System.IO;
 | |
| using System.Linq;
 | |
| using System.Threading.Tasks;
 | |
| using API.DTOs;
 | |
| using API.Entities.Enums;
 | |
| using API.Extensions;
 | |
| using API.Helpers.Converters;
 | |
| using API.Interfaces;
 | |
| using Kavita.Common;
 | |
| using Kavita.Common.Extensions;
 | |
| using Microsoft.AspNetCore.Authorization;
 | |
| using Microsoft.AspNetCore.Mvc;
 | |
| using Microsoft.Extensions.Logging;
 | |
| 
 | |
| namespace API.Controllers
 | |
| {
 | |
|     [Authorize(Policy = "RequireAdminRole")]
 | |
|     public class SettingsController : BaseApiController
 | |
|     {
 | |
|         private readonly ILogger<SettingsController> _logger;
 | |
|         private readonly IUnitOfWork _unitOfWork;
 | |
|         private readonly ITaskScheduler _taskScheduler;
 | |
| 
 | |
|         public SettingsController(ILogger<SettingsController> logger, IUnitOfWork unitOfWork, ITaskScheduler taskScheduler)
 | |
|         {
 | |
|             _logger = logger;
 | |
|             _unitOfWork = unitOfWork;
 | |
|             _taskScheduler = taskScheduler;
 | |
|         }
 | |
| 
 | |
|         [HttpGet]
 | |
|         public async Task<ActionResult<ServerSettingDto>> GetSettings()
 | |
|         {
 | |
|             var settingsDto = await _unitOfWork.SettingsRepository.GetSettingsDtoAsync();
 | |
|             settingsDto.Port = Configuration.Port;
 | |
|             settingsDto.LoggingLevel = Configuration.LogLevel;
 | |
|             return Ok(settingsDto);
 | |
|         }
 | |
| 
 | |
|         [HttpPost]
 | |
|         public async Task<ActionResult<ServerSettingDto>> UpdateSettings(ServerSettingDto updateSettingsDto)
 | |
|         {
 | |
|             _logger.LogInformation("{UserName}  is updating Server Settings", User.GetUsername());
 | |
| 
 | |
|             if (updateSettingsDto.CacheDirectory.Equals(string.Empty))
 | |
|             {
 | |
|                 return BadRequest("Cache Directory cannot be empty");
 | |
|             }
 | |
| 
 | |
|             if (!Directory.Exists(updateSettingsDto.CacheDirectory))
 | |
|             {
 | |
|                 return BadRequest("Directory does not exist or is not accessible.");
 | |
|             }
 | |
| 
 | |
|             // We do not allow CacheDirectory changes, so we will ignore.
 | |
|             var currentSettings = await _unitOfWork.SettingsRepository.GetSettingsAsync();
 | |
| 
 | |
|             foreach (var setting in currentSettings)
 | |
|             {
 | |
|                 if (setting.Key == ServerSettingKey.TaskBackup && updateSettingsDto.TaskBackup != setting.Value)
 | |
|                 {
 | |
|                     setting.Value = updateSettingsDto.TaskBackup;
 | |
|                     _unitOfWork.SettingsRepository.Update(setting);
 | |
|                 }
 | |
| 
 | |
|                 if (setting.Key == ServerSettingKey.TaskScan && updateSettingsDto.TaskScan != setting.Value)
 | |
|                 {
 | |
|                     setting.Value = updateSettingsDto.TaskScan;
 | |
|                     _unitOfWork.SettingsRepository.Update(setting);
 | |
|                 }
 | |
| 
 | |
|                 if (setting.Key == ServerSettingKey.Port && updateSettingsDto.Port + string.Empty != setting.Value)
 | |
|                 {
 | |
|                     setting.Value = updateSettingsDto.Port + string.Empty;
 | |
|                     // Port is managed in appSetting.json
 | |
|                     Configuration.Port = updateSettingsDto.Port;
 | |
|                     _unitOfWork.SettingsRepository.Update(setting);
 | |
|                 }
 | |
| 
 | |
|                 if (setting.Key == ServerSettingKey.LoggingLevel && updateSettingsDto.LoggingLevel + string.Empty != setting.Value)
 | |
|                 {
 | |
|                     setting.Value = updateSettingsDto.LoggingLevel + string.Empty;
 | |
|                     Configuration.LogLevel = updateSettingsDto.LoggingLevel;
 | |
|                     _unitOfWork.SettingsRepository.Update(setting);
 | |
|                 }
 | |
| 
 | |
|                 if (setting.Key == ServerSettingKey.AllowStatCollection && updateSettingsDto.AllowStatCollection + string.Empty != setting.Value)
 | |
|                 {
 | |
|                     setting.Value = updateSettingsDto.AllowStatCollection + string.Empty;
 | |
|                     _unitOfWork.SettingsRepository.Update(setting);
 | |
|                     if (!updateSettingsDto.AllowStatCollection)
 | |
|                     {
 | |
|                         _taskScheduler.CancelStatsTasks();
 | |
|                     }
 | |
|                     else
 | |
|                     {
 | |
|                         _taskScheduler.ScheduleStatsTasks();
 | |
|                     }
 | |
|                 }
 | |
|             }
 | |
| 
 | |
|             if (!_unitOfWork.HasChanges()) return Ok("Nothing was updated");
 | |
| 
 | |
|             if (!_unitOfWork.HasChanges() || !await _unitOfWork.CommitAsync())
 | |
|             {
 | |
|                 await _unitOfWork.RollbackAsync();
 | |
|                 return BadRequest("There was a critical issue. Please try again.");
 | |
|             }
 | |
| 
 | |
|             _logger.LogInformation("Server Settings updated");
 | |
|             _taskScheduler.ScheduleTasks();
 | |
|             return Ok(updateSettingsDto);
 | |
|         }
 | |
| 
 | |
|         [HttpGet("task-frequencies")]
 | |
|         public ActionResult<IEnumerable<string>> GetTaskFrequencies()
 | |
|         {
 | |
|             return Ok(CronConverter.Options);
 | |
|         }
 | |
| 
 | |
|         [HttpGet("library-types")]
 | |
|         public ActionResult<IEnumerable<string>> GetLibraryTypes()
 | |
|         {
 | |
|           return Ok(Enum.GetValues<LibraryType>().Select(t => t.ToDescription()));
 | |
|         }
 | |
| 
 | |
|         [HttpGet("log-levels")]
 | |
|         public ActionResult<IEnumerable<string>> GetLogLevels()
 | |
|         {
 | |
|             return Ok(new [] {"Trace", "Debug", "Information", "Warning", "Critical"});
 | |
|         }
 | |
|     }
 | |
| }
 |