public virtual void ProcessCommand(ClientManager clientManager, object cmd, long acknowledgementId, UsageStats stats) { Alachisoft.NCache.Common.Protobuf.Command command = cmd as Alachisoft.NCache.Common.Protobuf.Command; if (ServerMonitor.MonitorActivity) { ServerMonitor.LogClientActivity("CmdMgr.PrsCmd", "enter"); } if (ServerMonitor.MonitorActivity) { ServerMonitor.LogClientActivity("CmdMgr.PrsCmd", "" + command); } if (SocketServer.Logger.IsDetailedLogsEnabled) { SocketServer.Logger.NCacheLog.Info("ConnectionManager.ReceiveCallback", clientManager.ToString() + " COMMAND to be executed : " + command.type.ToString() + " RequestId :" + command.requestID); } HPTimeStats milliSecWatch = new HPTimeStats(); milliSecWatch.BeginSample(); bool clientDisposed = false; bool isAsync = false; string _methodName = command.type.ToString();; Stopwatch commandExecution = new Stopwatch(); commandExecution.Start(); CommandBase incommingCmd = null; bool isUnsafeCommand = false, doThrottleCommand = true; switch (command.type) { case Alachisoft.NCache.Common.Protobuf.Command.Type.INIT: Alachisoft.NCache.Common.Protobuf.InitCommand initCommand = command.initCommand; initCommand.requestId = command.requestID; if (SocketServer.Logger.IsDetailedLogsEnabled) { SocketServer.Logger.NCacheLog.Info("ConnectionManager.ReceiveCallback", clientManager.ToString() + " RequestId :" + command.requestID); } incommingCmd = new InitializeCommand(bookie.RequestLoggingEnabled); doThrottleCommand = false; break; case Alachisoft.NCache.Common.Protobuf.Command.Type.EXECUTE_READER: Alachisoft.NCache.Common.Protobuf.ExecuteReaderCommand executeReaderCommand = command.executeReaderCommand; executeReaderCommand.requestId = command.requestID; incommingCmd = new ExecuteReaderCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.EXECUTE_READER_CQ: Alachisoft.NCache.Common.Protobuf.ExecuteReaderCQCommand executeReaderCQCommand = command.executeReaderCQCommand; executeReaderCQCommand.requestId = command.requestID; incommingCmd = new ExecuteReaderCQCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.GET_READER_CHUNK: Alachisoft.NCache.Common.Protobuf.GetReaderNextChunkCommand getReaderChunkCommand = command.getReaderNextChunkCommand; getReaderChunkCommand.requestId = command.requestID; incommingCmd = new GetReaderChunkCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.DISPOSE_READER: Alachisoft.NCache.Common.Protobuf.DisposeReaderCommand disposeReaderCommand = command.disposeReaderCommand; disposeReaderCommand.requestId = command.requestID; incommingCmd = new DisposeReaderCommand(); break; // Added in server to cater getProductVersion request from client case Common.Protobuf.Command.Type.GET_PRODUCT_VERSION: command.getProductVersionCommand.requestId = command.requestID; incommingCmd = new GetProductVersionCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.ADD: command.addCommand.requestId = command.requestID; isAsync = command.addCommand.isAsync; incommingCmd = new AddCommand(); isUnsafeCommand = true; break; case Alachisoft.NCache.Common.Protobuf.Command.Type.ADD_BULK: command.bulkAddCommand.requestId = command.requestID; incommingCmd = new BulkAddCommand(); isUnsafeCommand = true; break; case Alachisoft.NCache.Common.Protobuf.Command.Type.ADD_DEPENDENCY: command.addDependencyCommand.requestId = command.requestID; incommingCmd = new AddDependencyCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.ADD_SYNC_DEPENDENCY: command.addSyncDependencyCommand.requestId = command.requestID; incommingCmd = new AddSyncDependencyCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.CLEAR: command.clearCommand.requestId = command.requestID; incommingCmd = new ClearCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.CLOSE_STREAM: command.closeStreamCommand.requestId = command.requestID; incommingCmd = new CloseStreamCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.CONTAINS: command.containsCommand.requestId = command.requestID; incommingCmd = new ContainsCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.COUNT: command.countCommand.requestId = command.requestID; incommingCmd = new CountCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.DISPOSE: command.disposeCommand.requestId = command.requestID; incommingCmd = new DisposeCommand(); clientDisposed = true; break; case Alachisoft.NCache.Common.Protobuf.Command.Type.GET: command.getCommand.requestId = command.requestID; incommingCmd = new GetCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.GET_BULK: command.bulkGetCommand.requestId = command.requestID; incommingCmd = new BulkGetCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.GET_CACHE_ITEM: command.getCacheItemCommand.requestId = command.requestID; incommingCmd = new GetCacheItemCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.GET_CACHE_BINDING: command.getCacheBindingCommand.requestId = command.requestID; incommingCmd = new GetCacheBindingCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.GET_ENUMERATOR: command.getEnumeratorCommand.requestId = command.requestID; incommingCmd = new GetEnumeratorCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.GET_NEXT_CHUNK: command.getNextChunkCommand.requestId = command.requestID; incommingCmd = new GetNextChunkCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.GET_GROUP_NEXT_CHUNK: command.getGroupNextChunkCommand.requestId = command.requestID; incommingCmd = new GetGroupNextChunkCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.GET_GROUP: Alachisoft.NCache.Common.Protobuf.GetGroupCommand getGroupCommand = command.getGroupCommand; getGroupCommand.requestId = command.requestID; if (getGroupCommand.getGroupKeys) { incommingCmd = new GetGroupKeys(); _methodName = MethodsName.GetGroupKeys; } else { incommingCmd = new GetGroupData(); _methodName = MethodsName.GetGroupData; } break; case Alachisoft.NCache.Common.Protobuf.Command.Type.GET_HASHMAP: command.getHashmapCommand.requestId = command.requestID; incommingCmd = new GetHashmapCommand(); doThrottleCommand = false; break; case Alachisoft.NCache.Common.Protobuf.Command.Type.GET_LOGGING_INFO: command.getLoggingInfoCommand.requestId = command.requestID; incommingCmd = new GetLogginInfoCommand(); break; #if !(DEVELOPMENT) case Alachisoft.NCache.Common.Protobuf.Command.Type.GET_OPTIMAL_SERVER: command.getOptimalServerCommand.requestId = command.requestID; incommingCmd = new GetOptimalServerCommand(); doThrottleCommand = false; break; #endif case Alachisoft.NCache.Common.Protobuf.Command.Type.GET_STREAM_LENGTH: command.getStreamLengthCommand.requestId = command.requestID; incommingCmd = new GetStreamLengthCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.GET_TAG: command.getTagCommand.requestId = command.requestID; incommingCmd = new GetTagCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.REMOVE_BY_TAG: command.removeByTagCommand.requestId = command.requestID; incommingCmd = new RemoveByTagCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.GET_KEYS_TAG: command.getKeysByTagCommand.requestId = command.requestID; incommingCmd = new GetKeysByTagCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.GET_TYPEINFO_MAP: command.getTypeInfoMapCommand.requestId = command.requestID; incommingCmd = new GetTypeInfoMap(); doThrottleCommand = false; break; case Alachisoft.NCache.Common.Protobuf.Command.Type.INSERT: command.insertCommand.requestId = command.requestID; incommingCmd = new InsertCommand(); isAsync = command.insertCommand.isAsync; isUnsafeCommand = true; break; case Alachisoft.NCache.Common.Protobuf.Command.Type.INSERT_BULK: command.bulkInsertCommand.requestId = command.requestID; incommingCmd = new BulkInsertCommand(); isUnsafeCommand = true; break; case Alachisoft.NCache.Common.Protobuf.Command.Type.ISLOCKED: command.isLockedCommand.requestId = command.requestID; incommingCmd = new IsLockedCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.LOCK: command.lockCommand.requestId = command.requestID; incommingCmd = new LockCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.LOCK_VERIFY: command.lockVerifyCommand.requestId = command.requestID; incommingCmd = new VerifyLockCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.OPEN_STREAM: command.openStreamCommand.requestId = command.requestID; incommingCmd = new OpenStreamCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.RAISE_CUSTOM_EVENT: command.raiseCustomEventCommand.requestId = command.requestID; incommingCmd = new RaiseCustomNotifCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.READ_FROM_STREAM: command.readFromStreamCommand.requestId = command.requestID; incommingCmd = new ReadFromStreamCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.REGISTER_BULK_KEY_NOTIF: command.registerBulkKeyNotifCommand.requestId = command.requestID; incommingCmd = new RegisterBulkKeyNotifcationCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.REGISTER_KEY_NOTIF: command.registerKeyNotifCommand.requestId = command.requestID; incommingCmd = new RegisterKeyNotifcationCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.REGISTER_NOTIF: command.registerNotifCommand.requestId = command.requestID; incommingCmd = new NotificationRegistered(); doThrottleCommand = false; break; case Common.Protobuf.Command.Type.REGISTER_POLLING_NOTIFICATION: command.registerPollNotifCommand.requestId = command.requestID; incommingCmd = new RegisterPollingNotificationCommand(); break; case Common.Protobuf.Command.Type.POLL: command.pollCommand.requestId = command.requestID; incommingCmd = new PollCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.REMOVE: command.removeCommand.requestId = command.requestID; incommingCmd = new RemoveCommand(); isUnsafeCommand = true; break; case Alachisoft.NCache.Common.Protobuf.Command.Type.DELETE: command.deleteCommand.requestId = command.requestID; incommingCmd = new DeleteCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.REMOVE_BULK: command.bulkRemoveCommand.requestId = command.requestID; incommingCmd = new BulkRemoveCommand(); isUnsafeCommand = true; break; case Alachisoft.NCache.Common.Protobuf.Command.Type.DELETE_BULK: command.bulkDeleteCommand.requestId = command.requestID; incommingCmd = new BulkDeleteCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.REMOVE_GROUP: command.removeGroupCommand.requestId = command.requestID; incommingCmd = new RemoveGroupCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.SEARCH: Alachisoft.NCache.Common.Protobuf.SearchCommand searchCommand = command.searchCommand; searchCommand.requestId = command.requestID; if (searchCommand.searchEntries) { incommingCmd = new SearchEnteriesCommand(); _methodName = "SearchEnteries"; } else { incommingCmd = new SearchCommand(); _methodName = "Search"; } break; case Alachisoft.NCache.Common.Protobuf.Command.Type.SEARCH_CQ: Alachisoft.NCache.Common.Protobuf.SearchCQCommand searchCQCommand = command.searchCQCommand; searchCQCommand.requestId = command.requestID; if (searchCQCommand.searchEntries) { _methodName = "SearchCQEnteries"; incommingCmd = new SearchEnteriesCQCommand(); } else { _methodName = "SearchCQ"; incommingCmd = new SearchCQCommand(); } break; case Alachisoft.NCache.Common.Protobuf.Command.Type.UNREGISTER_CQ: command.unRegisterCQCommand.requestId = command.requestID; incommingCmd = new UnRegisterCQCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.REGISTER_CQ: command.registerCQCommand.requestId = command.requestID; incommingCmd = new RegisterCQCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.DELETEQUERY: Alachisoft.NCache.Common.Protobuf.DeleteQueryCommand deleteQueryCommand = command.deleteQueryCommand; deleteQueryCommand.requestId = command.requestID; if (deleteQueryCommand.isRemove) { incommingCmd = new RemoveQueryCommand(); _methodName = "RemoveQuery"; } else { incommingCmd = new DeleteQueryCommand(); _methodName = "DeleteQuery"; } break; case Alachisoft.NCache.Common.Protobuf.Command.Type.UNLOCK: command.unlockCommand.requestId = command.requestID; incommingCmd = new UnlockCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.UNREGISTER_BULK_KEY_NOTIF: command.unRegisterBulkKeyNotifCommand.requestId = command.requestID; incommingCmd = new UnRegsisterBulkKeyNotification(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.UNREGISTER_KEY_NOTIF: command.unRegisterKeyNotifCommand.requestId = command.requestID; incommingCmd = new UnRegisterKeyNoticationCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.WRITE_TO_STREAM: command.writeToStreamCommand.requestId = command.requestID; incommingCmd = new WriteToStreamCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.ADD_ATTRIBUTE: command.addAttributeCommand.requestId = command.requestID; incommingCmd = new AddAttributeCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.SYNC_EVENTS: command.syncEventsCommand.requestId = command.requestID; incommingCmd = new SyncEventCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.INQUIRY_REQUEST: incommingCmd = new InquiryRequestCommand(bookie); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.MAP_REDUCE_TASK: command.mapReduceTaskCommand.requestId = command.requestID; incommingCmd = new MapReduceTaskCommand(); break; case Common.Protobuf.Command.Type.TASK_CALLBACK: command.TaskCallbackCommand.requestId = command.requestID; incommingCmd = new TaskCallbackCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.CANCEL_TASK: incommingCmd = new TaskCancelCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.RUNNING_TASKS: command.RunningTasksCommand.requestId = command.requestID; incommingCmd = new GetRunningTasksCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.TASK_PROGRESS: command.TaskProgressCommand.requestId = command.requestID; incommingCmd = new TaskProgressCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.TASK_ENUMERATOR: incommingCmd = new TaskEnumeratorCommand(); break; case Common.Protobuf.Command.Type.TASK_NEXT_RECORD: command.NextRecordCommand.RequestId = command.requestID; incommingCmd = new TaskNextRecordCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.INVOKE_ENTRY_PROCESSOR: incommingCmd = new InvokeEntryProcessorCommand(); break; case Alachisoft.NCache.Common.Protobuf.Command.Type.GET_RUNNING_SERVERS: command.getRunningServersCommand.requestId = command.requestID; incommingCmd = new GetRunningServersCommand(); doThrottleCommand = false; break; case Alachisoft.NCache.Common.Protobuf.Command.Type.GET_EXPIRATION: command.getExpirationCommand.requestId = command.requestID; incommingCmd = new GetExpirationCommand(); doThrottleCommand = false; break; case Common.Protobuf.Command.Type.GET_CONNECTED_CLIENTS: command.getConnectedClientsCommand.requestId = command.requestID; incommingCmd = new GetConnectedClientsCommand(); break; case Common.Protobuf.Command.Type.TOUCH: command.touchCommand.requestId = command.requestID; incommingCmd = new TouchCommand(); break; #region PUB_SUB case Common.Protobuf.Command.Type.GET_TOPIC: command.getTopicCommand.requestId = command.requestID; incommingCmd = new GetTopicCommand(); break; case Common.Protobuf.Command.Type.SUBSCRIBE_TOPIC: command.subscribeTopicCommand.requestId = command.requestID; incommingCmd = new SubscribeTopicCommand(); break; case Common.Protobuf.Command.Type.UNSUBSCRIBE_TOPIC: command.unSubscribeTopicCommand.requestId = command.requestID; incommingCmd = new UnSubscribeTopicCommand(); break; case Common.Protobuf.Command.Type.REMOVE_TOPIC: command.removeTopicCommand.requestId = command.requestID; incommingCmd = new RemoveTopicCommand(); break; case Common.Protobuf.Command.Type.MESSAGE_PUBLISH: command.messagePublishCommand.requestId = command.requestID; incommingCmd = new MessagePublishCommand(); break; case Common.Protobuf.Command.Type.GET_MESSAGE: command.getMessageCommand.requestId = command.requestID; incommingCmd = new GetMessageCommand(); break; case Common.Protobuf.Command.Type.MESSAGE_ACKNOWLEDGMENT: command.mesasgeAcknowledgmentCommand.requestId = command.requestID; incommingCmd = new MessageAcknowledgementCommand(); break; #endregion } if (SocketServer.IsServerCounterEnabled) { _perfStatsCollector.MsecPerCacheOperationBeginSample(); } try { if (isUnsafeCommand && clientManager.SupportAcknowledgement) { if (clientDisposed) { bookie.RemoveClientAccount(clientManager.ClientID); } else { bookie.RegisterRequest(clientManager.ClientID, command.requestID, command.commandID, acknowledgementId); } } incommingCmd.ExecuteCommand(clientManager, command); } catch (Exception ex) { if (isUnsafeCommand && clientManager.SupportAcknowledgement) { bookie.UpdateRequest(clientManager.ClientID, command.requestID, command.commandID, Alachisoft.NCache.Common.Enum.RequestStatus.RECEIVED_WITH_ERROR, null); } throw; } if (SocketServer.Logger.IsDetailedLogsEnabled) { SocketServer.Logger.NCacheLog.Info("ConnectionManager.ReceiveCallback", clientManager.ToString() + " after executing COMMAND : " + command.type.ToString() + " RequestId :" + command.requestID); } if (SocketServer.IsServerCounterEnabled) { _perfStatsCollector.MsecPerCacheOperationEndSample(); } #if COMMUNITY if (clientManager != null && clientManager.CmdExecuter != null && incommingCmd.OperationResult == OperationResult.Success) { clientManager.CmdExecuter.UpdateSocketServerStats(new SocketServerStats(clientManager.ClientsRequests, clientManager.ClientsBytesSent, clientManager.ClientsBytesRecieved)); } #endif if (isUnsafeCommand && clientManager.SupportAcknowledgement) { if (clientManager != null && clientManager.IsDisposed && incommingCmd.OperationResult == OperationResult.Failure) { bookie.UpdateRequest(clientManager.ClientID, command.requestID, command.commandID, Common.Enum.RequestStatus.RECEIVED_WITH_ERROR, null); } else { bookie.UpdateRequest(clientManager.ClientID, command.requestID, command.commandID, Common.Enum.RequestStatus.RECEIVED_AND_EXECUTED, incommingCmd.SerializedResponsePackets); } } if (clientManager != null && !clientManager.IsCacheStopped) { if (incommingCmd.SerializedResponsePackets != null) { if (SocketServer.IsServerCounterEnabled) { _perfStatsCollector.IncrementResponsesPerSecStats(1); } foreach (IList reponse in incommingCmd.SerializedResponsePackets) { ConnectionManager.AssureSend(clientManager, reponse, Alachisoft.NCache.Common.Enum.Priority.Normal); } } commandExecution.Stop(); if (!isAsync && command.type != Common.Protobuf.Command.Type.PING && (incommingCmd.SerializedResponsePackets == null || incommingCmd.SerializedResponsePackets.Count <= 0)) { try { if (Management.APILogging.APILogManager.APILogManger != null && Management.APILogging.APILogManager.EnableLogging) { APILogItemBuilder log = new APILogItemBuilder(); log.GenerateCommandManagerLog(_methodName, clientManager.ClientID.ToLower(), clientManager.ClientSocketId.ToString(), commandExecution.Elapsed, "Serialized Response Packets for " + _methodName + " command is null or empty."); } } catch { } } } double commandElapsedSeconds = commandExecution.Elapsed.TotalSeconds; if (ServiceConfiguration.EnableCommandThresholdLogging && commandElapsedSeconds > ServiceConfiguration.CommandExecutionThreshold) { try { string commandName; string details = incommingCmd.GetCommandParameters(out commandName); string[] clientIdParts = clientManager.ClientID.Split(':'); string clientipid = "CLIENT"; try { clientipid = clientIdParts[clientIdParts.Length - 2] + ":" + clientIdParts[clientIdParts.Length - 1]; } catch { } CommandLogManager.LogInfo(clientipid, commandElapsedSeconds.ToString(), commandName, details); } catch (Exception ex) { } } if (stats != null) { stats.EndSample(); if (incommingCmd != null) { // Increment Counter incommingCmd.IncrementCounter(_perfStatsCollector, stats.Current); } } if (ServerMonitor.MonitorActivity) { ServerMonitor.LogClientActivity("CmdMgr.PrsCmd", "exit"); } }
public void GetDataInCallback(int command, IReadOnlyList <byte> data, Action <Exception, IReadOnlyList <byte> > callback) { if (command == 6) { var result = data.ToList(); if (result[3] == 0) { Log.Log(Name + " > " + "Запрос текущих данных через шестерку"); var cmd = new PollCommand(); if (_lastCurrentDataRequestTime.HasValue && _lastCurrentDataResult != null && DateTime.Now - _lastCurrentDataRequestTime < _cacheTtl) { NamedLog("Данные взяты из кэша (время жизни кэша до: " + (_lastCurrentDataRequestTime.Value + _cacheTtl).ToString("yyyy.MM.dd-HH:mm:ss") + ") и сейчас будут отправлены: " + _lastCurrentDataResult.ToText()); callback(null, _lastCurrentDataResult); } else { NamedLog("Отправка запроса в менеджер обмена по сети БУМИЗ"); _bumiz.SendDataAsync( _bumizControllerInfo.Name, cmd, sendResult => { try { NamedLog("Менеджер обмена БУМИЗ вернул управление"); if (sendResult.ChannelException == null) { var cmdResult = cmd.GetResult(sendResult.Bytes); NamedLog("Результат обмена: " + cmdResult); var i1 = (float)cmdResult.PhaseAcurrent; var i2 = (float)cmdResult.PhaseBcurrent; var i3 = (float)cmdResult.PhaseCcurrent; var p1 = (float)cmdResult.PowerT1; var p2 = (float)cmdResult.PowerT2; var bits = (byte)( (cmdResult.IsInFault ? 0x01 : 0x00) + (cmdResult.IsTurnedOn ? 0x02 : 0x00) + (cmdResult.NoLinkWithCounter ? 0x00 : 0x04) + (cmdResult.CounterType == "СЕ102" ? 0x08 : 0x00) + (cmdResult.IsAutoTurnOffTimerStarted ? 0x10 : 0x00) + (cmdResult.NoFramOrCrcError ? 0x20 : 0x00) + (cmdResult.NoArchives ? 0x00 : 0x40)); NamedLog("Упаковка данных в байты ответа..."); result.AddRange(i1.ToBytes()); result.AddRange(i2.ToBytes()); result.AddRange(i3.ToBytes()); result.AddRange(p1.ToBytes()); result.AddRange(p2.ToBytes()); result.Add(bits); var channel = result[0]; var number = result[2]; result.Add(number); result.Add(0); result.Add(channel); result.Add(0); NamedLog("Упаковка текущих данных завершена"); _lastCurrentDataRequestTime = DateTime.Now; _lastCurrentDataResult = result.ToList(); File.AppendAllText( Path.Combine(Env.LogPath, _bumizControllerInfo.Name + ".read.txt"), DateTime.Now.ToString("yyyy.MM.dd-HH:mm:ss") + " > " + i1.ToString("f2") + " \t" + i2.ToString("f2") + " \t" + i3.ToString("f2") + " \t" + p1.ToString("f2") + " \t" + p2.ToString("f2") + " \t" + bits + Environment.NewLine); } else { NamedLog("Произошло внутреннее исключение при обмене: " + sendResult.ChannelException); } } catch (Exception ex) { NamedLog("После отправки команды, при обработке ответа возникло исключение: " + ex); } finally { NamedLog("В скаду через шлюз будет отправлен результат: " + result.ToText()); callback(null, result); } }, IoPriority.High); } } else if ((result[3] & 0x06) == 0x06) { try { NamedLog("Запрос получасовых данных для " + _bumizControllerInfo.Name); var minutes = result[3] == 0x06 ? 0 : 30; var hour = result[4]; var day = result[5]; var month = result[6]; var year = 2000 + result[7]; var certainTime = new DateTime(year, month, day, hour, minutes, 0); if (certainTime > DateTime.Now) { NamedLog("Запрос за время, которое в системе еще не достигнуто! " + certainTime.ToSimpleString()); } NamedLog("Запрос к хранилищу импульсов за время " + certainTime.ToSimpleString()); var storedImpulses = _pcStorageHolder.Storage.GetAtomicData(Name, certainTime); if (storedImpulses == null) { throw new Exception("Не удалось получить информацию по импульсам за время" + certainTime.ToSimpleString() + " для объекта " + Name); } var storedIntegral = _pcStorageHolder.Storage.GetIntegralData(Name, certainTime); if (storedIntegral == null) { throw new Exception("Не удалось получить суммарную информацию по импульсам до времени " + certainTime.ToSimpleString() + " для объекта " + Name); } NamedLog("Запрос к хранилищу выполнен"); NamedLog("Получены следующие суммарные данные из хранилища: " + storedIntegral); var exps = new List <Expression> { new Expression(_bumizControllerInfo.Pulse1Expression), new Expression(_bumizControllerInfo.Pulse2Expression), new Expression(_bumizControllerInfo.Pulse3Expression) }; foreach (var expression in exps) { expression.Parameters.Add("p1", storedIntegral.ImpulsesCount1); expression.Parameters.Add("p2", storedIntegral.ImpulsesCount2); expression.Parameters.Add("p3", storedIntegral.ImpulsesCount3); } var rp1 = (float)(double)exps[0].Evaluate(); var rp2 = (float)(double)exps[1].Evaluate(); var rp3 = (float)(double)exps[2].Evaluate(); result.AddRange(rp1.ToBytes()); result.AddRange(rp2.ToBytes()); result.AddRange(rp3.ToBytes()); NamedLog("В результате применения к импульсам расчетных формул получены значения расходов: (p1, p2, p3): " + rp1.ToString("f2") + " " + rp2.ToString("f2") + " " + rp3.ToString("f2")); result.AddRange(BitConverter.GetBytes(storedIntegral.RecordsCount)); result.AddRange(BitConverter.GetBytes(storedIntegral.CorrectRecordsCount)); result.AddRange(BitConverter.GetBytes(storedIntegral.IncorrectRecordsCount)); result.AddRange(BitConverter.GetBytes(storedIntegral.SupposedRecordsCount)); NamedLog("Всего записей в хранилище: " + storedIntegral.RecordsCount); result.Add((byte)storedImpulses.Value.PulseCount1); result.Add((byte)storedImpulses.Value.PulseCount2); result.Add((byte)storedImpulses.Value.PulseCount3); result.Add((byte)storedImpulses.Value.Status); result.Add((byte)((storedImpulses.Value.StatusX & 0xF0) >> 8)); result.Add((byte)(storedImpulses.Value.StatusX & 0x0F)); result.Add((byte)(storedImpulses.Value.IsRecordCorrect ? 0x01 : 0x00)); var channel = result[0]; var number = result[2]; result.Add(number); result.Add(0); result.Add(channel); result.Add(0); NamedLog("Упаковка получасовых данных завершена"); } catch (Exception ex) { NamedLog("Будет отправлена пустая посылка, т.к. произошло исключение во время составления ответа на получас: " + ex); } finally { callback(null, result); } } else { NamedLog("Такая шестерка не поддерживается, будет отправлена пустая посылка"); callback(null, result); } } else { throw new Exception("Такая команда не поддерживается объектом БУМИЗ"); } }