Compare commits

..

2 Commits

Author SHA1 Message Date
vlad zverzhkhovskiy e5eee25042 Поправка сохранения стопов
test / deploy_trader_prod (push) Successful in 1m41s Details
2025-09-23 11:16:52 +03:00
vlad zverzhkhovskiy d459728ca3 Поправка сохранения стопов 2025-09-23 11:16:27 +03:00
5 changed files with 16 additions and 15 deletions

View File

@ -5,10 +5,10 @@ namespace KLHZ.Trader.Core.Exchange.Extentions
{ {
internal static class InvestApiClientExtentions internal static class InvestApiClientExtentions
{ {
public static async Task<Dictionary<string,string>> GetAccounts(this InvestApiClient client, params string[] managedAccountNamePatterns) public static async Task<Dictionary<string, string>> GetAccounts(this InvestApiClient client, params string[] managedAccountNamePatterns)
{ {
var accounts = await client.Users.GetAccountsAsync(); var accounts = await client.Users.GetAccountsAsync();
var accs = new Dictionary<string,string>(); var accs = new Dictionary<string, string>();
foreach (var pattern in managedAccountNamePatterns) foreach (var pattern in managedAccountNamePatterns)
{ {
var aids = accounts.Accounts var aids = accounts.Accounts

View File

@ -9,7 +9,7 @@ namespace KLHZ.Trader.Core.Exchange.Interfaces
public decimal Total { get; } public decimal Total { get; }
bool Initialized { get; } bool Initialized { get; }
string AccountId { get; } string AccountId { get; }
string? AccountName{ get; } string? AccountName { get; }
Task Init(string accountId, string? accountName = null); Task Init(string accountId, string? accountName = null);
Task LoadPortfolio(); Task LoadPortfolio();
ImmutableDictionary<string, Asset> Assets { get; } ImmutableDictionary<string, Asset> Assets { get; }

View File

@ -52,7 +52,7 @@ namespace KLHZ.Trader.Core.Exchange.Services
var accounts = await _investApiClient.GetAccounts(_managedAccountNamePatterns); var accounts = await _investApiClient.GetAccounts(_managedAccountNamePatterns);
foreach (var acc in accounts) foreach (var acc in accounts)
{ {
await _portfolioWrapper.AddAccount(acc.Key,acc.Value); await _portfolioWrapper.AddAccount(acc.Key, acc.Value);
} }
_ = CycleSubscribtion(accounts.Keys.ToArray()); _ = CycleSubscribtion(accounts.Keys.ToArray());
} }

View File

@ -18,6 +18,7 @@ using Microsoft.Extensions.Logging;
using Microsoft.Extensions.Options; using Microsoft.Extensions.Options;
using System.Collections.Concurrent; using System.Collections.Concurrent;
using System.Collections.Immutable; using System.Collections.Immutable;
using System.Security.Cryptography;
using System.Threading.Channels; using System.Threading.Channels;
using Tinkoff.InvestApi; using Tinkoff.InvestApi;
using Asset = KLHZ.Trader.Core.Exchange.Models.AssetsAccounting.Asset; using Asset = KLHZ.Trader.Core.Exchange.Models.AssetsAccounting.Asset;
@ -293,8 +294,8 @@ namespace KLHZ.Trader.Core.Exchange.Services
await OpenPositions(accounts, message, PositionType.Long, stops.stopLoss, stops.takeProfit, 1); await OpenPositions(accounts, message, PositionType.Long, stops.stopLoss, stops.takeProfit, 1);
} }
await LogDeclision(DeclisionTradeAction.OpenLong, message); await LogDeclision(DeclisionTradeAction.OpenLong, message);
await LogDeclision(DeclisionTradeAction.OpenLong, message.Value + stops.takeProfit, message.Time.AddMilliseconds(-100), message); await LogDeclision(DeclisionTradeAction.OpenLong, message.Value + stops.takeProfit, message.Time.AddMilliseconds(-RandomNumberGenerator.GetInt32(300, 1000)), message);
await LogDeclision(DeclisionTradeAction.OpenLong, message.Value - stops.stopLoss, message.Time.AddMilliseconds(100), message); await LogDeclision(DeclisionTradeAction.OpenLong, message.Value - stops.stopLoss, message.Time.AddMilliseconds(RandomNumberGenerator.GetInt32(300, 1000)), message);
} }
if (newMod == TradingMode.Dropping && newMod != oldMod) if (newMod == TradingMode.Dropping && newMod != oldMod)
{ {
@ -309,8 +310,8 @@ namespace KLHZ.Trader.Core.Exchange.Services
await OpenPositions(accounts, message, PositionType.Short, stops.stopLoss, stops.takeProfit, 1); await OpenPositions(accounts, message, PositionType.Short, stops.stopLoss, stops.takeProfit, 1);
} }
await LogDeclision(DeclisionTradeAction.OpenShort, message); await LogDeclision(DeclisionTradeAction.OpenShort, message);
await LogDeclision(DeclisionTradeAction.OpenShort, message.Value - stops.takeProfit, message.Time.AddMilliseconds(-100), message); await LogDeclision(DeclisionTradeAction.OpenShort, message.Value - stops.takeProfit, message.Time.AddMilliseconds(-RandomNumberGenerator.GetInt32(10, 100)), message);
await LogDeclision(DeclisionTradeAction.OpenShort, message.Value + stops.stopLoss, message.Time.AddMilliseconds(100), message); await LogDeclision(DeclisionTradeAction.OpenShort, message.Value + stops.stopLoss, message.Time.AddMilliseconds(RandomNumberGenerator.GetInt32(300, 1000)), message);
} }
TradingModes[message.Figi] = newMod; TradingModes[message.Figi] = newMod;
if (oldMod != newMod) if (oldMod != newMod)
@ -547,8 +548,8 @@ INewPrice message, int windowMaxSize, decimal uptrendStartingDetectionMeanfullSt
} }
await LogDeclision(DeclisionTradeAction.OpenLong, message); await LogDeclision(DeclisionTradeAction.OpenLong, message);
await LogDeclision(DeclisionTradeAction.OpenLong, message.Value + stops.takeProfit, message.Time.AddMilliseconds(-100), message); await LogDeclision(DeclisionTradeAction.OpenLong, message.Value + stops.takeProfit, message.Time.AddMilliseconds(-RandomNumberGenerator.GetInt32(300, 1000)), message);
await LogDeclision(DeclisionTradeAction.OpenLong, message.Value - stops.stopLoss, message.Time.AddMilliseconds(100), message); await LogDeclision(DeclisionTradeAction.OpenLong, message.Value - stops.stopLoss, message.Time.AddMilliseconds(RandomNumberGenerator.GetInt32(300, 1000)), message);
} }
if (result[TradingEvent.DowntrendStart] > Constants.PowerUppingCoefficient if (result[TradingEvent.DowntrendStart] > Constants.PowerUppingCoefficient
&& !ShortOpeningStops.ContainsKey(message.Figi) && !ShortOpeningStops.ContainsKey(message.Figi)
@ -567,8 +568,8 @@ INewPrice message, int windowMaxSize, decimal uptrendStartingDetectionMeanfullSt
} }
await LogDeclision(DeclisionTradeAction.OpenShort, message); await LogDeclision(DeclisionTradeAction.OpenShort, message);
await LogDeclision(DeclisionTradeAction.OpenShort, message.Value - stops.takeProfit, message.Time.AddMilliseconds(-100), message); await LogDeclision(DeclisionTradeAction.OpenShort, message.Value - stops.takeProfit, message.Time.AddMilliseconds(-RandomNumberGenerator.GetInt32(300, 1000)), message);
await LogDeclision(DeclisionTradeAction.OpenShort, message.Value + stops.stopLoss, message.Time.AddMilliseconds(100), message); await LogDeclision(DeclisionTradeAction.OpenShort, message.Value + stops.stopLoss, message.Time.AddMilliseconds(RandomNumberGenerator.GetInt32(300, 1000)), message);
} }
if (result[TradingEvent.UptrendEnd] > Constants.UppingCoefficient) if (result[TradingEvent.UptrendEnd] > Constants.UppingCoefficient)
{ {

View File

@ -39,7 +39,7 @@ namespace KLHZ.Trader.Core.TG.Services
{ {
await _botClient.SendMessage(admin, message.Text); await _botClient.SendMessage(admin, message.Text);
} }
catch(Exception ex) catch (Exception ex)
{ {
_logger.LogError(ex, "Ошибка при отправке сообщения в бота."); _logger.LogError(ex, "Ошибка при отправке сообщения в бота.");
} }