示例#1
0
        /// <summary>
        /// Синхронизация фин инструментов
        /// </summary>
        private async Task SyncInstrums(ISyncPipeServer sps)
        {
            var remInstrums = await sps.GetInstrumList();

            if (remInstrums == null)
            {
                return;
            }

            var instrums = _instrumDA.GetInstrums();

            foreach (var rIns in remInstrums)
            {
                if (_instrum_rid_lid.ContainsKey(rIns.InsID))
                {
                    int lid = _instrum_rid_lid[rIns.InsID];
                    var ins = instrums.FirstOrDefault(r => r.InsID == lid);
                    if (ins != null) // локальный найден
                    {
                        if (ins.Ticker != rIns.Ticker ||
                            ins.ShortName != rIns.ShortName ||
                            ins.Name != rIns.Name ||
                            ins.LotSize != rIns.LotSize ||
                            ins.Decimals != rIns.Decimals ||
                            ins.PriceStep != rIns.PriceStep)
                        {
                            _instrumDA.UpdateInstrum(ins.InsID, rIns.Ticker, rIns.ShortName, rIns.Name,
                                                     rIns.LotSize, rIns.Decimals, rIns.PriceStep);
                        }
                    }
                    else // соответствие есть, но локальный не найден, значит соответствие уже не действительно
                    {
                        int insID = _instrumDA.InsertInstrum(
                            rIns.Ticker,
                            rIns.ShortName,
                            rIns.Name,
                            rIns.LotSize,
                            rIns.Decimals,
                            rIns.PriceStep);
                        _instrum_rid_lid[rIns.InsID] = insID; // прописываем новый ключ
                    }
                }
                else // соответствие не найдено
                {
                    int insID = _instrumDA.InsertInstrum(
                        rIns.Ticker,
                        rIns.ShortName,
                        rIns.Name,
                        rIns.LotSize,
                        rIns.Decimals,
                        rIns.PriceStep);
                    _instrum_rid_lid.Add(rIns.InsID, insID);
                }
            }

            // отследим ситуацию, когда удаленный объект удален, а локальный остался
            // если локальный объект есть, а репликации для него нет, то значит этот объект не реплицировался и мы его не трогаем
            // если локальный объект есть и репликация для него есть, то мы смотрим remote-объект
            // если remote-объект есть, то здесь ничего не делаем (эту ситуацию мы обработали выше)
            // если remote-объекта нет, то локальный объект НЕ удаляем и не меняем, а просто удаляем для него репликацию
            // удалить локальный объект нельзя, т.к. на него могут быть ссылки, т.е. он остается, но больше не будет реплицироваться
            // если в удаленной базе объект снова возникнет под прежним id (что вряд-ли возможно),
            // то локально будет создан новый объект, а старый также останется
            foreach (var ins in instrums)
            {
                if (!_instrum_rid_lid.ContainsValue(ins.InsID))
                {
                    continue;                                                           // запись не реплицировалась и мы ее пропускаем
                }
                var repl  = _instrum_rid_lid.FirstOrDefault(r => r.Value == ins.InsID); // обязательно будет не null
                var found = remInstrums.FirstOrDefault(r => r.InsID == repl.Key);
                if (found == null)                                                      // соответствующей remote-записи нет, значит локальную запись удаляем и убираем для нее репликацию
                {
                    _instrum_rid_lid.Remove(repl.Key);
                }
            }
        }