mirror of
https://github.com/xivdev/Penumbra.git
synced 2026-01-02 05:43:42 +01:00
Cleanup HTTP API, remove unused options.
This commit is contained in:
parent
0a47ae5b18
commit
7ee80c7d48
7 changed files with 140 additions and 170 deletions
128
Penumbra/Api/HttpApi.cs
Normal file
128
Penumbra/Api/HttpApi.cs
Normal file
|
|
@ -0,0 +1,128 @@
|
|||
using System;
|
||||
using System.Threading.Tasks;
|
||||
using EmbedIO;
|
||||
using EmbedIO.Routing;
|
||||
using EmbedIO.WebApi;
|
||||
using Penumbra.Api.Enums;
|
||||
|
||||
namespace Penumbra.Api;
|
||||
|
||||
public class HttpApi : IDisposable
|
||||
{
|
||||
private partial class Controller : WebApiController
|
||||
{
|
||||
// @formatter:off
|
||||
[Route( HttpVerbs.Get, "/mods" )] public partial object? GetMods();
|
||||
[Route( HttpVerbs.Post, "/redraw" )] public partial Task Redraw();
|
||||
[Route( HttpVerbs.Post, "/redrawAll" )] public partial void RedrawAll();
|
||||
[Route( HttpVerbs.Post, "/reloadmod" )] public partial Task ReloadMod();
|
||||
// @formatter:on
|
||||
}
|
||||
|
||||
public const string Prefix = "http://localhost:42069/";
|
||||
|
||||
private readonly IPenumbraApi _api;
|
||||
private WebServer? _server;
|
||||
|
||||
public HttpApi( IPenumbraApi api )
|
||||
{
|
||||
_api = api;
|
||||
if( Penumbra.Config.EnableHttpApi )
|
||||
{
|
||||
CreateWebServer();
|
||||
}
|
||||
}
|
||||
|
||||
public bool Enabled
|
||||
=> _server != null;
|
||||
|
||||
public void CreateWebServer()
|
||||
{
|
||||
ShutdownWebServer();
|
||||
|
||||
_server = new WebServer( o => o
|
||||
.WithUrlPrefix( Prefix )
|
||||
.WithMode( HttpListenerMode.EmbedIO ) )
|
||||
.WithCors( Prefix )
|
||||
.WithWebApi( "/api", m => m.WithController( () => new Controller( _api ) ) );
|
||||
|
||||
_server.StateChanged += ( _, e ) => Penumbra.Log.Information( $"WebServer New State - {e.NewState}" );
|
||||
_server.RunAsync();
|
||||
}
|
||||
|
||||
public void ShutdownWebServer()
|
||||
{
|
||||
_server?.Dispose();
|
||||
_server = null;
|
||||
}
|
||||
|
||||
public void Dispose()
|
||||
=> ShutdownWebServer();
|
||||
|
||||
private partial class Controller
|
||||
{
|
||||
private readonly IPenumbraApi _api;
|
||||
|
||||
public Controller( IPenumbraApi api )
|
||||
=> _api = api;
|
||||
|
||||
public partial object? GetMods()
|
||||
{
|
||||
Penumbra.Log.Debug( $"[HTTP] {nameof( GetMods )} triggered." );
|
||||
return _api.GetModList();
|
||||
}
|
||||
|
||||
public async partial Task Redraw()
|
||||
{
|
||||
var data = await HttpContext.GetRequestDataAsync< RedrawData >();
|
||||
Penumbra.Log.Debug( $"[HTTP] {nameof( Redraw )} triggered with {data}." );
|
||||
if( data.ObjectTableIndex >= 0 )
|
||||
{
|
||||
_api.RedrawObject( data.ObjectTableIndex, data.Type );
|
||||
}
|
||||
else if( data.Name.Length > 0 )
|
||||
{
|
||||
_api.RedrawObject( data.Name, data.Type );
|
||||
}
|
||||
else
|
||||
{
|
||||
_api.RedrawAll( data.Type );
|
||||
}
|
||||
}
|
||||
|
||||
public partial void RedrawAll()
|
||||
{
|
||||
Penumbra.Log.Debug( $"[HTTP] {nameof( RedrawAll )} triggered." );
|
||||
_api.RedrawAll( RedrawType.Redraw );
|
||||
}
|
||||
|
||||
public async partial Task ReloadMod()
|
||||
{
|
||||
var data = await HttpContext.GetRequestDataAsync< ModReloadData >();
|
||||
Penumbra.Log.Debug( $"[HTTP] {nameof( ReloadMod )} triggered with {data}." );
|
||||
// Add the mod if it is not already loaded and if the directory name is given.
|
||||
// AddMod returns Success if the mod is already loaded.
|
||||
if( data.Path.Length != 0 )
|
||||
{
|
||||
_api.AddMod( data.Path );
|
||||
}
|
||||
|
||||
// Reload the mod by path or name, which will also remove no-longer existing mods.
|
||||
_api.ReloadMod( data.Path, data.Name );
|
||||
}
|
||||
|
||||
private record ModReloadData( string Path, string Name )
|
||||
{
|
||||
public ModReloadData()
|
||||
: this( string.Empty, string.Empty )
|
||||
{ }
|
||||
}
|
||||
|
||||
private record RedrawData( string Name, RedrawType Type, int ObjectTableIndex )
|
||||
{
|
||||
public RedrawData()
|
||||
: this( string.Empty, RedrawType.Redraw, -1 )
|
||||
{ }
|
||||
}
|
||||
}
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue