mirror of
				https://github.com/Kareadita/Kavita.git
				synced 2025-10-31 18:47:05 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			168 lines
		
	
	
		
			7.4 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			168 lines
		
	
	
		
			7.4 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| using System.Collections.Generic;
 | |
| using System.Linq;
 | |
| using System.Threading.Tasks;
 | |
| using API.Data;
 | |
| using API.Data.Repositories;
 | |
| using API.DTOs;
 | |
| using API.Extensions;
 | |
| using API.Services;
 | |
| using API.SignalR;
 | |
| using AutoMapper;
 | |
| using Microsoft.AspNetCore.Authorization;
 | |
| using Microsoft.AspNetCore.Mvc;
 | |
| 
 | |
| namespace API.Controllers;
 | |
| 
 | |
| #nullable enable
 | |
| 
 | |
| [Authorize]
 | |
| public class UsersController : BaseApiController
 | |
| {
 | |
|     private readonly IUnitOfWork _unitOfWork;
 | |
|     private readonly IMapper _mapper;
 | |
|     private readonly IEventHub _eventHub;
 | |
|     private readonly ILocalizationService _localizationService;
 | |
| 
 | |
|     public UsersController(IUnitOfWork unitOfWork, IMapper mapper, IEventHub eventHub,
 | |
|         ILocalizationService localizationService)
 | |
|     {
 | |
|         _unitOfWork = unitOfWork;
 | |
|         _mapper = mapper;
 | |
|         _eventHub = eventHub;
 | |
|         _localizationService = localizationService;
 | |
|     }
 | |
| 
 | |
|     [Authorize(Policy = "RequireAdminRole")]
 | |
|     [HttpDelete("delete-user")]
 | |
|     public async Task<ActionResult> DeleteUser(string username)
 | |
|     {
 | |
|         var user = await _unitOfWork.UserRepository.GetUserByUsernameAsync(username);
 | |
|         _unitOfWork.UserRepository.Delete(user);
 | |
| 
 | |
|         //(TODO: After updating a role or removing a user, delete their token)
 | |
|         // await _userManager.RemoveAuthenticationTokenAsync(user, TokenOptions.DefaultProvider, RefreshTokenName);
 | |
| 
 | |
|         if (await _unitOfWork.CommitAsync()) return Ok();
 | |
| 
 | |
|         return BadRequest(await _localizationService.Translate(User.GetUserId(), "generic-user-delete"));
 | |
|     }
 | |
| 
 | |
|     /// <summary>
 | |
|     /// Returns all users of this server
 | |
|     /// </summary>
 | |
|     /// <param name="includePending">This will include pending members</param>
 | |
|     /// <returns></returns>
 | |
|     [Authorize(Policy = "RequireAdminRole")]
 | |
|     [HttpGet]
 | |
|     public async Task<ActionResult<IEnumerable<MemberDto>>> GetUsers(bool includePending = false)
 | |
|     {
 | |
|         return Ok(await _unitOfWork.UserRepository.GetEmailConfirmedMemberDtosAsync(!includePending));
 | |
|     }
 | |
| 
 | |
|     [HttpGet("myself")]
 | |
|     public async Task<ActionResult<IEnumerable<MemberDto>>> GetMyself()
 | |
|     {
 | |
|         var users = await _unitOfWork.UserRepository.GetAllUsersAsync();
 | |
|         return Ok(users.Where(u => u.UserName == User.GetUsername()).DefaultIfEmpty().Select(u => _mapper.Map<MemberDto>(u)).SingleOrDefault());
 | |
|     }
 | |
| 
 | |
| 
 | |
|     [HttpGet("has-reading-progress")]
 | |
|     public async Task<ActionResult<bool>> HasReadingProgress(int libraryId)
 | |
|     {
 | |
|         var library = await _unitOfWork.LibraryRepository.GetLibraryForIdAsync(libraryId);
 | |
|         if (library == null) return BadRequest(await _localizationService.Translate(User.GetUserId(), "library-doesnt-exist"));
 | |
|         return Ok(await _unitOfWork.AppUserProgressRepository.UserHasProgress(library.Type, User.GetUserId()));
 | |
|     }
 | |
| 
 | |
|     [HttpGet("has-library-access")]
 | |
|     public ActionResult<bool> HasLibraryAccess(int libraryId)
 | |
|     {
 | |
|         var libs = _unitOfWork.LibraryRepository.GetLibraryDtosForUsernameAsync(User.GetUsername());
 | |
|         return Ok(libs.Any(x => x.Id == libraryId));
 | |
|     }
 | |
| 
 | |
|     [HttpPost("update-preferences")]
 | |
|     public async Task<ActionResult<UserPreferencesDto>> UpdatePreferences(UserPreferencesDto preferencesDto)
 | |
|     {
 | |
|         var user = await _unitOfWork.UserRepository.GetUserByUsernameAsync(User.GetUsername(),
 | |
|             AppUserIncludes.UserPreferences);
 | |
|         if (user == null) return Unauthorized();
 | |
|         var existingPreferences = user!.UserPreferences;
 | |
| 
 | |
|         existingPreferences.ReadingDirection = preferencesDto.ReadingDirection;
 | |
|         existingPreferences.ScalingOption = preferencesDto.ScalingOption;
 | |
|         existingPreferences.PageSplitOption = preferencesDto.PageSplitOption;
 | |
|         existingPreferences.AutoCloseMenu = preferencesDto.AutoCloseMenu;
 | |
|         existingPreferences.ShowScreenHints = preferencesDto.ShowScreenHints;
 | |
|         existingPreferences.EmulateBook = preferencesDto.EmulateBook;
 | |
|         existingPreferences.ReaderMode = preferencesDto.ReaderMode;
 | |
|         existingPreferences.LayoutMode = preferencesDto.LayoutMode;
 | |
|         existingPreferences.BackgroundColor = string.IsNullOrEmpty(preferencesDto.BackgroundColor) ? "#000000" : preferencesDto.BackgroundColor;
 | |
|         existingPreferences.BookReaderMargin = preferencesDto.BookReaderMargin;
 | |
|         existingPreferences.BookReaderLineSpacing = preferencesDto.BookReaderLineSpacing;
 | |
|         existingPreferences.BookReaderFontFamily = preferencesDto.BookReaderFontFamily;
 | |
|         existingPreferences.BookReaderFontSize = preferencesDto.BookReaderFontSize;
 | |
|         existingPreferences.BookReaderTapToPaginate = preferencesDto.BookReaderTapToPaginate;
 | |
|         existingPreferences.BookReaderReadingDirection = preferencesDto.BookReaderReadingDirection;
 | |
|         existingPreferences.BookReaderWritingStyle = preferencesDto.BookReaderWritingStyle;
 | |
|         existingPreferences.BookThemeName = preferencesDto.BookReaderThemeName;
 | |
|         existingPreferences.BookReaderLayoutMode = preferencesDto.BookReaderLayoutMode;
 | |
|         existingPreferences.BookReaderImmersiveMode = preferencesDto.BookReaderImmersiveMode;
 | |
|         existingPreferences.GlobalPageLayoutMode = preferencesDto.GlobalPageLayoutMode;
 | |
|         existingPreferences.BlurUnreadSummaries = preferencesDto.BlurUnreadSummaries;
 | |
|         existingPreferences.LayoutMode = preferencesDto.LayoutMode;
 | |
|         existingPreferences.PromptForDownloadSize = preferencesDto.PromptForDownloadSize;
 | |
|         existingPreferences.NoTransitions = preferencesDto.NoTransitions;
 | |
|         existingPreferences.SwipeToPaginate = preferencesDto.SwipeToPaginate;
 | |
|         existingPreferences.CollapseSeriesRelationships = preferencesDto.CollapseSeriesRelationships;
 | |
|         existingPreferences.ShareReviews = preferencesDto.ShareReviews;
 | |
| 
 | |
|         existingPreferences.PdfTheme = preferencesDto.PdfTheme;
 | |
|         existingPreferences.PdfScrollMode = preferencesDto.PdfScrollMode;
 | |
|         existingPreferences.PdfSpreadMode = preferencesDto.PdfSpreadMode;
 | |
| 
 | |
|         if (preferencesDto.Theme != null && existingPreferences.Theme.Id != preferencesDto.Theme?.Id)
 | |
|         {
 | |
|             var theme = await _unitOfWork.SiteThemeRepository.GetTheme(preferencesDto.Theme!.Id);
 | |
|             existingPreferences.Theme = theme ?? await _unitOfWork.SiteThemeRepository.GetDefaultTheme();
 | |
|         }
 | |
| 
 | |
| 
 | |
|         if (_localizationService.GetLocales().Contains(preferencesDto.Locale))
 | |
|         {
 | |
|             existingPreferences.Locale = preferencesDto.Locale;
 | |
|         }
 | |
| 
 | |
|         _unitOfWork.UserRepository.Update(existingPreferences);
 | |
| 
 | |
|         if (!await _unitOfWork.CommitAsync()) return BadRequest(await _localizationService.Translate(User.GetUserId(), "generic-user-pref"));
 | |
| 
 | |
|         await _eventHub.SendMessageToAsync(MessageFactory.UserUpdate, MessageFactory.UserUpdateEvent(user.Id, user.UserName!), user.Id);
 | |
|         return Ok(preferencesDto);
 | |
|     }
 | |
| 
 | |
|     /// <summary>
 | |
|     /// Returns the preferences of the user
 | |
|     /// </summary>
 | |
|     /// <returns></returns>
 | |
|     [HttpGet("get-preferences")]
 | |
|     public async Task<ActionResult<UserPreferencesDto>> GetPreferences()
 | |
|     {
 | |
|         return _mapper.Map<UserPreferencesDto>(
 | |
|             await _unitOfWork.UserRepository.GetPreferencesAsync(User.GetUsername()));
 | |
| 
 | |
|     }
 | |
| 
 | |
|     /// <summary>
 | |
|     /// Returns a list of the user names within the system
 | |
|     /// </summary>
 | |
|     /// <returns></returns>
 | |
|     [Authorize(Policy = "RequireAdminRole")]
 | |
|     [HttpGet("names")]
 | |
|     public async Task<ActionResult<IEnumerable<string>>> GetUserNames()
 | |
|     {
 | |
|         return Ok((await _unitOfWork.UserRepository.GetAllUsersAsync()).Select(u => u.UserName));
 | |
|     }
 | |
| }
 |