cs-codex-dist-tests/Tools/TestNetRewarder/EventsFormatter.cs

135 lines
4.1 KiB
C#
Raw Normal View History

2024-06-27 08:07:10 +00:00
using CodexContractsPlugin;
using CodexContractsPlugin.ChainMonitor;
using GethPlugin;
using System.Globalization;
2024-06-27 08:07:10 +00:00
using System.Numerics;
using Utils;
namespace TestNetRewarder
{
public class EventsFormatter : IChainStateChangeHandler
{
private static readonly string nl = Environment.NewLine;
private readonly List<string> events = new List<string>();
public string[] GetEvents()
{
var result = events.ToArray();
events.Clear();
return result;
}
public void AddError(string error)
{
AddBlock("📢 **Error**", error);
}
public void OnNewRequest(RequestEvent requestEvent)
2024-06-27 08:07:10 +00:00
{
var request = requestEvent.Request;
AddRequestBlock(requestEvent, "New Request",
2024-06-27 08:07:10 +00:00
$"Client: {request.Client}",
$"Content: {request.Request.Content.Cid}",
$"Duration: {BigIntToDuration(request.Request.Ask.Duration)}",
$"Expiry: {BigIntToDuration(request.Request.Expiry)}",
$"Collateral: {BitIntToTestTokens(request.Request.Ask.Collateral)}",
$"Reward: {BitIntToTestTokens(request.Request.Ask.Reward)}",
$"Number of Slots: {request.Request.Ask.Slots}",
$"Slot Tolerance: {request.Request.Ask.MaxSlotLoss}",
$"Slot Size: {BigIntToByteSize(request.Request.Ask.SlotSize)}"
);
}
public void OnRequestCancelled(RequestEvent requestEvent)
2024-06-27 08:07:10 +00:00
{
AddRequestBlock(requestEvent, "Cancelled");
2024-06-27 08:07:10 +00:00
}
2024-08-21 11:59:54 +00:00
public void OnRequestFailed(RequestEvent requestEvent)
{
AddRequestBlock(requestEvent, "Failed");
}
public void OnRequestFinished(RequestEvent requestEvent)
2024-06-27 08:07:10 +00:00
{
AddRequestBlock(requestEvent, "Finished");
2024-06-27 08:07:10 +00:00
}
public void OnRequestFulfilled(RequestEvent requestEvent)
2024-06-27 08:07:10 +00:00
{
AddRequestBlock(requestEvent, "Started");
2024-06-27 08:07:10 +00:00
}
public void OnSlotFilled(RequestEvent requestEvent, EthAddress host, BigInteger slotIndex)
2024-06-27 08:07:10 +00:00
{
AddRequestBlock(requestEvent, "Slot Filled",
2024-06-27 08:07:10 +00:00
$"Host: {host}",
$"Slot Index: {slotIndex}"
);
}
public void OnSlotFreed(RequestEvent requestEvent, BigInteger slotIndex)
2024-06-27 08:07:10 +00:00
{
AddRequestBlock(requestEvent, "Slot Freed",
2024-06-27 08:07:10 +00:00
$"Slot Index: {slotIndex}"
);
}
private void AddRequestBlock(RequestEvent requestEvent, string eventName, params string[] content)
2024-06-27 08:07:10 +00:00
{
var blockNumber = $"[{requestEvent.Block.BlockNumber} {FormatDateTime(requestEvent.Block.Utc)}]";
var title = $"{blockNumber} **{eventName}** `{requestEvent.Request.Request.Id}`";
2024-06-27 08:07:10 +00:00
AddBlock(title, content);
}
private void AddBlock(string title, params string[] content)
{
events.Add(FormatBlock(title, content));
}
private string FormatBlock(string title, params string[] content)
{
if (content == null || !content.Any())
{
return $"{title}{nl}{nl}";
}
return string.Join(nl,
new string[]
{
title,
"```"
}
.Concat(content)
.Concat(new string[]
{
"```"
})
) + nl + nl;
}
private string FormatDateTime(DateTime utc)
{
return utc.ToString("yyyy-MM-dd HH:mm:ss UTC", CultureInfo.InvariantCulture);
}
2024-06-27 08:07:10 +00:00
private string BigIntToDuration(BigInteger big)
{
var span = TimeSpan.FromSeconds((int)big);
return Time.FormatDuration(span);
}
private string BigIntToByteSize(BigInteger big)
{
var size = new ByteSize((long)big);
return size.ToString();
}
private string BitIntToTestTokens(BigInteger big)
{
var tt = new TestToken(big);
return tt.ToString();
}
}
}