public bool AddOrder(Order order) { var db_order = _da.GetOrder(order.OrderNo); if (db_order == null) { _da.InsertOrder(order); } else { order.OrderID = db_order.OrderID; _da.UpdateOrder(order); } return(true); }
/// <summary> /// Сохранить все данные по торговому счету /// </summary> public void SaveData() { if (_account.AccountID <= 0) { _account = _accountDA.CreateAccount(_account.Code, _account.Name, _account.CommPerc, _account.IsShortEnable, _account.AccountType); _cash.AccountID = _account.AccountID; foreach (Holding holding in _holdings) { holding.AccountID = _account.AccountID; } foreach (Order order in _orders) { order.AccountID = _account.AccountID; } foreach (StopOrder stopOrder in _stopOrders) { stopOrder.AccountID = _account.AccountID; } foreach (Trade trade in _trades) { trade.AccountID = _account.AccountID; } } else { _accountDA.UpdateAccount(_account); } if (_cash.CashID <= 0) { _cash = _accountDA.CreateCash(_cash.AccountID, _cash.Initial, _cash.Current, _cash.Sell, _cash.Buy, _cash.SellComm, _cash.BuyComm); } else { _accountDA.UpdateCash(_cash); } foreach (var holding in _holdings) { if (holding.HoldingID <= 0) { _accountDA.CreateHolding(holding.AccountID, holding.InsID, holding.LotCount); } else { _accountDA.UpdateHolding(holding); // holdings всегда обновляем, так проще } } var createStopOrders = _stopOrders.Where(r => r.StopOrderID <= 0).ToList(); _stopOrders.RemoveAll(r => r.StopOrderID <= 0); foreach (var so in _stopOrders) { if (_modifiedStopOrders.Contains(so)) { _accountDA.UpdateStopOrder(so); } } _modifiedStopOrders.Clear(); foreach (var so in createStopOrders) { var newSo = _accountDA.CreateStopOrder(so.AccountID, so.Time, so.InsID, so.BuySell, so.StopType, so.EndTime, so.AlertPrice, so.Price, so.LotCount, so.Status, so.CompleteTime, so.StopOrderNo); _stopOrders.Add(newSo); var orders = _orders.Where(r => r.StopOrderID == so.StopOrderID).ToList(); foreach (var ord in orders) { ord.StopOrderID = newSo.StopOrderID; if (ord.OrderID > 0) { MarkAsModified(ord); } } } var createOrders = _orders.Where(r => r.OrderID <= 0).ToList(); _orders.RemoveAll(r => r.OrderID <= 0); foreach (var order in _orders) { if (_modifiedOrders.Contains(order)) { _accountDA.UpdateOrder(order); } } _modifiedOrders.Clear(); foreach (var ord in createOrders) { var newOrd = _accountDA.CreateOrder(ord.AccountID, ord.Time, ord.InsID, ord.BuySell, ord.LotCount, ord.Price, ord.Status, ord.StopOrderID, ord.OrderNo); _orders.Add(newOrd); var trades = _trades.Where(r => r.OrderID == ord.OrderID).ToList(); foreach (var trd in trades) { trd.OrderID = newOrd.OrderID; } } var newTrades = _trades.Where(r => r.TradeID <= 0).ToList(); _trades.RemoveAll(r => r.TradeID <= 0); foreach (var nt in newTrades) { var t = _accountDA.CreateTrade(nt.AccountID, nt.OrderID, nt.Time, nt.InsID, nt.BuySell, nt.LotCount, nt.Price, nt.Comm, nt.TradeNo); _trades.Add(t); } }
/// <summary> /// Полная синхронизация заявок /// </summary> private async Task SyncOrdersFull(ISyncPipeServer sps, int localAccountID, int remoteAccountID) { var remOrders = await sps.GetOrders(remoteAccountID, 0); if (remOrders == null) { return; } var orders = _accountDA.GetOrders(localAccountID, false); foreach (var rOrd in remOrders) { int insID = 0; // пытаемся сопоставить инструмент if (_instrum_rid_lid.ContainsKey(rOrd.InsID)) { insID = _instrum_rid_lid[rOrd.InsID]; } if (insID == 0) { continue; // если не смогли сопоставить инструмент, то ничего больше сделать не можем } // ссылка на стоп-заявку int?soID = null; if (rOrd.StopOrderID != null && _stoporder_rid_lid.ContainsKey(rOrd.StopOrderID.Value)) { soID = _stoporder_rid_lid[rOrd.StopOrderID.Value]; } if (_order_rid_lid.ContainsKey(rOrd.OrderID)) { int lid = _order_rid_lid[rOrd.OrderID]; var order = orders.FirstOrDefault(r => r.OrderID == lid); if (order != null) // локальный найден { // сравниваем все по полной, хотя в реальности объект не может так сильно меняться bool isUpdate = false; if (order.InsID != insID) { order.InsID = insID; isUpdate = true; } if (order.BuySell != rOrd.BuySell) { order.BuySell = rOrd.BuySell; isUpdate = true; } if (order.LotCount != rOrd.LotCount) { order.LotCount = rOrd.LotCount; isUpdate = true; } if (order.Status != rOrd.Status) { order.Status = rOrd.Status; isUpdate = true; } if (order.OrderNo != rOrd.OrderNo) { order.OrderNo = rOrd.OrderNo; isUpdate = true; } if (order.Time != rOrd.Time) { order.Time = rOrd.Time; isUpdate = true; } if (order.Price != rOrd.Price) { order.Price = rOrd.Price; isUpdate = true; } if (order.StopOrderID != soID) { order.StopOrderID = soID; isUpdate = true; } if (isUpdate) { _accountDA.UpdateOrder(order); } } else // соответствие есть, но локальный не найден, значит соответствие уже не действительно { _order_rid_lid.Remove(rOrd.OrderID); // удаляем старое соответствие var ord = _accountDA.CreateOrder(localAccountID, rOrd.Time, insID, rOrd.BuySell, rOrd.LotCount, rOrd.Price, rOrd.Status, soID, rOrd.OrderNo); _order_rid_lid.Add(rOrd.OrderID, ord.OrderID); } } else // соответствие не найдено { var ord = _accountDA.CreateOrder(localAccountID, rOrd.Time, insID, rOrd.BuySell, rOrd.LotCount, rOrd.Price, rOrd.Status, soID, rOrd.OrderNo); _order_rid_lid.Add(rOrd.OrderID, ord.OrderID); } } }