Add bot worker
This commit is contained in:
@@ -3,9 +3,9 @@ using MediatR;
|
||||
using static Managing.Common.Enums;
|
||||
using Managing.Application.Abstractions;
|
||||
using Managing.Core;
|
||||
using Managing.Domain.MoneyManagements;
|
||||
using Newtonsoft.Json;
|
||||
using Managing.Application.Bots;
|
||||
using Microsoft.Extensions.Logging;
|
||||
|
||||
namespace Managing.Application.ManageBot
|
||||
{
|
||||
@@ -15,20 +15,18 @@ namespace Managing.Application.ManageBot
|
||||
private readonly ITaskCache _taskCache;
|
||||
private readonly IMoneyManagementService _moneyManagementService;
|
||||
private readonly IBotRepository _botRepository;
|
||||
private readonly IMediator _mediator;
|
||||
private readonly ILogger<LoadBackupBotCommandHandler> _logger;
|
||||
|
||||
public LoadBackupBotCommandHandler(
|
||||
IBotFactory botFactory,
|
||||
ITaskCache taskCache,
|
||||
IMoneyManagementService moneyManagementService,
|
||||
IBotRepository botRepository,
|
||||
IMediator mediator)
|
||||
IBotRepository botRepository)
|
||||
{
|
||||
_botFactory = botFactory;
|
||||
_taskCache = taskCache;
|
||||
_moneyManagementService = moneyManagementService;
|
||||
_botRepository = botRepository;
|
||||
_mediator = mediator;
|
||||
}
|
||||
|
||||
public Task<string> Handle(LoadBackupBotCommand request, CancellationToken cancellationToken)
|
||||
@@ -37,6 +35,8 @@ namespace Managing.Application.ManageBot
|
||||
var backupBots = _botRepository.GetBots();
|
||||
var result = new Dictionary<string, BotStatus>();
|
||||
|
||||
_logger.LogInformation($"Loading {backupBots.Count()} backup bots");
|
||||
|
||||
foreach (var backupBot in backupBots)
|
||||
{
|
||||
// Check if bot is existing in cache
|
||||
@@ -46,7 +46,8 @@ namespace Managing.Application.ManageBot
|
||||
var simpleBot = _taskCache.Get<IBot>(backupBot.Name);
|
||||
if (simpleBot == null)
|
||||
{
|
||||
StartBot(request, backupBot);
|
||||
_logger.LogInformation($"Starting backup bot {backupBot.Name}");
|
||||
StartBot(backupBot);
|
||||
simpleBot.LoadBackup(backupBot);
|
||||
result.Add(simpleBot.GetName(), BotStatus.Backup);
|
||||
}
|
||||
@@ -61,7 +62,8 @@ namespace Managing.Application.ManageBot
|
||||
var scalpingBot = _taskCache.Get<ITradingBot>(backupBot.Name);
|
||||
if (scalpingBot == null)
|
||||
{
|
||||
StartBot(request, backupBot);
|
||||
_logger.LogInformation($"Starting backup bot {backupBot.Name}");
|
||||
StartBot(backupBot);
|
||||
scalpingBot.LoadBackup(backupBot);
|
||||
result.Add(scalpingBot.GetName(), BotStatus.Backup);
|
||||
}
|
||||
@@ -80,13 +82,13 @@ namespace Managing.Application.ManageBot
|
||||
return Task.FromResult(botStatus.ToString());
|
||||
}
|
||||
|
||||
private void StartBot(LoadBackupBotCommand request, BotBackup backupBot)
|
||||
private void StartBot(BotBackup backupBot)
|
||||
{
|
||||
switch (backupBot.BotType)
|
||||
{
|
||||
case BotType.SimpleBot:
|
||||
Func<Task<IBot>> simpleBot = () => Task.FromResult(_botFactory.CreateSimpleBot(request.Name, null));
|
||||
var bot1 = _taskCache.AddOrGetExisting(request.Name, simpleBot).Result;
|
||||
Func<Task<IBot>> simpleBot = () => Task.FromResult(_botFactory.CreateSimpleBot(backupBot.Name, null));
|
||||
var bot1 = _taskCache.AddOrGetExisting(backupBot.Name, simpleBot).Result;
|
||||
bot1.LoadBackup(backupBot);
|
||||
break;
|
||||
case BotType.ScalpingBot:
|
||||
@@ -99,7 +101,7 @@ namespace Managing.Application.ManageBot
|
||||
data.Scenario,
|
||||
data.Timeframe,
|
||||
data.IsForWatchingOnly));
|
||||
var bot2 = _taskCache.AddOrGetExisting(request.Name, scalpingBot).Result;
|
||||
var bot2 = _taskCache.AddOrGetExisting(backupBot.Name, scalpingBot).Result;
|
||||
bot2.LoadBackup(backupBot);
|
||||
break;
|
||||
case BotType.FlippingBot:
|
||||
@@ -112,7 +114,7 @@ namespace Managing.Application.ManageBot
|
||||
dataFlippingBot.Scenario,
|
||||
dataFlippingBot.Timeframe,
|
||||
dataFlippingBot.IsForWatchingOnly));
|
||||
var bot3 = _taskCache.AddOrGetExisting(request.Name, flippingBot).Result;
|
||||
var bot3 = _taskCache.AddOrGetExisting(backupBot.Name, flippingBot).Result;
|
||||
bot3.LoadBackup(backupBot);
|
||||
break;
|
||||
};
|
||||
@@ -121,7 +123,5 @@ namespace Managing.Application.ManageBot
|
||||
|
||||
public class LoadBackupBotCommand : IRequest<string>
|
||||
{
|
||||
public string Name { get; internal set; }
|
||||
public string AccountName { get; internal set; }
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user