This commit is contained in:
master
2026-01-07 10:25:34 +02:00
726 changed files with 147397 additions and 1364 deletions

View File

@@ -20,17 +20,20 @@ public sealed class ChatWebhookChannelAdapter : IChannelAdapter
private readonly INotifyAuditRepository _auditRepository;
private readonly ChannelAdapterOptions _options;
private readonly ILogger<ChatWebhookChannelAdapter> _logger;
private readonly Func<double> _jitterSource;
public ChatWebhookChannelAdapter(
HttpClient httpClient,
INotifyAuditRepository auditRepository,
IOptions<ChannelAdapterOptions> options,
ILogger<ChatWebhookChannelAdapter> logger)
ILogger<ChatWebhookChannelAdapter> logger,
Func<double>? jitterSource = null)
{
_httpClient = httpClient ?? throw new ArgumentNullException(nameof(httpClient));
_auditRepository = auditRepository ?? throw new ArgumentNullException(nameof(auditRepository));
_options = options?.Value ?? throw new ArgumentNullException(nameof(options));
_logger = logger ?? throw new ArgumentNullException(nameof(logger));
_jitterSource = jitterSource ?? Random.Shared.NextDouble;
}
// Routes Slack type to this adapter; Teams uses Custom type
@@ -337,7 +340,7 @@ public sealed class ChatWebhookChannelAdapter : IChannelAdapter
{
var baseDelay = _options.RetryBaseDelay;
var maxDelay = _options.RetryMaxDelay;
var jitter = Random.Shared.NextDouble() * 0.3 + 0.85;
var jitter = _jitterSource() * 0.3 + 0.85;
var delay = TimeSpan.FromMilliseconds(baseDelay.TotalMilliseconds * Math.Pow(2, attempt - 1) * jitter);
return delay > maxDelay ? maxDelay : delay;
}

View File

@@ -18,18 +18,21 @@ public sealed class EmailChannelAdapter : IChannelAdapter, IDisposable
private readonly ChannelAdapterOptions _options;
private readonly ILogger<EmailChannelAdapter> _logger;
private readonly TimeProvider _timeProvider;
private readonly Func<double> _jitterSource;
private bool _disposed;
public EmailChannelAdapter(
INotifyAuditRepository auditRepository,
IOptions<ChannelAdapterOptions> options,
TimeProvider timeProvider,
ILogger<EmailChannelAdapter> logger)
ILogger<EmailChannelAdapter> logger,
Func<double>? jitterSource = null)
{
_auditRepository = auditRepository ?? throw new ArgumentNullException(nameof(auditRepository));
_options = options?.Value ?? throw new ArgumentNullException(nameof(options));
_timeProvider = timeProvider ?? TimeProvider.System;
_logger = logger ?? throw new ArgumentNullException(nameof(logger));
_jitterSource = jitterSource ?? Random.Shared.NextDouble;
}
public NotifyChannelType ChannelType => NotifyChannelType.Email;
@@ -298,7 +301,7 @@ public sealed class EmailChannelAdapter : IChannelAdapter, IDisposable
{
var baseDelay = _options.RetryBaseDelay;
var maxDelay = _options.RetryMaxDelay;
var jitter = Random.Shared.NextDouble() * 0.3 + 0.85;
var jitter = _jitterSource() * 0.3 + 0.85;
var delay = TimeSpan.FromMilliseconds(baseDelay.TotalMilliseconds * Math.Pow(2, attempt - 1) * jitter);
return delay > maxDelay ? maxDelay : delay;
}

View File

@@ -24,6 +24,7 @@ public sealed class OpsGenieChannelAdapter : IChannelAdapter
private readonly ChannelAdapterOptions _options;
private readonly ILogger<OpsGenieChannelAdapter> _logger;
private readonly TimeProvider _timeProvider;
private readonly Func<double> _jitterSource;
private static readonly JsonSerializerOptions JsonOptions = new(JsonSerializerDefaults.Web)
{
@@ -36,13 +37,15 @@ public sealed class OpsGenieChannelAdapter : IChannelAdapter
INotifyAuditRepository auditRepository,
IOptions<ChannelAdapterOptions> options,
TimeProvider timeProvider,
ILogger<OpsGenieChannelAdapter> logger)
ILogger<OpsGenieChannelAdapter> logger,
Func<double>? jitterSource = null)
{
_httpClient = httpClient ?? throw new ArgumentNullException(nameof(httpClient));
_auditRepository = auditRepository ?? throw new ArgumentNullException(nameof(auditRepository));
_options = options?.Value ?? throw new ArgumentNullException(nameof(options));
_timeProvider = timeProvider ?? TimeProvider.System;
_logger = logger ?? throw new ArgumentNullException(nameof(logger));
_jitterSource = jitterSource ?? Random.Shared.NextDouble;
}
public NotifyChannelType ChannelType => NotifyChannelType.OpsGenie;
@@ -439,7 +442,7 @@ public sealed class OpsGenieChannelAdapter : IChannelAdapter
{
var baseDelay = _options.RetryBaseDelay;
var maxDelay = _options.RetryMaxDelay;
var jitter = Random.Shared.NextDouble() * 0.3 + 0.85;
var jitter = _jitterSource() * 0.3 + 0.85;
var delay = TimeSpan.FromMilliseconds(baseDelay.TotalMilliseconds * Math.Pow(2, attempt - 1) * jitter);
return delay > maxDelay ? maxDelay : delay;
}

