|
|
@ -1,6 +1,7 @@
|
|
|
|
using System;
|
|
|
|
using System;
|
|
|
|
using System.Collections.Generic;
|
|
|
|
using System.Collections.Generic;
|
|
|
|
using System.Linq;
|
|
|
|
using System.Linq;
|
|
|
|
|
|
|
|
using NLog;
|
|
|
|
using NzbDrone.Api.Extensions;
|
|
|
|
using NzbDrone.Api.Extensions;
|
|
|
|
using NzbDrone.Api.Validation;
|
|
|
|
using NzbDrone.Api.Validation;
|
|
|
|
using NzbDrone.Common;
|
|
|
|
using NzbDrone.Common;
|
|
|
@ -17,14 +18,17 @@ namespace NzbDrone.Api.Commands
|
|
|
|
{
|
|
|
|
{
|
|
|
|
private readonly IManageCommandQueue _commandQueueManager;
|
|
|
|
private readonly IManageCommandQueue _commandQueueManager;
|
|
|
|
private readonly IServiceFactory _serviceFactory;
|
|
|
|
private readonly IServiceFactory _serviceFactory;
|
|
|
|
|
|
|
|
private readonly Logger _logger;
|
|
|
|
|
|
|
|
|
|
|
|
public CommandModule(IManageCommandQueue commandQueueManager,
|
|
|
|
public CommandModule(IManageCommandQueue commandQueueManager,
|
|
|
|
IBroadcastSignalRMessage signalRBroadcaster,
|
|
|
|
IBroadcastSignalRMessage signalRBroadcaster,
|
|
|
|
IServiceFactory serviceFactory)
|
|
|
|
IServiceFactory serviceFactory,
|
|
|
|
|
|
|
|
Logger logger)
|
|
|
|
: base(signalRBroadcaster)
|
|
|
|
: base(signalRBroadcaster)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
_commandQueueManager = commandQueueManager;
|
|
|
|
_commandQueueManager = commandQueueManager;
|
|
|
|
_serviceFactory = serviceFactory;
|
|
|
|
_serviceFactory = serviceFactory;
|
|
|
|
|
|
|
|
_logger = logger;
|
|
|
|
|
|
|
|
|
|
|
|
GetResourceById = GetCommand;
|
|
|
|
GetResourceById = GetCommand;
|
|
|
|
CreateResource = StartCommand;
|
|
|
|
CreateResource = StartCommand;
|
|
|
@ -41,7 +45,13 @@ namespace NzbDrone.Api.Commands
|
|
|
|
private int StartCommand(CommandResource commandResource)
|
|
|
|
private int StartCommand(CommandResource commandResource)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
var commandType = _serviceFactory.GetImplementations(typeof(Command))
|
|
|
|
var commandType = _serviceFactory.GetImplementations(typeof(Command))
|
|
|
|
.Single(c => c.Name.Replace("Command", "").Equals(commandResource.Name, StringComparison.InvariantCultureIgnoreCase));
|
|
|
|
.SingleOrDefault(c => c.Name.Replace("Command", "").Equals(commandResource.Name, StringComparison.InvariantCultureIgnoreCase));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (commandType == null)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
_logger.Error("Found no matching command for {0}", commandResource.Name);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
dynamic command = Request.Body.FromJson(commandType);
|
|
|
|
dynamic command = Request.Body.FromJson(commandType);
|
|
|
|
command.Trigger = CommandTrigger.Manual;
|
|
|
|
command.Trigger = CommandTrigger.Manual;
|
|
|
|