Update bot workflow
This commit is contained in:
@@ -111,8 +111,10 @@ public class TradingBot : Bot, ITradingBot
|
||||
|
||||
try
|
||||
{
|
||||
await MessengerService.SendMessage(
|
||||
$"Hi everyone, I'm going to run {Name}. \nI will send a message here everytime a signal is triggered by the {string.Join(",", Strategies.Select(s => s.Name))} strategies.");
|
||||
// await MessengerService.SendMessage(
|
||||
// $"Hey everyone! I'm about to start {Name}. 🚀\n" +
|
||||
// $"I'll post an update here each time a signal is triggered by the following strategies: {string.Join(", ", Strategies.Select(s => s.Name))}."
|
||||
// );
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
@@ -185,7 +187,7 @@ public class TradingBot : Bot, ITradingBot
|
||||
|
||||
if (!IsForWatchingOnly)
|
||||
await ManagePositions();
|
||||
|
||||
|
||||
if (!IsForBacktest)
|
||||
{
|
||||
SaveBackup();
|
||||
@@ -414,11 +416,11 @@ public class TradingBot : Bot, ITradingBot
|
||||
await LogWarning($"Open position trade is rejected for signal {signal.Identifier}");
|
||||
// if position is not open
|
||||
// Re-open the trade for the signal only if signal still up
|
||||
//if (signal.Status == SignalStatus.PositionOpen)
|
||||
//{
|
||||
// Logger.LogInformation($"Try to re-open position");
|
||||
// OpenPosition(signal);
|
||||
//}
|
||||
if (signal.Status == SignalStatus.PositionOpen)
|
||||
{
|
||||
Logger.LogInformation($"Try to re-open position");
|
||||
await OpenPosition(signal);
|
||||
}
|
||||
}
|
||||
}
|
||||
catch (Exception ex)
|
||||
@@ -495,7 +497,7 @@ public class TradingBot : Bot, ITradingBot
|
||||
MoneyManagement,
|
||||
signal.Direction,
|
||||
Ticker,
|
||||
PositionInitiator.Bot,
|
||||
IsForBacktest ? PositionInitiator.PaperTrading : PositionInitiator.Bot ,
|
||||
signal.Date,
|
||||
IsForBacktest,
|
||||
lastPrice,
|
||||
|
||||
@@ -131,7 +131,7 @@ namespace Managing.Application.ManageBot
|
||||
scalpingBotData.ScenarioName,
|
||||
scalpingBotData.Timeframe,
|
||||
scalpingBotData.IsForWatchingOnly);
|
||||
botTask = Task.Run(() => ((ITradingBot)bot).Start());
|
||||
botTask = Task.Run(() => InitBot((ITradingBot)bot, backupBot));
|
||||
break;
|
||||
case Enums.BotType.FlippingBot:
|
||||
var flippingBotData = JsonConvert.DeserializeObject<TradingBotBackup>(backupBot.Data);
|
||||
@@ -143,7 +143,7 @@ namespace Managing.Application.ManageBot
|
||||
flippingBotData.ScenarioName,
|
||||
flippingBotData.Timeframe,
|
||||
flippingBotData.IsForWatchingOnly);
|
||||
botTask = Task.Run(() => ((ITradingBot)bot).Start());
|
||||
botTask = Task.Run(InitBot((ITradingBot)bot, backupBot));
|
||||
break;
|
||||
}
|
||||
|
||||
@@ -154,6 +154,13 @@ namespace Managing.Application.ManageBot
|
||||
}
|
||||
}
|
||||
|
||||
private static Action InitBot(ITradingBot bot, BotBackup backupBot)
|
||||
{
|
||||
bot.Start();
|
||||
bot.LoadBackup(backupBot);
|
||||
return () => { };
|
||||
}
|
||||
|
||||
public IBot CreateSimpleBot(string botName, Workflow workflow)
|
||||
{
|
||||
return new SimpleBot(botName, _tradingBotLogger, workflow, this);
|
||||
|
||||
@@ -19,71 +19,67 @@ public class LoadBackupBotCommandHandler : IRequestHandler<LoadBackupBotCommand,
|
||||
}
|
||||
|
||||
public Task<string> Handle(LoadBackupBotCommand request, CancellationToken cancellationToken)
|
||||
{
|
||||
var backupBots = _botService.GetSavedBots().ToList();
|
||||
_logger.LogInformation("Loading {Count} backup bots.", backupBots.Count);
|
||||
|
||||
var result = new Dictionary<string, BotStatus>();
|
||||
bool anyBackupStarted = false;
|
||||
bool anyBotActive = false;
|
||||
|
||||
foreach (var backupBot in backupBots)
|
||||
{
|
||||
BotStatus botStatus = BotStatus.Down;
|
||||
var backupBots = _botService.GetSavedBots().ToList();
|
||||
var activeBots = _botService.GetActiveBots();
|
||||
var result = new Dictionary<string, BotStatus>();
|
||||
|
||||
_logger.LogInformation($"Loading {backupBots.Count()} backup bots");
|
||||
|
||||
foreach (var backupBot in backupBots)
|
||||
try
|
||||
{
|
||||
// Check if bot is existing in cache
|
||||
try
|
||||
var activeBot = _botService.GetActiveBots().FirstOrDefault(b => b.GetName() == backupBot.Name);
|
||||
|
||||
if (activeBot == null)
|
||||
{
|
||||
switch (backupBot.BotType)
|
||||
_logger.LogInformation("No active instance found for bot {BotName}. Starting backup...", backupBot.Name);
|
||||
_botService.StartBotFromBackup(backupBot);
|
||||
|
||||
activeBot = _botService.GetActiveBots().FirstOrDefault(b => b.GetName() == backupBot.Name);
|
||||
if (activeBot != null)
|
||||
{
|
||||
case BotType.SimpleBot:
|
||||
var simpleBot = activeBots.FirstOrDefault(b => b.GetName() == backupBot.Name);
|
||||
if (simpleBot == null)
|
||||
{
|
||||
_logger.LogInformation($"Starting backup bot {backupBot.Name}");
|
||||
_botService.StartBotFromBackup(backupBot);
|
||||
result.Add(simpleBot.GetName(), BotStatus.Backup);
|
||||
}
|
||||
else
|
||||
{
|
||||
result.Add(simpleBot.GetName(), MiscExtensions.ParseEnum<BotStatus>(simpleBot.GetStatus()));
|
||||
}
|
||||
|
||||
break;
|
||||
case BotType.ScalpingBot:
|
||||
case BotType.FlippingBot:
|
||||
var scalpingBot = activeBots.FirstOrDefault(b => b.GetName() == backupBot.Name);
|
||||
if (scalpingBot == null)
|
||||
{
|
||||
_logger.LogInformation($"Starting backup bot {backupBot.Name}");
|
||||
_botService.StartBotFromBackup(backupBot);
|
||||
var bots = _botService.GetActiveBots();
|
||||
scalpingBot = bots.FirstOrDefault(b => b.GetName() == backupBot.Name);
|
||||
result.Add(scalpingBot.GetName(), BotStatus.Backup);
|
||||
}
|
||||
else
|
||||
{
|
||||
result.Add(scalpingBot.GetName(),
|
||||
MiscExtensions.ParseEnum<BotStatus>(scalpingBot.GetStatus()));
|
||||
}
|
||||
|
||||
break;
|
||||
default:
|
||||
result.Add(backupBot.Name, BotStatus.Down);
|
||||
break;
|
||||
result[activeBot.GetName()] = BotStatus.Backup;
|
||||
anyBackupStarted = true;
|
||||
_logger.LogInformation("Backup bot {BotName} started successfully.", backupBot.Name);
|
||||
}
|
||||
else
|
||||
{
|
||||
result[backupBot.Name] = BotStatus.Down;
|
||||
_logger.LogWarning("Backup bot {BotName} failed to start.", backupBot.Name);
|
||||
}
|
||||
}
|
||||
catch (Exception ex)
|
||||
else
|
||||
{
|
||||
_logger.LogError($"Error loading bot {backupBot.Name}", ex.Message);
|
||||
_botService.DeleteBotBackup(backupBot.Name);
|
||||
result.Add(backupBot.Name, BotStatus.Down);
|
||||
var status = MiscExtensions.ParseEnum<BotStatus>(activeBot.GetStatus());
|
||||
result[activeBot.GetName()] = status;
|
||||
anyBotActive = true;
|
||||
_logger.LogInformation("Bot {BotName} is already active with status {Status}.", activeBot.GetName(), status);
|
||||
}
|
||||
}
|
||||
|
||||
_logger.LogInformation("Bot loading completed");
|
||||
_logger.LogInformation($"Bots: {result.Select(b => $"{b.Key} - {b.Value}")}");
|
||||
|
||||
return Task.FromResult(botStatus.ToString());
|
||||
catch (Exception ex)
|
||||
{
|
||||
_logger.LogError(ex, "Error loading bot {BotName}. Deleting its backup.", backupBot.Name);
|
||||
_botService.DeleteBotBackup(backupBot.Name);
|
||||
result[backupBot.Name] = BotStatus.Down;
|
||||
}
|
||||
}
|
||||
|
||||
var summary = string.Join(", ", result.Select(b => $"{b.Key}: {b.Value}"));
|
||||
_logger.LogInformation("Bot loading completed. Summary: {Summary}", summary);
|
||||
|
||||
// Determine final status
|
||||
BotStatus finalStatus = anyBackupStarted
|
||||
? BotStatus.Backup
|
||||
: anyBotActive ? BotStatus.Up : BotStatus.Down;
|
||||
|
||||
_logger.LogInformation("Final aggregate bot status: {FinalStatus}", finalStatus);
|
||||
|
||||
return Task.FromResult(finalStatus.ToString());
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
public class LoadBackupBotCommand : IRequest<string>
|
||||
|
||||
@@ -108,7 +108,11 @@ namespace Managing.Application.Trading
|
||||
position.Status = IsOpenTradeHandled(position.Open.Status, account.Exchange)
|
||||
? position.Status
|
||||
: PositionStatus.Rejected;
|
||||
tradingService.InsertPosition(position);
|
||||
|
||||
if (request.IsForPaperTrading)
|
||||
{
|
||||
tradingService.InsertPosition(position);
|
||||
}
|
||||
|
||||
return position;
|
||||
}
|
||||
|
||||
@@ -11,7 +11,14 @@ public class UserService : IUserService
|
||||
private readonly IUserRepository _userRepository;
|
||||
private readonly IAccountService _accountService;
|
||||
|
||||
private string[] authorizedAddresses = ["0x6781920674dA695aa5120d95D80c4B1788046806", "0xA2B43AFF0992a47838DF2e6099A8439981f0B717", "0xAD4bcf258852e9d47E580798d312E1a52D59E721", "0xAd6D6c80910096b40e45690506a9f1052e072dCB", "0x309b9235edbe1C6f840816771c6C21aDa6c275EE"];
|
||||
private string[] authorizedAddresses = [
|
||||
"0x6781920674dA695aa5120d95D80c4B1788046806", // Macbook
|
||||
"0xA2B43AFF0992a47838DF2e6099A8439981f0B717", // Phone
|
||||
"0xAD4bcf258852e9d47E580798d312E1a52D59E721", // Razil
|
||||
"0xAd6D6c80910096b40e45690506a9f1052e072dCB", // Teru
|
||||
"0x309b9235edbe1C6f840816771c6C21aDa6c275EE", // Cowchain
|
||||
"0x23AA99254cfaA2c374bE2bA5B55C68018cCdFCb3" // Local optiflex
|
||||
];
|
||||
|
||||
public UserService(
|
||||
IEvmManager evmManager,
|
||||
|
||||
Reference in New Issue
Block a user