< Summary

Information
Class: Elsa.Diagnostics.StructuredLogs.Persistence.Relational.Services.StructuredLogRetentionService
Assembly: Elsa.Diagnostics.StructuredLogs.Persistence.Relational
File(s): /home/runner/work/elsa-core/elsa-core/src/modules/Elsa.Diagnostics.StructuredLogs.Persistence.Relational/Services/StructuredLogRetentionService.cs
Line coverage
0%
Covered lines: 0
Uncovered lines: 24
Coverable lines: 24
Total lines: 48
Line coverage: 0%
Branch coverage
0%
Covered branches: 0
Total branches: 20
Branch coverage: 0%
Method coverage

Feature is only available for sponsors

Upgrade to PRO version

Metrics

MethodBranch coverage Crap Score Cyclomatic complexity Line coverage
.ctor(...)100%210%
CleanupAsync()0%156120%
ExecuteAsync()0%7280%

File(s)

/home/runner/work/elsa-core/elsa-core/src/modules/Elsa.Diagnostics.StructuredLogs.Persistence.Relational/Services/StructuredLogRetentionService.cs

#LineLine coverage
 1using System.Data.Common;
 2using Elsa.Diagnostics.StructuredLogs.Persistence.Relational.Contracts;
 3using Elsa.Diagnostics.StructuredLogs.Persistence.Relational.Options;
 4using Microsoft.Extensions.Options;
 5
 6namespace Elsa.Diagnostics.StructuredLogs.Persistence.Relational.Services;
 7
 08public class StructuredLogRetentionService(
 09    IRelationalStructuredLogConnectionFactory connectionFactory,
 010    IRelationalStructuredLogDialect dialect,
 011    RelationalStructuredLogSqlBuilder sqlBuilder,
 012    IOptions<RelationalStructuredLogOptions> options)
 13{
 14    public async ValueTask CleanupAsync(CancellationToken cancellationToken = default)
 15    {
 016        var retention = options.Value.Retention;
 17
 018        if (retention.MaxAge == null && retention.MaxRows == null)
 019            return;
 20
 021        await using var connection = await connectionFactory.OpenConnectionAsync(cancellationToken);
 22
 023        if (retention.MaxAge is { } maxAge)
 24        {
 025            var cutoff = RelationalStructuredLogMapper.FormatTimestamp(DateTimeOffset.UtcNow.Subtract(maxAge));
 026            await ExecuteAsync(connection, sqlBuilder.BuildDeleteOlderThan(cutoff), cancellationToken);
 27        }
 28
 029        if (retention.MaxRows is { } maxRows and >= 0)
 030            await ExecuteAsync(connection, sqlBuilder.BuildDeleteRowsBeyondMax(maxRows), cancellationToken);
 031    }
 32
 33    private async ValueTask ExecuteAsync(DbConnection connection, QueryDefinition query, CancellationToken cancellationT
 34    {
 035        await using var command = connection.CreateCommand();
 036        command.CommandText = query.Sql;
 37
 038        foreach (var (name, value) in query.Parameters)
 39        {
 040            var parameter = command.CreateParameter();
 041            parameter.ParameterName = name.StartsWith(dialect.ParameterPrefix, StringComparison.Ordinal) ? name : $"{dia
 042            parameter.Value = value ?? DBNull.Value;
 043            command.Parameters.Add(parameter);
 44        }
 45
 046        await command.ExecuteNonQueryAsync(cancellationToken);
 047    }
 48}