View File

@@ -23,6 +23,7 @@ public sealed class PagerDutyChannelAdapter : IChannelAdapter
private readonly ChannelAdapterOptions _options;
private readonly ILogger<PagerDutyChannelAdapter> _logger;
private readonly TimeProvider _timeProvider;
private readonly Func<double> _jitterSource;
private static readonly JsonSerializerOptions JsonOptions = new(JsonSerializerDefaults.Web)
{
@@ -35,13 +36,15 @@ public sealed class PagerDutyChannelAdapter : IChannelAdapter
INotifyAuditRepository auditRepository,
IOptions<ChannelAdapterOptions> options,
TimeProvider timeProvider,
ILogger<PagerDutyChannelAdapter> logger)
ILogger<PagerDutyChannelAdapter> logger,
Func<double>? jitterSource = null)
{
_httpClient = httpClient ?? throw new ArgumentNullException(nameof(httpClient));
_auditRepository = auditRepository ?? throw new ArgumentNullException(nameof(auditRepository));
_options = options?.Value ?? throw new ArgumentNullException(nameof(options));
_timeProvider = timeProvider ?? TimeProvider.System;
_logger = logger ?? throw new ArgumentNullException(nameof(logger));
_jitterSource = jitterSource ?? Random.Shared.NextDouble;
}
public NotifyChannelType ChannelType => NotifyChannelType.PagerDuty;
@@ -403,7 +406,7 @@ public sealed class PagerDutyChannelAdapter : IChannelAdapter
{
var baseDelay = _options.RetryBaseDelay;
var maxDelay = _options.RetryMaxDelay;
var jitter = Random.Shared.NextDouble() * 0.3 + 0.85;
var jitter = _jitterSource() * 0.3 + 0.85;
var delay = TimeSpan.FromMilliseconds(baseDelay.TotalMilliseconds * Math.Pow(2, attempt - 1) * jitter);
return delay > maxDelay ? maxDelay : delay;
}

View File

@@ -22,6 +22,7 @@ public sealed class WebhookChannelAdapter : IChannelAdapter
private readonly ChannelAdapterOptions _options;
private readonly ILogger<WebhookChannelAdapter> _logger;
private readonly TimeProvider _timeProvider;
private readonly Func<double> _jitterSource;
private static readonly JsonSerializerOptions JsonOptions = new(JsonSerializerDefaults.Web)
{
@@ -33,13 +34,15 @@ public sealed class WebhookChannelAdapter : IChannelAdapter
INotifyAuditRepository auditRepository,
IOptions<ChannelAdapterOptions> options,
TimeProvider timeProvider,
ILogger<WebhookChannelAdapter> logger)
ILogger<WebhookChannelAdapter> logger,
Func<double>? jitterSource = null)
{
_httpClient = httpClient ?? throw new ArgumentNullException(nameof(httpClient));
_auditRepository = auditRepository ?? throw new ArgumentNullException(nameof(auditRepository));
_options = options?.Value ?? throw new ArgumentNullException(nameof(options));
_timeProvider = timeProvider ?? TimeProvider.System;
_logger = logger ?? throw new ArgumentNullException(nameof(logger));
_jitterSource = jitterSource ?? Random.Shared.NextDouble;
}
public NotifyChannelType ChannelType => NotifyChannelType.Webhook;
@@ -288,7 +291,7 @@ public sealed class WebhookChannelAdapter : IChannelAdapter
{
var baseDelay = _options.RetryBaseDelay;
var maxDelay = _options.RetryMaxDelay;
var jitter = Random.Shared.NextDouble() * 0.3 + 0.85;
var jitter = _jitterSource() * 0.3 + 0.85;
var delay = TimeSpan.FromMilliseconds(baseDelay.TotalMilliseconds * Math.Pow(2, attempt - 1) * jitter);
return delay > maxDelay ? maxDelay : delay;
}