2
0
mirror of synced 2025-01-13 10:04:29 +00:00
2024-04-01 20:47:56 +02:00

74 lines
2.1 KiB
C#

using ArgsUniform;
using AutoClient;
using CodexPlugin;
using Core;
using Logging;
using static Org.BouncyCastle.Math.EC.ECCurve;
public static class Program
{
public static void Main(string[] args)
{
var cts = new CancellationTokenSource();
var cancellationToken = cts.Token;
Console.CancelKeyPress += (sender, args) => cts.Cancel();
var uniformArgs = new ArgsUniform<Configuration>(PrintHelp, args);
var config = uniformArgs.Parse(true);
var log = new LogSplitter(
new FileLog(Path.Combine(config.LogPath, "autoclient")),
new ConsoleLog()
);
var address = new Utils.Address(
host: config.CodexHost,
port: config.CodexPort
);
log.Log($"Start. Address: {address}");
var tools = CreateTools(log, config);
var fileManager = tools.GetFileManager();
var codex = new Codex(tools, address);
CheckCodex(codex, log);
var runner = new Runner(log, codex, fileManager, cancellationToken, config);
runner.Run();
log.Log("Done.");
}
private static void CheckCodex(Codex codex, ILog log)
{
log.Log("Checking Codex...");
try
{
var info = codex.GetDebugInfo();
if (string.IsNullOrEmpty(info.Id)) throw new Exception("Failed to fetch Codex node id");
}
catch (Exception ex)
{
log.Log($"Codex not OK: {ex}");
throw;
}
}
private static void PrintHelp()
{
Console.WriteLine("Generates fake data and creates Codex storage contracts for it.");
}
private static IPluginTools CreateTools(ILog log, Configuration config)
{
var configuration = new KubernetesWorkflow.Configuration(
null,
operationTimeout: TimeSpan.FromMinutes(10),
retryDelay: TimeSpan.FromSeconds(10),
kubernetesNamespace: "notUsed!#");
var result = new EntryPoint(log, configuration, config.DataPath, new DefaultTimeSet());
return result.Tools;
}
}