< Summary

Information
Class: Elsa.Identity.Services.DefaultApplicationCredentialsValidator
Assembly: Elsa.Identity
File(s): /home/runner/work/elsa-core/elsa-core/src/modules/Elsa.Identity/Services/DefaultApplicationCredentialsValidator.cs
Line coverage
82%
Covered lines: 33
Uncovered lines: 7
Coverable lines: 40
Total lines: 90
Line coverage: 82.5%
Branch coverage
75%
Covered branches: 9
Total branches: 12
Branch coverage: 75%
Method coverage

Feature is only available for sponsors

Upgrade to PRO version

Metrics

MethodBranch coverage Crap Score Cyclomatic complexity Line coverage
.ctor(...)100%11100%
.ctor(...)100%11100%
.ctor(...)100%22100%
ValidateAsync()70%111075.86%

File(s)

/home/runner/work/elsa-core/elsa-core/src/modules/Elsa.Identity/Services/DefaultApplicationCredentialsValidator.cs

#LineLine coverage
 1using Elsa.Extensions;
 2using Elsa.Identity.Contracts;
 3using Elsa.Identity.Entities;
 4using JetBrains.Annotations;
 5using Microsoft.Extensions.Logging;
 6using Microsoft.Extensions.Logging.Abstractions;
 7
 8namespace Elsa.Identity.Services;
 9
 10/// <inheritdoc />
 11[PublicAPI]
 12public class DefaultApplicationCredentialsValidator : IApplicationCredentialsValidator
 13{
 14    private readonly IApiKeyParser _apiKeyParser;
 15    private readonly IApplicationProvider _applicationProvider;
 16    private readonly IApplicationStore? _applicationStore;
 17    private readonly ISecretHasher _secretHasher;
 18    private readonly ILogger<DefaultApplicationCredentialsValidator> _logger;
 19
 20    /// <summary>
 21    /// Initializes a new instance of the <see cref="DefaultApplicationCredentialsValidator"/> class.
 22    /// </summary>
 123    public DefaultApplicationCredentialsValidator(IApiKeyParser apiKeyParser, IApplicationProvider applicationProvider, 
 24    {
 125    }
 26
 27    /// <summary>
 28    /// Initializes a new instance of the <see cref="DefaultApplicationCredentialsValidator"/> class.
 29    /// </summary>
 230    public DefaultApplicationCredentialsValidator(IApiKeyParser apiKeyParser, IApplicationProvider applicationProvider, 
 31    {
 232    }
 33
 34    /// <summary>
 35    /// Initializes a new instance of the <see cref="DefaultApplicationCredentialsValidator"/> class.
 36    /// </summary>
 337    public DefaultApplicationCredentialsValidator(IApiKeyParser apiKeyParser, IApplicationProvider applicationProvider, 
 38    {
 339        _apiKeyParser = apiKeyParser;
 340        _applicationProvider = applicationProvider;
 341        _applicationStore = applicationStore;
 342        _secretHasher = secretHasher;
 343        _logger = logger ?? NullLogger<DefaultApplicationCredentialsValidator>.Instance;
 344    }
 45
 46    /// <inheritdoc />
 47    public async ValueTask<Application?> ValidateAsync(string apiKey, CancellationToken cancellationToken = default)
 48    {
 349        if(string.IsNullOrWhiteSpace(apiKey))
 050            return null;
 51
 352        var clientId = _apiKeyParser.Parse(apiKey);
 353        var application = await _applicationProvider.FindByClientIdAsync(clientId, cancellationToken);
 54
 355        if(application == null)
 056            return null;
 57
 358        var isValidApiKey = _secretHasher.VerifySecret(apiKey, application.HashedApiKey, application.HashedApiKeySalt, o
 59
 360        if (!isValidApiKey)
 061            return null;
 62
 363        if (needsRehash && _applicationStore != null)
 64        {
 265            var previousHashedApiKey = application.HashedApiKey;
 266            var previousHashedApiKeySalt = application.HashedApiKeySalt;
 267            var hashedApiKey = _secretHasher.HashSecret(apiKey);
 268            application.HashedApiKey = hashedApiKey.EncodeSecret();
 269            application.HashedApiKeySalt = hashedApiKey.EncodeSalt();
 70            try
 71            {
 272                await _applicationStore.SaveAsync(application, cancellationToken);
 173            }
 074            catch (OperationCanceledException)
 75            {
 076                application.HashedApiKey = previousHashedApiKey;
 077                application.HashedApiKeySalt = previousHashedApiKeySalt;
 078                throw;
 79            }
 180            catch (Exception e)
 81            {
 182                application.HashedApiKey = previousHashedApiKey;
 183                application.HashedApiKeySalt = previousHashedApiKeySalt;
 184                _logger.LogWarning(e, "Failed to save upgraded API key hash for application {ApplicationId}.", applicati
 185            }
 286        }
 87
 388        return application;
 389    }
 90}