2024-03-25 15:46:45 +01:00
using CodexOpenApi ;
using Core ;
2023-09-11 11:59:33 +02:00
using KubernetesWorkflow ;
2023-11-12 10:07:23 +01:00
using KubernetesWorkflow.Types ;
2023-10-19 11:18:59 +02:00
using Utils ;
2023-04-12 13:53:55 +02:00
2023-09-11 11:59:33 +02:00
namespace CodexPlugin
2023-04-12 13:53:55 +02:00
{
2023-08-15 11:01:18 +02:00
public class CodexAccess : ILogHandler
2023-04-12 13:53:55 +02:00
{
2023-09-12 10:31:55 +02:00
private readonly IPluginTools tools ;
2024-03-26 08:58:16 +01:00
private readonly Mapper mapper = new Mapper ( ) ;
2023-08-15 11:01:18 +02:00
private bool hasContainerCrashed ;
2023-04-30 10:08:32 +02:00
2023-09-20 12:55:09 +02:00
public CodexAccess ( IPluginTools tools , RunningContainer container , CrashWatcher crashWatcher )
2023-04-12 13:53:55 +02:00
{
2023-09-12 10:31:55 +02:00
this . tools = tools ;
2023-06-29 16:07:49 +02:00
Container = container ;
2023-09-20 12:55:09 +02:00
CrashWatcher = crashWatcher ;
2023-08-15 11:01:18 +02:00
hasContainerCrashed = false ;
2023-09-20 12:55:09 +02:00
CrashWatcher . Start ( this ) ;
2023-04-18 15:33:12 +02:00
}
2023-06-21 08:28:40 +02:00
public RunningContainer Container { get ; }
2023-09-20 12:55:09 +02:00
public CrashWatcher CrashWatcher { get ; }
2023-05-11 12:44:53 +02:00
2024-03-26 08:58:16 +01:00
public DebugInfo GetDebugInfo ( )
2023-05-04 11:34:43 +02:00
{
2024-03-26 08:58:16 +01:00
return Map ( OnCodex ( api = > api . GetDebugInfoAsync ( ) ) ) ;
2023-06-29 16:07:49 +02:00
}
2023-05-04 11:34:43 +02:00
2023-06-29 16:07:49 +02:00
public CodexDebugPeerResponse GetDebugPeer ( string peerId )
{
2023-07-17 15:21:10 +02:00
var http = Http ( ) ;
2023-06-29 16:07:49 +02:00
var str = http . HttpGetString ( $"debug/peer/{peerId}" ) ;
if ( str . ToLowerInvariant ( ) = = "unable to find peer!" )
2023-05-04 11:34:43 +02:00
{
2023-06-29 16:07:49 +02:00
return new CodexDebugPeerResponse
{
IsPeerFound = false
} ;
2023-05-04 11:34:43 +02:00
}
2023-06-29 16:07:49 +02:00
2023-10-24 09:41:37 +02:00
var result = http . Deserialize < CodexDebugPeerResponse > ( str ) ;
2023-06-29 16:07:49 +02:00
result . IsPeerFound = true ;
return result ;
}
2023-10-09 12:33:35 +02:00
public CodexDebugBlockExchangeResponse GetDebugBlockExchange ( )
{
return Http ( ) . HttpGetJson < CodexDebugBlockExchangeResponse > ( "debug/blockexchange" ) ;
}
2023-10-10 17:54:19 +02:00
public CodexDebugRepoStoreResponse [ ] GetDebugRepoStore ( )
{
2023-10-10 18:08:21 +02:00
return LongHttp ( ) . HttpGetJson < CodexDebugRepoStoreResponse [ ] > ( "debug/repostore" ) ;
2023-10-10 17:54:19 +02:00
}
2023-07-07 08:52:53 +02:00
public CodexDebugThresholdBreaches GetDebugThresholdBreaches ( )
{
return Http ( ) . HttpGetJson < CodexDebugThresholdBreaches > ( "debug/loop" ) ;
}
2023-06-29 16:07:49 +02:00
public string UploadFile ( FileStream fileStream )
{
2023-11-10 08:20:08 +01:00
return Http ( ) . HttpPostStream ( "data" , fileStream ) ;
2023-06-29 16:07:49 +02:00
}
public Stream DownloadFile ( string contentId )
{
2023-11-23 13:32:58 +01:00
return Http ( ) . HttpGetStream ( "data/" + contentId + "/network" ) ;
2023-11-10 08:20:08 +01:00
}
public CodexLocalDataResponse [ ] LocalFiles ( )
{
2023-11-23 13:43:19 +01:00
return Http ( ) . HttpGetJson < CodexLocalDataResponse [ ] > ( "data" ) ;
2023-06-29 16:07:49 +02:00
}
public CodexSalesAvailabilityResponse SalesAvailability ( CodexSalesAvailabilityRequest request )
{
return Http ( ) . HttpPostJson < CodexSalesAvailabilityRequest , CodexSalesAvailabilityResponse > ( "sales/availability" , request ) ;
}
public string RequestStorage ( CodexSalesRequestStorageRequest request , string contentId )
{
2023-08-31 11:19:53 +02:00
return Http ( ) . HttpPostJson ( $"storage/request/{contentId}" , request ) ;
2023-06-29 16:07:49 +02:00
}
public CodexStoragePurchase GetPurchaseStatus ( string purchaseId )
{
return Http ( ) . HttpGetJson < CodexStoragePurchase > ( $"storage/purchases/{purchaseId}" ) ;
}
public string ConnectToPeer ( string peerId , string peerMultiAddress )
{
return Http ( ) . HttpGetString ( $"connect/{peerId}?addrs={peerMultiAddress}" ) ;
}
2023-08-24 11:32:32 +02:00
public string GetName ( )
{
return Container . Name ;
}
2023-11-06 14:33:47 +01:00
public PodInfo GetPodInfo ( )
{
var workflow = tools . CreateWorkflow ( ) ;
return workflow . GetPodInfo ( Container ) ;
}
2024-03-26 08:58:16 +01:00
private dynamic Map ( dynamic input )
{
return mapper . Map ( input ) ;
}
2024-03-25 15:46:45 +01:00
private T OnCodex < T > ( Func < CodexApi , Task < T > > action )
2023-06-29 16:07:49 +02:00
{
2024-03-25 11:37:41 +01:00
var address = GetAddress ( ) ;
2024-03-25 15:46:45 +01:00
var result = tools . CreateHttp ( ) . OnClient ( client = >
{
var api = new CodexApi ( client ) ;
api . BaseUrl = $"{address.Host}:{address.Port}/api/codex/v1" ;
return Time . Wait ( action ( api ) ) ;
} ) ;
return result ;
}
2024-03-25 11:37:41 +01:00
2024-03-25 15:46:45 +01:00
//private IHttp Http()
//{
// var address = GetAddress();
// var api = new CodexOpenApi.CodexApi(new HttpClient());
// api.BaseUrl = $"{address.Host}:{address.Port}/api/codex/v1";
2024-03-25 11:37:41 +01:00
2024-03-25 15:46:45 +01:00
// var debugInfo = Time.Wait(api.GetDebugInfoAsync());
2024-03-25 11:37:41 +01:00
2024-03-25 15:46:45 +01:00
// using var stream = File.OpenRead("C:\\Users\\thatb\\Desktop\\Collect\\Wallpapers\\demerui_djinn_illuminatus_fullbody_full_body_view_in_the_style__86ea9491-1fe1-44ab-8577-a3636cad1b21.png");
// var cid = Time.Wait(api.UploadAsync(stream));
2024-03-25 11:37:41 +01:00
2024-03-25 15:46:45 +01:00
// var file = Time.Wait(api.DownloadNetworkAsync(cid));
// while (file.IsPartial) Thread.Sleep(100);
// using var outfile = File.OpenWrite("C:\\Users\\thatb\\Desktop\\output.png");
// file.Stream.CopyTo(outfile);
2023-08-15 11:01:18 +02:00
2024-03-25 15:46:45 +01:00
// return tools.CreateHttp(GetAddress(), baseUrl: "/api/codex/v1", CheckContainerCrashed, Container.Name);
//}
//private IHttp LongHttp()
//{
// return tools.CreateHttp(GetAddress(), baseUrl: "/api/codex/v1", CheckContainerCrashed, new LongTimeSet(), Container.Name);
//}
2023-10-19 11:18:59 +02:00
private Address GetAddress ( )
{
2023-11-07 12:02:17 +01:00
return Container . GetAddress ( tools . GetLog ( ) , CodexContainerRecipe . ApiPortTag ) ;
2023-10-10 18:08:21 +02:00
}
2023-08-29 10:09:48 +02:00
private void CheckContainerCrashed ( HttpClient client )
2023-08-15 11:01:18 +02:00
{
if ( hasContainerCrashed ) throw new Exception ( "Container has crashed." ) ;
}
public void Log ( Stream crashLog )
{
2023-09-12 10:31:55 +02:00
var log = tools . GetLog ( ) ;
2023-08-15 11:01:18 +02:00
var file = log . CreateSubfile ( ) ;
log . Log ( $"Container {Container.Name} has crashed. Downloading crash log to '{file.FullFilename}'..." ) ;
2023-10-16 11:19:57 +02:00
file . Write ( $"Container Crash Log for {Container.Name}." ) ;
2023-08-15 11:01:18 +02:00
using var reader = new StreamReader ( crashLog ) ;
var line = reader . ReadLine ( ) ;
while ( line ! = null )
{
file . Write ( line ) ;
line = reader . ReadLine ( ) ;
}
log . Log ( "Crash log successfully downloaded." ) ;
hasContainerCrashed = true ;
}
2023-04-18 15:33:12 +02:00
}
2023-04-12 13:53:55 +02:00
}