mod_agentip.cpp 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221
  1. #include "stdafx.h"
  2. #include "SpBase.h"
  3. #include "sysvar.h"
  4. #include "mod_assistantchannel/AssistantChannel_client_g.h"
  5. using namespace AssistantChannel;
  6. #include "mod_assistantchannel/chan_protocol.h"
  7. #define LOG_EVT_SELFCHECK_ASSISTANTCHANNEL_IDLE 0x50500001 //协助通道重启
  8. class CAgentInterpreterEntity;
  9. class CamSwitchChannelClient : public ChannelService_ClientBase
  10. {
  11. public:
  12. CamSwitchChannelClient(CAgentInterpreterEntity *pEntity);
  13. virtual void OnMessage(ErrorCodeEnum Error, ChannelService_State_Info &Msg, CSmartPointer<IReleasable> pData);
  14. virtual void OnMessage(ErrorCodeEnum Error, ChannelService_Packet_Info &Msg, CSmartPointer<IReleasable> pData);
  15. };
  16. // code:0x906
  17. class CAgentInterpreterEntity : public CEntityBase,public ILogListener
  18. {
  19. public:
  20. CAgentInterpreterEntity() : m_iCurrentOp(ACM_CAMSWITCH_AUTO) {}
  21. virtual ~CAgentInterpreterEntity() {}
  22. virtual const char *GetEntityName() const { return "AgentInterpreter"; }
  23. virtual void OnPreStart(CAutoArray<CSimpleStringA> strArgs,CSmartPointer<ITransactionContext> pTransactionContext)
  24. {
  25. ErrorCodeEnum Error = __OnStart(Error_Succeed);
  26. pTransactionContext->SendAnswer(Error);
  27. }
  28. virtual void OnPreClose(EntityCloseCauseEnum eCloseCause,CSmartPointer<ITransactionContext> pTransactionContext)
  29. {
  30. ErrorCodeEnum Error = __OnClose(Error_Succeed);
  31. pTransactionContext->SendAnswer(Error);
  32. }
  33. ErrorCodeEnum __OnStart(ErrorCodeEnum preOperationError)
  34. {
  35. ErrorCodeEnum Error;
  36. CSmartPointer<IEntityFunction> pFunc = GetFunction();
  37. int i = 0;
  38. m_arrListener.Init(1);
  39. pFunc->SubscribeLog(m_arrListener[i++], this, Log_Event, Severity_None, Error_IgnoreAll, LOG_EVT_SELFCHECK_ASSISTANTCHANNEL_IDLE,NULL,false);
  40. //m_iCurrentOp = ACM_CAMSWITCH_AUTO;
  41. ChangeSysvar(ACM_CAMSWITCH_AUTO); // change to auto state anyway when started
  42. m_pCamSwitchChannel = new CamSwitchChannelClient(this);
  43. Error = m_pCamSwitchChannel->Connect();
  44. if (Error != Error_Succeed) {
  45. m_pCamSwitchChannel->SafeDelete();
  46. return Error;
  47. }
  48. {
  49. ChannelService_BeginState_Sub Sub;
  50. Error = m_pCamSwitchChannel->BeginState(Sub);
  51. if (Error != Error_Succeed) {
  52. LOG_TRACE("BeginState biz channel failed!");
  53. m_pCamSwitchChannel->GetFunction()->CloseSession();
  54. m_pCamSwitchChannel = NULL;
  55. }
  56. }
  57. {
  58. ChannelService_BeginRecv_Sub Sub;
  59. Sub.type = ACM_TYPE_CAMSWITCH;
  60. Error = m_pCamSwitchChannel->BeginRecv(Sub);
  61. if (Error != Error_Succeed) {
  62. m_pCamSwitchChannel->GetFunction()->CloseSession();
  63. m_pCamSwitchChannel = NULL;
  64. return Error;
  65. }
  66. }
  67. return Error_Succeed;
  68. }
  69. virtual void OnLog(const CAutoArray<CUUID> &SubIDs, const CUUID nLogID,const LogTypeEnum eLogType, const SeverityLevelEnum eLevel,
  70. const DWORD dwSysError,const DWORD dwUserCode,const DWORD dwEntityInstanceID, const WORD wEntityDevelID,
  71. const CAutoArray<DWORD> &Param, const char *pszEntityName, const char *pszModuleName,const char *pszMessage)
  72. {
  73. if (dwUserCode == LOG_EVT_SELFCHECK_ASSISTANTCHANNEL_IDLE)
  74. {
  75. Dbg("recv LOG_EVT_SELFCHECK_ASSISTANTCHANNEL_IDLE");
  76. if (m_pCamSwitchChannel!=NULL)
  77. {
  78. m_pCamSwitchChannel->GetFunction()->CloseSession();
  79. m_pCamSwitchChannel = NULL;
  80. Dbg("Close AssistChannel Session ");
  81. }
  82. if (m_pCamSwitchChannel == NULL)
  83. {
  84. Dbg("ReConnection AssistChannel Session");
  85. m_pCamSwitchChannel = new CamSwitchChannelClient(this);
  86. ErrorCodeEnum Error = m_pCamSwitchChannel->Connect();
  87. if (Error != Error_Succeed)
  88. {
  89. m_pCamSwitchChannel->SafeDelete();
  90. Dbg("AssistChannelClient connect fail!");
  91. }
  92. if (Error == Error_Succeed)
  93. {
  94. ChannelService_BeginRecv_Sub Sub;
  95. Sub.type = ACM_TYPE_CAMSWITCH;
  96. Error = m_pCamSwitchChannel->BeginRecv(Sub);
  97. if (Error != Error_Succeed)
  98. {
  99. m_pCamSwitchChannel->GetFunction()->CloseSession();
  100. m_pCamSwitchChannel = NULL;
  101. }
  102. }
  103. if (Error == Error_Succeed)
  104. {
  105. ChannelService_BeginState_Sub Sub;
  106. Error = m_pCamSwitchChannel->BeginState(Sub);
  107. if (Error != Error_Succeed)
  108. {
  109. LOG_TRACE("BeginState biz channel failed!");
  110. m_pCamSwitchChannel->GetFunction()->CloseSession();
  111. m_pCamSwitchChannel = NULL;
  112. }
  113. }
  114. }
  115. }
  116. }
  117. ErrorCodeEnum __OnClose(ErrorCodeEnum preOperationError)
  118. {
  119. CSmartPointer<IEntityFunction> spFunction = GetFunction();
  120. for (int i = 0; i < m_arrListener.GetCount(); ++i)
  121. {
  122. spFunction->UnsubscribeLog(m_arrListener[i]);
  123. }
  124. if (m_pCamSwitchChannel) {
  125. m_pCamSwitchChannel->GetFunction()->CloseSession();
  126. m_pCamSwitchChannel = NULL;
  127. }
  128. return Error_Succeed;
  129. }
  130. ErrorCodeEnum SwitchCamera(int op)
  131. {
  132. if (m_iCurrentOp != op) {
  133. ChangeSysvar(op);
  134. m_iCurrentOp = op;
  135. }
  136. return Error_Succeed;
  137. }
  138. void ChangeSessionState(int on)
  139. {
  140. if (!on) {
  141. if (m_iCurrentOp != ACM_CAMSWITCH_AUTO) {
  142. ChangeSysvar(ACM_CAMSWITCH_AUTO);
  143. m_iCurrentOp = ACM_CAMSWITCH_AUTO;
  144. }
  145. }
  146. }
  147. private:
  148. ErrorCodeEnum ChangeSysvar(int op)
  149. {
  150. if (op == ACM_CAMSWITCH_AUTO) {
  151. Dbg("agent --> cam switch to auto");
  152. GetFunction()->SetSysVar(SYSVAR_AGENTCAMERASWITCH, AGENTCAMERASWITCH_AUTO);
  153. } else if (op == ACM_CAMSWITCH_ENV) {
  154. Dbg("agent --> cam switch to env");
  155. GetFunction()->SetSysVar(SYSVAR_AGENTCAMERASWITCH, AGENTCAMERASWITCH_ENV);
  156. } else if (op == ACM_CAMSWITCH_OPT) {
  157. Dbg("agent --> cam switch to opt");
  158. GetFunction()->SetSysVar(SYSVAR_AGENTCAMERASWITCH, AGENTCAMERASWITCH_OPT);
  159. } else {
  160. _ASSERT(0);
  161. }
  162. return Error_Succeed;
  163. }
  164. private:
  165. CamSwitchChannelClient *m_pCamSwitchChannel;
  166. int m_iCurrentOp;
  167. CAutoArray<CUUID> m_arrListener;
  168. };
  169. CamSwitchChannelClient::CamSwitchChannelClient( CAgentInterpreterEntity *pEntity ) : ChannelService_ClientBase(pEntity)
  170. {
  171. }
  172. void CamSwitchChannelClient::OnMessage(ErrorCodeEnum Error, ChannelService_State_Info &Msg, CSmartPointer<IReleasable> pData)
  173. {
  174. if (Error == Error_Succeed) {
  175. CAgentInterpreterEntity *pEntity = static_cast<CAgentInterpreterEntity*>(m_pEntityBase);
  176. if (Msg.state == eChannelState_Idle) {
  177. pEntity->ChangeSessionState(0);
  178. } else if (Msg.state == eChannelState_Connected) {
  179. pEntity->ChangeSessionState(1);
  180. }
  181. }
  182. }
  183. void CamSwitchChannelClient::OnMessage( ErrorCodeEnum Error, ChannelService_Packet_Info &Msg, CSmartPointer<IReleasable> pData )
  184. {
  185. LOG_FUNCTION();
  186. if (Error == Error_Succeed) {
  187. CAgentInterpreterEntity *pEntity = static_cast<CAgentInterpreterEntity*>(m_pEntityBase);
  188. pEntity->SwitchCamera(Msg.sub_type);
  189. }
  190. }
  191. SP_BEGIN_ENTITY_MAP()
  192. SP_ENTITY(CAgentInterpreterEntity)
  193. SP_END_ENTITY_MAP()