jellyfin/Emby.Common.Implementations/Net/NetSocket.cs

86 lines
2 KiB
C#
Raw Normal View History

2016-11-08 19:44:23 +01:00
using System;
using System.Net;
using System.Net.Sockets;
using System.Threading;
using Emby.Common.Implementations.Networking;
using MediaBrowser.Model.Net;
using MediaBrowser.Model.Logging;
namespace Emby.Common.Implementations.Net
{
public class NetSocket : ISocket
{
public Socket Socket { get; private set; }
private readonly ILogger _logger;
public NetSocket(Socket socket, ILogger logger)
{
Socket = socket;
_logger = logger;
}
public IpEndPointInfo LocalEndPoint
{
get
{
2016-11-11 08:24:36 +01:00
return NetworkManager.ToIpEndPointInfo((IPEndPoint)Socket.LocalEndPoint);
2016-11-08 19:44:23 +01:00
}
}
public IpEndPointInfo RemoteEndPoint
{
get
{
2016-11-11 08:24:36 +01:00
return NetworkManager.ToIpEndPointInfo((IPEndPoint)Socket.RemoteEndPoint);
2016-11-08 19:44:23 +01:00
}
}
public void Close()
{
#if NET46
Socket.Close();
#else
Socket.Dispose();
#endif
}
public void Shutdown(bool both)
{
if (both)
{
Socket.Shutdown(SocketShutdown.Both);
}
else
{
// Change interface if ever needed
throw new NotImplementedException();
}
}
public void Listen(int backlog)
{
Socket.Listen(backlog);
}
public void Bind(IpEndPointInfo endpoint)
{
2016-11-11 08:24:36 +01:00
var nativeEndpoint = NetworkManager.ToIPEndPoint(endpoint);
2016-11-08 19:44:23 +01:00
Socket.Bind(nativeEndpoint);
}
private SocketAcceptor _acceptor;
public void StartAccept(Action<ISocket> onAccept, Func<bool> isClosed)
{
_acceptor = new SocketAcceptor(_logger, Socket, onAccept, isClosed);
_acceptor.StartAccept();
}
public void Dispose()
{
Socket.Dispose();
}
}
}