2
0
mirror of synced 2025-01-27 16:56:04 +00:00

172 lines
6.0 KiB
C#
Raw Normal View History

2023-04-12 13:53:55 +02:00
using KubernetesWorkflow;
2023-04-30 10:08:32 +02:00
using Logging;
2023-04-12 13:53:55 +02:00
namespace DistTestCore.Codex
{
public class CodexAccess
{
2023-04-30 10:08:32 +02:00
private readonly BaseLog log;
private readonly ITimeSet timeSet;
2023-04-30 10:08:32 +02:00
public CodexAccess(BaseLog log, ITimeSet timeSet, RunningContainer runningContainer)
2023-04-12 13:53:55 +02:00
{
2023-04-30 10:08:32 +02:00
this.log = log;
this.timeSet = timeSet;
2023-04-13 09:33:10 +02:00
Container = runningContainer;
2023-04-12 13:53:55 +02:00
}
2023-04-13 09:33:10 +02:00
public RunningContainer Container { get; }
2023-04-12 13:53:55 +02:00
public CodexDebugResponse GetDebugInfo()
{
2023-05-11 12:44:53 +02:00
return Http(TimeSpan.FromSeconds(2)).HttpGetJson<CodexDebugResponse>("debug/info");
}
public CodexDebugPeerResponse GetDebugPeer(string peerId)
{
return Http(TimeSpan.FromSeconds(2)).HttpGetJson<CodexDebugPeerResponse>($"debug/peer/{peerId}");
2023-04-12 13:53:55 +02:00
}
2023-04-13 09:33:10 +02:00
public string UploadFile(FileStream fileStream)
{
return Http().HttpPostStream("upload", fileStream);
}
public Stream DownloadFile(string contentId)
{
return Http().HttpGetStream("download/" + contentId);
}
public CodexSalesAvailabilityResponse SalesAvailability(CodexSalesAvailabilityRequest request)
{
return Http().HttpPostJson<CodexSalesAvailabilityRequest, CodexSalesAvailabilityResponse>("sales/availability", request);
}
public string RequestStorage(CodexSalesRequestStorageRequest request, string contentId)
{
return Http().HttpPostJson($"storage/request/{contentId}", request);
}
2023-05-11 12:44:53 +02:00
public string ConnectToPeer(string peerId, string peerMultiAddress)
{
return Http().HttpGetString($"connect/{peerId}?addrs={peerMultiAddress}");
}
public void EnsureOnline()
{
try
{
var debugInfo = GetDebugInfo();
if (debugInfo == null || string.IsNullOrEmpty(debugInfo.id)) throw new InvalidOperationException("Unable to get debug-info from codex node at startup.");
var nodePeerId = debugInfo.id;
var nodeName = Container.Name;
log.AddStringReplace(nodePeerId, $"___{nodeName}___");
}
catch (Exception e)
{
log.Error($"Failed to start codex node: {e}. Test infra failure.");
throw new InvalidOperationException($"Failed to start codex node. Test infra failure.", e);
}
}
2023-05-11 12:44:53 +02:00
private Http Http(TimeSpan? timeoutOverride = null)
2023-04-12 13:53:55 +02:00
{
2023-04-13 10:11:33 +02:00
var ip = Container.Pod.Cluster.IP;
2023-04-13 09:33:10 +02:00
var port = Container.ServicePorts[0].Number;
2023-05-11 12:44:53 +02:00
return new Http(log, timeSet, ip, port, baseUrl: "/api/codex/v1", timeoutOverride);
2023-04-13 09:33:10 +02:00
}
2023-04-12 13:53:55 +02:00
}
public class CodexDebugResponse
{
public string id { get; set; } = string.Empty;
public string[] addrs { get; set; } = new string[0];
public string repo { get; set; } = string.Empty;
public string spr { get; set; } = string.Empty;
2023-04-26 14:40:54 +02:00
public EnginePeerResponse[] enginePeers { get; set; } = Array.Empty<EnginePeerResponse>();
public SwitchPeerResponse[] switchPeers { get; set; } = Array.Empty<SwitchPeerResponse>();
2023-04-12 13:53:55 +02:00
public CodexDebugVersionResponse codex { get; set; } = new();
2023-05-10 08:53:57 +02:00
public CodexDebugTableResponse table { get; set; } = new();
}
public class CodexDebugTableResponse
{
public CodexDebugTableNodeResponse localNode { get; set; } = new();
public CodexDebugTableNodeResponse[] nodes { get; set; } = Array.Empty<CodexDebugTableNodeResponse>();
}
public class CodexDebugTableNodeResponse
{
public string nodeId { get; set; } = string.Empty;
public string record { get; set; } = string.Empty;
public bool seen { get; set; }
2023-04-12 13:53:55 +02:00
}
2023-04-26 14:40:54 +02:00
public class EnginePeerResponse
{
public string peerId { get; set; } = string.Empty;
public EnginePeerContextResponse context { get; set; } = new();
}
public class EnginePeerContextResponse
{
public int blocks { get; set; } = 0;
public int peerWants { get; set; } = 0;
public int exchanged { get; set; } = 0;
public string lastExchange { get; set; } = string.Empty;
}
public class SwitchPeerResponse
{
public string peerId { get; set; } = string.Empty;
public string key { get; set; } = string.Empty;
}
2023-04-12 13:53:55 +02:00
public class CodexDebugVersionResponse
{
public string version { get; set; } = string.Empty;
public string revision { get; set; } = string.Empty;
}
2023-05-11 12:44:53 +02:00
public class CodexDebugPeerResponse
{
public string peerId { get; set; } = string.Empty;
public long seqNo { get; set; }
public CodexDebugPeerAddressResponse[] addresses { get; set; } = Array.Empty<CodexDebugPeerAddressResponse>();
}
public class CodexDebugPeerAddressResponse
{
public string address { get; set; } = string.Empty;
}
public class CodexSalesAvailabilityRequest
{
public string size { get; set; } = string.Empty;
public string duration { get; set; } = string.Empty;
public string minPrice { get; set; } = string.Empty;
public string maxCollateral { get; set; } = string.Empty;
}
public class CodexSalesAvailabilityResponse
{
public string id { get; set; } = string.Empty;
public string size { get; set; } = string.Empty;
public string duration { get; set; } = string.Empty;
public string minPrice { get; set; } = string.Empty;
public string maxCollateral { get; set; } = string.Empty;
}
public class CodexSalesRequestStorageRequest
{
public string duration { get; set; } = string.Empty;
public string proofProbability { get; set; } = string.Empty;
public string reward { get; set; } = string.Empty;
public string collateral { get; set; } = string.Empty;
public string? expiry { get; set; }
public uint? nodes { get; set; }
public uint? tolerance { get; set;}
}
2023-04-12 13:53:55 +02:00
}