2013-05-05 21:24:33 +00:00
|
|
|
using System.Threading.Tasks;
|
|
|
|
using Microsoft.AspNet.SignalR;
|
2013-05-06 00:33:43 +00:00
|
|
|
using Microsoft.AspNet.SignalR.Infrastructure;
|
2013-05-05 21:24:33 +00:00
|
|
|
using NLog;
|
|
|
|
using NzbDrone.Common.Messaging;
|
|
|
|
using NzbDrone.Core.Datastore;
|
|
|
|
using NzbDrone.Core.Datastore.Events;
|
|
|
|
|
|
|
|
namespace NzbDrone.Api.SignalR
|
|
|
|
{
|
|
|
|
public abstract class BasicResourceConnection<T> :
|
|
|
|
NzbDronePersistentConnection,
|
|
|
|
IHandleAsync<ModelEvent<T>>
|
|
|
|
where T : ModelBase
|
|
|
|
{
|
|
|
|
private readonly Logger _logger;
|
|
|
|
|
2013-05-06 00:33:43 +00:00
|
|
|
|
2013-05-05 21:24:33 +00:00
|
|
|
public BasicResourceConnection()
|
|
|
|
{
|
|
|
|
_logger = LogManager.GetCurrentClassLogger();
|
|
|
|
}
|
|
|
|
|
|
|
|
protected override Task OnConnected(IRequest request, string connectionId)
|
|
|
|
{
|
|
|
|
_logger.Debug("SignalR client connected. ID:{0}", connectionId);
|
|
|
|
return base.OnConnected(request, connectionId);
|
|
|
|
}
|
|
|
|
|
|
|
|
public override Task ProcessRequest(Microsoft.AspNet.SignalR.Hosting.HostContext context)
|
|
|
|
{
|
|
|
|
_logger.Debug("Request: {0}", context);
|
|
|
|
return base.ProcessRequest(context);
|
|
|
|
}
|
|
|
|
|
|
|
|
public void HandleAsync(ModelEvent<T> message)
|
|
|
|
{
|
2013-05-06 00:33:43 +00:00
|
|
|
var context =((ConnectionManager)GlobalHost.ConnectionManager).GetConnection(GetType());
|
|
|
|
context.Connection.Broadcast(message);
|
2013-05-05 21:24:33 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|