public bool Execute(FFTgtExecutionContext context, IFreeformEntity_MsgTgt target) { using (ILogMethod method = Log.LogMethod(this.DYN_MODULE_NAME, "Execute")) { bool result = default(bool); try { result = this.OnExecuteInternal(context, target); } catch (Exception ex) { method.Exception(ex); } return result; } }
public bool Execute(IFreeformEntity_Msg request) { using (ILogMethod method = Log.LogMethod(this.DYN_MODULE_NAME, "ProcessMessage(G2H)")) { bool result = default(bool); string ipAddress = string.Empty; try { using (FFTgtExecutionContext context = new FFTgtExecutionContext(request)) { Stack <IFreeformEntity> st = new Stack <IFreeformEntity>(); request.CopyTo(st); // push all the grandchildren into stack and process again while (st.Count != 0) { IFreeformEntity_MsgTgt target = st.Pop() as IFreeformEntity_MsgTgt; if (target == null || target.IsLeafNode) { continue; } _requestResponseMappings.Persist(request, target); string targetKey = CreateSessionTargetKey((int)request.SessionID, target.TypeKey); if (_targetHandlers.ContainsKey(targetKey)) { _HandlerInfo info = _targetHandlers[targetKey]; context.HandlerAttribute = info.HandlerAttribute; info.Handler.Execute(context, target); } target.CopyTo(st); } if (request.TransactionID <= 0) { request.TransactionID = FFMsgHandlerFactory.NewTransactionId; } if (request.SessionID != FF_AppId_SessionIds.Internal) { // ok everything processed, now do the external or internal processing if (request.FlowDirection == FF_FlowDirection.G2H) { // add the monitor meters if (context.MonitorMeters.IsValueCreated) { context.MonitorTargets.Value.Add(context.MonitorMeters.Value); } _msgTransmitter.ProcessMessage(request as FFMsg_G2H, context.MonitorTargets.Value); } else if (request.FlowDirection == FF_FlowDirection.H2G) { _msgTransmitter.ProcessMessage(request as FFMsg_H2G); } // process the internal messages if (context.FreeformTargets != null && context.FreeformTargets.Count > 0) { FFMsg_H2G h2gMessage = null; foreach (var freeformEntity in context.FreeformTargets) { if (freeformEntity is IFreeformEntity_Msg) { FFMsgHandlerFactory.Current.Execute(freeformEntity as IFreeformEntity_Msg); } else if (freeformEntity is IFreeformEntity_MsgTgt) { if (h2gMessage == null) { h2gMessage = FreeformEntityFactory.CreateEntity <FFMsg_H2G>(FF_FlowDirection.H2G, new FFCreateEntityRequest_H2G() { IPAddress = request.IpAddress, PollCode = FF_AppId_H2G_PollCodes.FreeformNoResponse, SessionID = request.SessionID, TransactionID = request.TransactionID, }); } h2gMessage.Targets.Add(freeformEntity as IFreeformEntity_MsgTgt); } } if (h2gMessage != null) { FFMsgHandlerFactory.Current.Execute(h2gMessage); } } } } } catch (Exception ex) { method.Exception(ex); } return(result); } }
protected virtual bool OnProcessMessageH2GExternal_SIM(FFTgtExecutionContext context, IFreeformEntity_MsgTgt target) { return true; }