< Summary

Information
Class: Elsa.Diagnostics.ConsoleLogs.Endpoints.ConsoleLogs.Recent.Endpoint
Assembly: Elsa.Diagnostics.ConsoleLogs
File(s): /home/runner/work/elsa-core/elsa-core/src/modules/Elsa.Diagnostics.ConsoleLogs/Endpoints/ConsoleLogs/Recent/Endpoint.cs
Line coverage
75%
Covered lines: 22
Uncovered lines: 7
Coverable lines: 29
Total lines: 66
Line coverage: 75.8%
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%
.cctor()100%11100%
Configure()100%11100%
ExecuteAsync()75%4471.42%
ReadJsonBodyAsync()75%11864.28%
DeserializeJsonBodyAsync()100%11100%

File(s)

/home/runner/work/elsa-core/elsa-core/src/modules/Elsa.Diagnostics.ConsoleLogs/Endpoints/ConsoleLogs/Recent/Endpoint.cs

#LineLine coverage
 1using System.Text.Json;
 2using ConsoleLogStreaming.Core;
 3using Elsa.Abstractions;
 4using Elsa.Diagnostics.ConsoleLogs.Permissions;
 5using Elsa.Diagnostics.ConsoleLogs.Services;
 6using JetBrains.Annotations;
 7using Microsoft.AspNetCore.Http;
 8
 9namespace Elsa.Diagnostics.ConsoleLogs.Endpoints.ConsoleLogs.Recent;
 10
 11[PublicAPI]
 912internal class Endpoint(IConsoleLogProvider provider) : ElsaEndpointWithoutRequest<RecentConsoleLogsResult>
 13{
 214    private static readonly JsonSerializerOptions JsonSerializerOptions = new(JsonSerializerDefaults.Web);
 15
 16    public override void Configure()
 17    {
 118        Verbs(FastEndpoints.Http.POST);
 119        Routes("/diagnostics/console-logs/recent");
 120        ConfigurePermissions(ConsoleLogsPermissions.Read);
 121    }
 22
 23    public override async Task<RecentConsoleLogsResult> ExecuteAsync(CancellationToken cancellationToken)
 24    {
 825        var request = await ReadJsonBodyAsync(cancellationToken);
 826        if (ValidationFailed)
 27        {
 028            await Send.ErrorsAsync(StatusCodes.Status400BadRequest, cancellationToken);
 029            return new();
 30        }
 31
 832        var result = await provider.GetRecentAsync(ConsoleLogFilterMapper.ToStreamingFilter(request ?? new()), cancellat
 833        return result;
 834    }
 35
 36    private async Task<ElsaConsoleLogFilter?> ReadJsonBodyAsync(CancellationToken cancellationToken)
 37    {
 838        if (HttpContext.Request.ContentLength is 0)
 039            return null;
 40
 841        if (!HttpContext.Request.HasJsonContentType())
 042            return null;
 43
 844        using var body = new MemoryStream();
 845        await HttpContext.Request.Body.CopyToAsync(body, cancellationToken);
 46
 847        if (body.Length == 0)
 148            return null;
 49
 750        body.Position = 0;
 51        try
 52        {
 753            return await DeserializeJsonBodyAsync(body, cancellationToken);
 54        }
 055        catch (JsonException)
 56        {
 057            AddError("Invalid console log filter JSON.");
 058            return null;
 59        }
 860    }
 61
 62    internal static async ValueTask<ElsaConsoleLogFilter?> DeserializeJsonBodyAsync(Stream body, CancellationToken cance
 63    {
 864        return await JsonSerializer.DeserializeAsync<ElsaConsoleLogFilter>(body, JsonSerializerOptions, cancellationToke
 765    }
 66}