#region copyright
//------------------------------------------------------------------------------
//  此代码版权声明为全文件覆盖,如有原作者特别声明,会在下方手动补充
//  此代码版权(除特别声明外的代码)归作者本人Diego所有
//  源代码使用协议遵循本仓库的开源协议及附加协议
//  Gitee源代码仓库:https://gitee.com/diego2098/ThingsGateway
//  Github源代码仓库:https://github.com/kimdiego2098/ThingsGateway
//  使用文档:https://diego2098.gitee.io/thingsgateway-docs/
//  QQ群:605534569
//------------------------------------------------------------------------------
#endregion
using TouchSocket.Core;
using TouchSocket.Sockets;
namespace ThingsGateway.Blazor;
/// 
public partial class UdpSessionPage : IDisposable
{
    /// 
    /// 日志输出
    /// 
    public Action LogAction;
    private TouchSocketConfig config;
    private string ip = "127.0.0.1";
    private int port = 502;
    private UdpSession UdpSession { get; set; } = new();
    /// 
    public void Dispose()
    {
        UdpSession.SafeDispose();
    }
    private void Connect()
    {
        try
        {
            UdpSession.Stop();
            GetUdpSession().Start();
        }
        catch (Exception ex)
        {
            LogAction?.Invoke(LogLevel.Error, null, null, ex);
        }
    }
    private void DisConnect()
    {
        try
        {
            UdpSession.Stop();
        }
        catch (Exception ex)
        {
            LogAction?.Invoke(LogLevel.Error, null, null, ex);
        }
    }
    /// 
    /// 获取对象
    /// 
    /// 
    public UdpSession GetUdpSession()
    {
        config ??= new TouchSocketConfig();
        var LogMessage = new TouchSocket.Core.LoggerGroup() { LogLevel = TouchSocket.Core.LogLevel.Trace };
        LogMessage.AddLogger(new EasyLogger(LogOut) { LogLevel = TouchSocket.Core.LogLevel.Trace });
        config.ConfigureContainer(a => a.RegisterSingleton(LogMessage));
        config.SetRemoteIPHost(new IPHost(ip + ":" + port)).SetBufferLength(300);
        config.SetBindIPHost(new IPHost(0));
        //载入配置
        UdpSession.Setup(config);
        return UdpSession;
    }
    /// 
    /// 
    /// 
    protected override void OnInitialized()
    {
        config?.Dispose();
        config = new TouchSocketConfig();
        var LogMessage = new TouchSocket.Core.LoggerGroup() { LogLevel = TouchSocket.Core.LogLevel.Trace };
        LogMessage.AddLogger(new EasyLogger(LogOut) { LogLevel = TouchSocket.Core.LogLevel.Trace });
        config.ConfigureContainer(a => a.RegisterSingleton(LogMessage));
        config.SetRemoteIPHost(new IPHost(ip + ":" + port)).SetBufferLength(300);
        config.SetBindIPHost(new IPHost(0));
        UdpSession = new UdpSession();
        UdpSession.Setup(config);
        base.OnInitialized();
    }
    private void LogOut(LogLevel logLevel, object source, string message, Exception exception) => LogAction?.Invoke(logLevel, source, message, exception);
}