access token generation added

This commit is contained in:
2026-01-30 00:18:25 +01:00
Unverified
parent 236a7a0fe1
commit dc12ee75e5
8 changed files with 96 additions and 16 deletions

View File

@@ -10,11 +10,13 @@ public class AuthPasswordHandler : IRequestHandler<AuthPasswordCommand, AuthPass
{
private readonly DatabaseContext _databaseContext;
private readonly IPasswordHasher _passwordHasher;
private readonly ITokenGenerator _tokenGenerator;
public AuthPasswordHandler(DatabaseContext databaseContext, IPasswordHasher passwordHasher)
public AuthPasswordHandler(DatabaseContext databaseContext, IPasswordHasher passwordHasher, ITokenGenerator tokenGenerator)
{
_databaseContext = databaseContext;
_passwordHasher = passwordHasher;
_tokenGenerator = tokenGenerator;
}
public async Task<AuthPasswordResult> Handle(AuthPasswordCommand request, CancellationToken cancellationToken)
@@ -31,6 +33,8 @@ public class AuthPasswordHandler : IRequestHandler<AuthPasswordCommand, AuthPass
return AuthPasswordResult.Failure();
}
string accessToken = _tokenGenerator.GenerateAccessToken(account);
return null;
}
}

View File

@@ -1,4 +1,5 @@
using MediatR;
using Microsoft.EntityFrameworkCore.Storage;
using TimetableDesigner.Backend.Events.OutboxPattern;
using TimetableDesigner.Backend.Services.Authentication.Core.Helpers;
using TimetableDesigner.Backend.Services.Authentication.Database;
@@ -21,20 +22,25 @@ public class RegisterHandler : IRequestHandler<RegisterCommand, RegisterResult>
public async Task<RegisterResult> Handle(RegisterCommand command, CancellationToken cancellationToken)
{
PasswordHashData hash = _passwordHasher.CreateHash(command.Password);
Account account = new Account
{
Email = command.Email,
Password = hash.Hash,
PasswordSalt = hash.Salt,
};
await _databaseContext.Accounts.AddAsync(account, cancellationToken);
await _databaseContext.SaveChangesAsync(cancellationToken);
Event eventData = Event.Create(new RegisterEvent(account.Id, account.Email));
await _databaseContext.Events.AddAsync(eventData, cancellationToken);
await _databaseContext.SaveChangesAsync(cancellationToken);
await using (IDbContextTransaction transaction = await _databaseContext.Database.BeginTransactionAsync(cancellationToken))
{
await _databaseContext.Accounts.AddAsync(account, cancellationToken);
await _databaseContext.SaveChangesAsync(cancellationToken);
Event eventData = Event.Create(new RegisterEvent(account.Id, account.Email));
await _databaseContext.Events.AddAsync(eventData, cancellationToken);
await _databaseContext.SaveChangesAsync(cancellationToken);
await transaction.CommitAsync(cancellationToken);
}
return new RegisterResult(account.Id, account.Email);
}