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 Microsoft.AspNetCore.Authorization; using Microsoft.AspNetCore.Mvc; namespace API.Controllers { [Authorize] public class UsersController : BaseApiController { private readonly IUnitOfWork _unitOfWork; public UsersController(IUnitOfWork unitOfWork) { _unitOfWork = unitOfWork; } [Authorize(Policy = "RequireAdminRole")] [HttpDelete("delete-user")] public async Task DeleteUser(string username) { var user = await _unitOfWork.UserRepository.GetUserByUsernameAsync(username); _unitOfWork.UserRepository.Delete(user); if (await _unitOfWork.CommitAsync()) return Ok(); return BadRequest("Could not delete the user."); } [Authorize(Policy = "RequireAdminRole")] [HttpGet] public async Task>> GetUsers() { return Ok(await _unitOfWork.UserRepository.GetMembersAsync()); } [AllowAnonymous] [HttpGet("names")] public async Task>> GetUserNames() { var setting = await _unitOfWork.SettingsRepository.GetSettingsDtoAsync(); if (setting.EnableAuthentication) { return Unauthorized("This API cannot be used given your server's configuration"); } var members = await _unitOfWork.UserRepository.GetMembersAsync(); return Ok(members.Select(m => m.Username)); } [HttpGet("has-reading-progress")] public async Task> HasReadingProgress(int libraryId) { var userId = await _unitOfWork.UserRepository.GetUserIdByUsernameAsync(User.GetUsername()); var library = await _unitOfWork.LibraryRepository.GetLibraryForIdAsync(libraryId, LibraryIncludes.None); return Ok(await _unitOfWork.AppUserProgressRepository.UserHasProgress(library.Type, userId)); } [HttpGet("has-library-access")] public async Task> HasLibraryAccess(int libraryId) { var libs = await _unitOfWork.LibraryRepository.GetLibraryDtosForUsernameAsync(User.GetUsername()); return Ok(libs.Any(x => x.Id == libraryId)); } [HttpPost("update-preferences")] public async Task> UpdatePreferences(UserPreferencesDto preferencesDto) { var existingPreferences = await _unitOfWork.UserRepository.GetPreferencesAsync(User.GetUsername()); existingPreferences.ReadingDirection = preferencesDto.ReadingDirection; existingPreferences.ScalingOption = preferencesDto.ScalingOption; existingPreferences.PageSplitOption = preferencesDto.PageSplitOption; existingPreferences.AutoCloseMenu = preferencesDto.AutoCloseMenu; existingPreferences.ReaderMode = preferencesDto.ReaderMode; existingPreferences.BookReaderMargin = preferencesDto.BookReaderMargin; existingPreferences.BookReaderLineSpacing = preferencesDto.BookReaderLineSpacing; existingPreferences.BookReaderFontFamily = preferencesDto.BookReaderFontFamily; existingPreferences.BookReaderDarkMode = preferencesDto.BookReaderDarkMode; existingPreferences.BookReaderFontSize = preferencesDto.BookReaderFontSize; existingPreferences.BookReaderTapToPaginate = preferencesDto.BookReaderTapToPaginate; existingPreferences.SiteDarkMode = preferencesDto.SiteDarkMode; _unitOfWork.UserRepository.Update(existingPreferences); if (await _unitOfWork.CommitAsync()) { return Ok(preferencesDto); } return BadRequest("There was an issue saving preferences."); } } }