| | | 1 | | using System.Text.Json; |
| | | 2 | | using ConsoleLogStreaming.Core; |
| | | 3 | | using Elsa.Abstractions; |
| | | 4 | | using Elsa.Diagnostics.ConsoleLogs.Permissions; |
| | | 5 | | using Elsa.Diagnostics.ConsoleLogs.Services; |
| | | 6 | | using JetBrains.Annotations; |
| | | 7 | | using Microsoft.AspNetCore.Http; |
| | | 8 | | |
| | | 9 | | namespace Elsa.Diagnostics.ConsoleLogs.Endpoints.ConsoleLogs.Recent; |
| | | 10 | | |
| | | 11 | | [PublicAPI] |
| | 9 | 12 | | internal class Endpoint(IConsoleLogProvider provider) : ElsaEndpointWithoutRequest<RecentConsoleLogsResult> |
| | | 13 | | { |
| | 2 | 14 | | private static readonly JsonSerializerOptions JsonSerializerOptions = new(JsonSerializerDefaults.Web); |
| | | 15 | | |
| | | 16 | | public override void Configure() |
| | | 17 | | { |
| | 1 | 18 | | Verbs(FastEndpoints.Http.POST); |
| | 1 | 19 | | Routes("/diagnostics/console-logs/recent"); |
| | 1 | 20 | | ConfigurePermissions(ConsoleLogsPermissions.Read); |
| | 1 | 21 | | } |
| | | 22 | | |
| | | 23 | | public override async Task<RecentConsoleLogsResult> ExecuteAsync(CancellationToken cancellationToken) |
| | | 24 | | { |
| | 8 | 25 | | var request = await ReadJsonBodyAsync(cancellationToken); |
| | 8 | 26 | | if (ValidationFailed) |
| | | 27 | | { |
| | 0 | 28 | | await Send.ErrorsAsync(StatusCodes.Status400BadRequest, cancellationToken); |
| | 0 | 29 | | return new(); |
| | | 30 | | } |
| | | 31 | | |
| | 8 | 32 | | var result = await provider.GetRecentAsync(ConsoleLogFilterMapper.ToStreamingFilter(request ?? new()), cancellat |
| | 8 | 33 | | return result; |
| | 8 | 34 | | } |
| | | 35 | | |
| | | 36 | | private async Task<ElsaConsoleLogFilter?> ReadJsonBodyAsync(CancellationToken cancellationToken) |
| | | 37 | | { |
| | 8 | 38 | | if (HttpContext.Request.ContentLength is 0) |
| | 0 | 39 | | return null; |
| | | 40 | | |
| | 8 | 41 | | if (!HttpContext.Request.HasJsonContentType()) |
| | 0 | 42 | | return null; |
| | | 43 | | |
| | 8 | 44 | | using var body = new MemoryStream(); |
| | 8 | 45 | | await HttpContext.Request.Body.CopyToAsync(body, cancellationToken); |
| | | 46 | | |
| | 8 | 47 | | if (body.Length == 0) |
| | 1 | 48 | | return null; |
| | | 49 | | |
| | 7 | 50 | | body.Position = 0; |
| | | 51 | | try |
| | | 52 | | { |
| | 7 | 53 | | return await DeserializeJsonBodyAsync(body, cancellationToken); |
| | | 54 | | } |
| | 0 | 55 | | catch (JsonException) |
| | | 56 | | { |
| | 0 | 57 | | AddError("Invalid console log filter JSON."); |
| | 0 | 58 | | return null; |
| | | 59 | | } |
| | 8 | 60 | | } |
| | | 61 | | |
| | | 62 | | internal static async ValueTask<ElsaConsoleLogFilter?> DeserializeJsonBodyAsync(Stream body, CancellationToken cance |
| | | 63 | | { |
| | 8 | 64 | | return await JsonSerializer.DeserializeAsync<ElsaConsoleLogFilter>(body, JsonSerializerOptions, cancellationToke |
| | 7 | 65 | | } |
| | | 66 | | } |