2014-04-10 08:06:54 -07:00
|
|
|
|
using MediaBrowser.Model.Logging;
|
|
|
|
|
using System;
|
|
|
|
|
using System.Net;
|
|
|
|
|
using System.Net.Sockets;
|
|
|
|
|
using System.Text;
|
|
|
|
|
|
2014-04-25 10:30:41 -07:00
|
|
|
|
namespace MediaBrowser.Dlna.Ssdp
|
2014-04-10 08:06:54 -07:00
|
|
|
|
{
|
|
|
|
|
public class Datagram
|
|
|
|
|
{
|
2014-04-30 20:24:55 -07:00
|
|
|
|
public IPEndPoint ToEndPoint { get; private set; }
|
|
|
|
|
public IPAddress FromEndPoint { get; private set; }
|
2014-04-10 08:06:54 -07:00
|
|
|
|
public string Message { get; private set; }
|
|
|
|
|
|
2014-04-25 10:30:41 -07:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// The number of times to send the message
|
|
|
|
|
/// </summary>
|
|
|
|
|
public int TotalSendCount { get; private set; }
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// The number of times the message has been sent
|
|
|
|
|
/// </summary>
|
2014-04-10 08:06:54 -07:00
|
|
|
|
public int SendCount { get; private set; }
|
|
|
|
|
|
|
|
|
|
private readonly ILogger _logger;
|
|
|
|
|
|
2014-04-30 20:24:55 -07:00
|
|
|
|
public Datagram(IPEndPoint toEndPoint, IPAddress fromEndPoint, ILogger logger, string message, int totalSendCount)
|
2014-04-10 08:06:54 -07:00
|
|
|
|
{
|
|
|
|
|
Message = message;
|
|
|
|
|
_logger = logger;
|
2014-04-25 10:30:41 -07:00
|
|
|
|
TotalSendCount = totalSendCount;
|
2014-04-30 20:24:55 -07:00
|
|
|
|
FromEndPoint = fromEndPoint;
|
|
|
|
|
ToEndPoint = toEndPoint;
|
2014-04-10 08:06:54 -07:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public void Send()
|
|
|
|
|
{
|
|
|
|
|
var msg = Encoding.ASCII.GetBytes(Message);
|
|
|
|
|
try
|
|
|
|
|
{
|
2014-04-25 10:30:41 -07:00
|
|
|
|
var client = CreateSocket();
|
|
|
|
|
|
2014-04-30 20:24:55 -07:00
|
|
|
|
if (FromEndPoint != null)
|
|
|
|
|
{
|
|
|
|
|
client.Bind(new IPEndPoint(FromEndPoint, 0));
|
|
|
|
|
}
|
2014-04-25 10:30:41 -07:00
|
|
|
|
|
2014-04-30 20:24:55 -07:00
|
|
|
|
client.BeginSendTo(msg, 0, msg.Length, SocketFlags.None, ToEndPoint, result =>
|
2014-04-10 08:06:54 -07:00
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
client.EndSend(result);
|
|
|
|
|
}
|
|
|
|
|
catch (Exception ex)
|
|
|
|
|
{
|
|
|
|
|
_logger.ErrorException("Error sending Datagram", ex);
|
|
|
|
|
}
|
|
|
|
|
finally
|
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
client.Close();
|
|
|
|
|
}
|
|
|
|
|
catch (Exception)
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}, null);
|
|
|
|
|
}
|
|
|
|
|
catch (Exception ex)
|
|
|
|
|
{
|
|
|
|
|
_logger.ErrorException("Error sending Datagram", ex);
|
|
|
|
|
}
|
|
|
|
|
++SendCount;
|
|
|
|
|
}
|
2014-04-25 10:30:41 -07:00
|
|
|
|
|
|
|
|
|
private Socket CreateSocket()
|
|
|
|
|
{
|
|
|
|
|
var socket = new Socket(AddressFamily.InterNetwork, SocketType.Dgram, ProtocolType.Udp);
|
|
|
|
|
|
|
|
|
|
socket.SetSocketOption(SocketOptionLevel.Socket, SocketOptionName.ReuseAddress, true);
|
|
|
|
|
return socket;
|
|
|
|
|
}
|
2014-04-10 08:06:54 -07:00
|
|
|
|
}
|
|
|
|
|
}
|