say NO to try-catch in controllers

- added ExceptionsMiddleware.cs
- added more Exception types
- removed all exceptions logic in controllers
This commit is contained in:
Вячеслав 2025-04-18 15:15:32 +05:00
parent eb271793ad
commit 55e82425a9
8 changed files with 75 additions and 20 deletions

View file

@ -0,0 +1,10 @@
namespace SurveyBackend.Services.Exceptions;
public class NotFoundException : ServiceException
{
public override int StatusCode => 404;
public NotFoundException(string message) : base(message)
{
}
}

View file

@ -16,12 +16,12 @@ public class AuthorizationService : IAuthorizationService
_passwordHasher = passwordHasher;
}
public async Task<string?> LogInUser(string email, string password)
public async Task<string> LogInUser(string email, string password)
{
var user = await _userService.GetUserByEmail(email);
if (user is null || !_passwordHasher.Verify(password, user.Password))
if (!_passwordHasher.Verify(password, user.Password))
{
throw new UnauthorizedException("Email or password is incorrect.");
throw new UnauthorizedException("Password is incorrect.");
}
var token = TokenHelper.GetAuthToken(user);

View file

@ -1,6 +1,7 @@
using SurveyBackend.Core.Models;
using SurveyBackend.Core.Repositories;
using SurveyBackend.Core.Services;
using SurveyBackend.Services.Exceptions;
namespace SurveyBackend.Services.Services;
@ -13,9 +14,9 @@ public class UserService : IUserService
_userRepository = userRepository;
}
public async Task<User?> GetUserByEmail(string email)
public async Task<User> GetUserByEmail(string email)
{
return await _userRepository.GetUserByEmail(email);
return await _userRepository.GetUserByEmail(email) ?? throw new NotFoundException("Email not found");
}
public async Task CreateUserAsync(User user)