2
0
mirror of synced 2025-01-09 08:12:10 +00:00

63 lines
1.8 KiB
C#
Raw Normal View History

2024-01-22 10:27:07 +01:00
using Logging;
using Utils;
namespace TestNetRewarder
{
2024-06-14 11:05:29 +02:00
public interface ITimeSegmentHandler
{
Task OnNewSegment(TimeRange timeRange);
}
2024-01-22 10:27:07 +01:00
public class TimeSegmenter
{
private readonly ILog log;
2024-06-14 11:05:29 +02:00
private readonly ITimeSegmentHandler handler;
2024-01-22 10:27:07 +01:00
private readonly TimeSpan segmentSize;
2024-06-14 11:05:29 +02:00
private DateTime latest;
2024-01-22 10:27:07 +01:00
2024-08-21 15:03:20 +02:00
public TimeSegmenter(ILog log, TimeSpan segmentSize, DateTime historyStartUtc, ITimeSegmentHandler handler)
2024-01-22 10:27:07 +01:00
{
this.log = log;
2024-06-14 11:05:29 +02:00
this.handler = handler;
2024-08-21 15:03:20 +02:00
this.segmentSize = segmentSize;
latest = historyStartUtc;
2024-01-22 10:27:07 +01:00
2024-06-14 11:05:29 +02:00
log.Log("Starting time segments at " + latest);
2024-01-22 10:27:07 +01:00
log.Log("Segment size: " + Time.FormatDuration(segmentSize));
}
2024-08-21 15:03:20 +02:00
public bool IsRealtime { get; private set; } = false;
2024-06-14 11:05:29 +02:00
public async Task ProcessNextSegment()
2024-01-22 10:27:07 +01:00
{
2024-06-14 11:05:29 +02:00
var end = latest + segmentSize;
2024-08-21 15:03:20 +02:00
IsRealtime = await WaitUntilTimeSegmentInPast(end);
2024-01-22 10:27:07 +01:00
if (Program.CancellationToken.IsCancellationRequested) return;
2024-01-22 11:47:28 +01:00
var postfix = "(Catching up...)";
2024-08-21 15:03:20 +02:00
if (IsRealtime) postfix = "(Real-time)";
2024-06-14 11:05:29 +02:00
log.Log($"Time segment [{latest} to {end}] {postfix}");
var range = new TimeRange(latest, end);
latest = end;
2024-01-22 11:47:28 +01:00
2024-06-14 11:05:29 +02:00
await handler.OnNewSegment(range);
}
private async Task<bool> WaitUntilTimeSegmentInPast(DateTime end)
{
await Task.Delay(TimeSpan.FromSeconds(3), Program.CancellationToken);
2024-01-22 10:27:07 +01:00
2024-06-14 11:05:29 +02:00
var now = DateTime.UtcNow;
while (end > now)
{
var delay = (end - now) + TimeSpan.FromSeconds(3);
await Task.Delay(delay, Program.CancellationToken);
return true;
}
return false;
2024-01-22 10:27:07 +01:00
}
}
}