Files
Electron.NET/src/ElectronNET.AspNet/Runtime/Controllers/RuntimeControllerAspNetBase.cs
Pierre Arnaud be609a513e Refactor: Introduce IFacade interface for SocketIO and SignalR facades
- Create IFacade interface defining common API for SocketIO and SignalR
- Update SocketIoFacade to implement IFacade
- Update SignalRFacade to implement IFacade (add Connect no-op)
- Update RuntimeControllerBase.Socket to return IFacade
- Update RuntimeControllerAspNetBase.Socket to return IFacade
- Update RuntimeControllerDotNetFirst.Socket to return IFacade
- Update ElectronNetRuntime.GetSocket() to return IFacade
- Update BridgeConnector.Socket to return IFacade

This enables polymorphic usage of both facades throughout the codebase
and prepares for full Electron API integration with SignalR mode.
2026-01-30 13:03:19 +01:00

134 lines
4.1 KiB
C#

namespace ElectronNET.AspNet.Runtime
{
using System;
using System.Threading.Tasks;
using ElectronNET.API;
using ElectronNET.API.Bridge;
using ElectronNET.Common;
using ElectronNET.Runtime.Controllers;
using ElectronNET.Runtime.Data;
using ElectronNET.Runtime.Services.SocketBridge;
internal abstract class RuntimeControllerAspNetBase : RuntimeControllerBase
{
private readonly AspNetLifetimeAdapter aspNetLifetimeAdapter;
private SocketBridgeService socketBridge;
protected RuntimeControllerAspNetBase(AspNetLifetimeAdapter aspNetLifetimeAdapter)
{
this.aspNetLifetimeAdapter = aspNetLifetimeAdapter;
this.aspNetLifetimeAdapter.Ready += this.AspNetLifetimeAdapter_Ready;
this.aspNetLifetimeAdapter.Stopping += this.AspNetLifetimeAdapter_Stopping;
this.aspNetLifetimeAdapter.Stopped += this.AspNetLifetimeAdapter_Stopped;
ElectronNetRuntime.RuntimeControllerCore = this;
}
internal override SocketBridgeService SocketBridge => this.socketBridge;
internal override IFacade Socket
{
get
{
if (this.State == LifetimeState.Ready)
{
return this.socketBridge.Socket;
}
throw new Exception("Cannot access socket bridge. Runtime is not in 'Ready' state");
}
}
protected void CreateSocketBridge(int port)
{
this.socketBridge = new SocketBridgeService(port);
this.socketBridge.Ready += this.SocketBridge_Ready;
this.socketBridge.Stopped += this.SocketBridge_Stopped;
this.socketBridge.Start();
}
protected void HandleReady()
{
if (this.SocketBridge.IsReady() &&
this.ElectronProcess.IsReady() &&
this.aspNetLifetimeAdapter.IsReady())
{
this.TransitionState(LifetimeState.Ready);
Task.Run(this.RunReadyCallback);
}
}
protected void HandleStopped()
{
this.TransitionState(LifetimeState.Stopping);
if (this.SocketBridge.IsNotStopped())
{
this.SocketBridge.Stop();
}
if (this.ElectronProcess.IsNotStopped())
{
this.ElectronProcess.Stop();
}
if (this.aspNetLifetimeAdapter.IsNotStopped())
{
this.aspNetLifetimeAdapter.Stop();
}
if ((this.SocketBridge.IsNullOrStopped()) &&
(this.ElectronProcess.IsNullOrStopped()) &&
(this.aspNetLifetimeAdapter.IsNullOrStopped()))
{
this.TransitionState(LifetimeState.Stopped);
}
}
protected abstract override Task StopCore();
private void SocketBridge_Ready(object sender, EventArgs e)
{
this.HandleReady();
}
private void AspNetLifetimeAdapter_Ready(object sender, EventArgs e)
{
this.HandleReady();
}
private void SocketBridge_Stopped(object sender, EventArgs e)
{
this.HandleStopped();
}
private void AspNetLifetimeAdapter_Stopped(object sender, EventArgs e)
{
this.HandleStopped();
}
private void AspNetLifetimeAdapter_Stopping(object sender, EventArgs e)
{
}
private async Task RunReadyCallback()
{
if (ElectronNetRuntime.OnAppReadyCallback == null)
{
Console.WriteLine("Warning: Non OnReadyCallback provided in UseElectron() setup.");
return;
}
try
{
await ElectronNetRuntime.OnAppReadyCallback().ConfigureAwait(false);
}
catch (Exception ex)
{
Console.WriteLine("Exception while executing OnAppReadyCallback. Stopping...\n" + ex);
this.Stop();
}
}
}
}