< Summary - Syki

Information
Class: Syki.Back.Features.Identity.TwoFactorLogin.TwoFactorLoginService
Assembly: Back
File(s): /home/runner/work/syki/syki/Back/Features/Identity/TwoFactorLogin/TwoFactorLoginService.cs
Tag: 56_26538939494
Line coverage
100%
Covered lines: 21
Uncovered lines: 0
Coverable lines: 21
Total lines: 43
Line coverage: 100%
Branch coverage
90%
Covered branches: 9
Total branches: 10
Branch coverage: 90%
Method coverage

Feature is only available for sponsors

Upgrade to PRO version

Metrics

MethodBranch coverage Crap Score Cyclomatic complexity Line coverage
.ctor(...)100%11100%
Login()90%1010100%

File(s)

/home/runner/work/syki/syki/Back/Features/Identity/TwoFactorLogin/TwoFactorLoginService.cs

#LineLine coverage
 1using System.Security.Claims;
 2using Syki.Back.Domain.Identity;
 3using Syki.Back.Features.Cross.SignIn;
 4using Microsoft.AspNetCore.Authentication;
 5
 6namespace Syki.Back.Features.Identity.TwoFactorLogin;
 7
 408public class TwoFactorLoginService(
 409    SignInService service,
 4010    IHttpContextAccessor httpCtx,
 4011    UserManager<SykiUser> userManager) : ISykiService
 12{
 13    public async Task<OneOf<TwoFactorLoginOut, SykiError>> Login(TwoFactorLoginIn data)
 14    {
 4015        var authResult = await httpCtx.HttpContext.AuthenticateAsync(IdentityConstants.TwoFactorUserIdScheme);
 4016        var userId = authResult.Principal?.FindFirstValue(ClaimTypes.Name);
 4617        if (userId == null) return InvalidTwoFactorToken.I;
 18
 3419        var user = await userManager.FindByIdAsync(userId);
 3420        if (user == null) return InvalidTwoFactorToken.I;
 21
 3822        if (await userManager.IsLockedOutAsync(user)) return InvalidTwoFactorToken.I;
 23
 3024        var token = data.Token!.OnlyNumbers();
 3025        var tokenProvider = userManager.Options.Tokens.AuthenticatorTokenProvider;
 3026        var isValid = await userManager.VerifyTwoFactorTokenAsync(user, tokenProvider, token);
 27
 3028        if (!isValid)
 29        {
 2430            await userManager.AccessFailedAsync(user);
 2431            return InvalidTwoFactorToken.I;
 32        }
 33
 634        await userManager.ResetAccessFailedCountAsync(user);
 35
 36        // Clear the 2FA cookie (we use JWT for auth)
 637        await httpCtx.HttpContext.SignOutAsync(IdentityConstants.TwoFactorUserIdScheme);
 38
 639        var jwtResult = await service.SignIn(user.Email);
 40
 641        return jwtResult.ToTwoFactorLoginOut();
 4042    }
 43}