ZmqManager.cs 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392
  1. using GSG.NET.Concurrent;
  2. using GSG.NET.Logging;
  3. using GSG.NET.ObjectBase;
  4. using NetMQ;
  5. using NetMQ.Monitoring;
  6. using NetMQ.Sockets;
  7. using OHV.Common.Model;
  8. using OHV.Common.Shareds;
  9. using StackExchange.Redis.Extensions.Core.Extensions;
  10. using System;
  11. using System.Collections.Generic;
  12. using System.Diagnostics;
  13. using System.Linq;
  14. using System.Text;
  15. using System.Threading.Tasks;
  16. namespace VehicleControlSystem.ControlLayer.MQ
  17. {
  18. public class ZmqManager : ControlObjectBase, IDisposable
  19. {
  20. Logger logger = Logger.GetLogger();
  21. SubscriberSocket sub = null;
  22. RequestSocket req = null;
  23. ResponseSocket rep = null;
  24. NetMQPoller poller = null;
  25. NetMQMonitor monitor = null;
  26. ThreadCancel threadCancel = new ThreadCancel();
  27. private bool isReqConnected;
  28. public bool IsReqConnected
  29. {
  30. get { return isReqConnected; }
  31. set { isReqConnected = value; }
  32. }
  33. #region Properties
  34. private eSteeringState requestSteering;
  35. public eSteeringState RequestSteering
  36. {
  37. get { return requestSteering; }
  38. set { SetField( ref this.requestSteering, value ); }
  39. }
  40. private bool isDriveMoving;
  41. public bool IsDriveMoving
  42. {
  43. get { return isDriveMoving; }
  44. set { SetField( ref isDriveMoving, value ); }
  45. }
  46. private eRoadForm currentLoadForm;
  47. public eRoadForm CurrentLoadForm
  48. {
  49. get { return currentLoadForm; }
  50. set { SetField( ref currentLoadForm, value ); }
  51. }
  52. private eOperatationMode operatationMode;
  53. public eOperatationMode OperationMode
  54. {
  55. get { return operatationMode; }
  56. set { operatationMode = value; }
  57. }
  58. #endregion
  59. public ZmqManager()
  60. {
  61. NetMQ.NetMQConfig.Cleanup();
  62. }
  63. public void Init()
  64. {
  65. rep = new ResponseSocket();
  66. rep.Bind( "tcp://127.0.0.1:5568" );
  67. rep.ReceiveReady += Rep_ReceiveReady;
  68. sub = new SubscriberSocket();
  69. sub.Connect( "tcp://127.0.0.1:5565" );
  70. sub.Connect( "tcp://127.0.0.1:5566" );
  71. sub.Subscribe( "" ); //All
  72. sub.ReceiveReady += Sub_ReceiveReady;
  73. req = new RequestSocket();
  74. this.monitor = new NetMQMonitor( req, "inproc://rep.inproc", SocketEvents.Disconnected | SocketEvents.Connected );
  75. this.monitor.Connected += ( s, a ) => { this.IsReqConnected = true; };
  76. this.monitor.Disconnected += ( s, a ) => { this.IsReqConnected = false; };
  77. this.monitor.StartAsync();
  78. req.Connect( "tcp://127.0.0.1:5567" );
  79. this.poller = new NetMQPoller { this.sub, this.rep };
  80. this.poller.RunAsync();
  81. }
  82. public void Dispose()
  83. {
  84. this.threadCancel.Cancel();
  85. this.monitor.Stop();
  86. this.monitor.Dispose();
  87. this.poller.Stop();
  88. this.poller.Dispose();
  89. this.sub.Dispose();
  90. this.req.Dispose();
  91. }
  92. private void Rep_ReceiveReady( object sender, NetMQSocketEventArgs e )
  93. {
  94. var ret = e.Socket.ReceiveMultipartStrings();
  95. logger.D( $"[rep] - {ret}" );
  96. if ( ret[0].Equals( "setm" ) )
  97. {
  98. var v = ret[1].Split( '/' );
  99. switch ( v[0] )
  100. {
  101. case "3050":
  102. {
  103. switch ( v[1] )
  104. {
  105. case "1":
  106. this.RequestSteering = eSteeringState.Left;
  107. break;
  108. case "-1":
  109. this.RequestSteering = eSteeringState.Right;
  110. break;
  111. default:
  112. this.RequestSteering = eSteeringState.None;
  113. break;
  114. }
  115. }
  116. break;
  117. case "111":
  118. {
  119. if ( v[1].Equals( "1" ) )
  120. OperationMode = eOperatationMode.AutoMode;
  121. else
  122. OperationMode = eOperatationMode.ManualMode;
  123. }
  124. break;
  125. case "113":
  126. {
  127. }
  128. break;
  129. default:
  130. break;
  131. }
  132. rep.SendMoreFrame( "setm" ).SendFrame( $"ok/{v[0]}" );
  133. }
  134. }
  135. private void Sub_ReceiveReady( object sender, NetMQ.NetMQSocketEventArgs e )
  136. {
  137. var ret = e.Socket.ReceiveMultipartStrings();
  138. logger.I( ret );
  139. switch ( ret[0] )
  140. {
  141. case "3050": //TargetSteering
  142. {
  143. //switch ( ret[1] )
  144. //{
  145. // case "1":
  146. // this.RequestSteering = eSteeringState.Left;
  147. // break;
  148. // case "-1":
  149. // this.RequestSteering = eSteeringState.Right;
  150. // break;
  151. // default:
  152. // this.RequestSteering = eSteeringState.None;
  153. // break;
  154. //}
  155. }
  156. break;
  157. case "111": //0=StartUp, 1=DeviceOpened, 2=DiviceOpenFailed, 3=ManualOP, 4=AutomaticOp, 5=DeviceCloseed, 6=Finished
  158. break;
  159. case "3010": //진행중의 길의 모양, 0이면 정지 상태
  160. {
  161. var v = ret[1].Split( ';' );
  162. switch ( v[0] )
  163. {
  164. case "1":
  165. //this.RequestSteering = eSteeringState.Left;
  166. break;
  167. case "-1":
  168. //this.RequestSteering = eSteeringState.Right;
  169. break;
  170. default:
  171. //this.RequestSteering = eSteeringState.None;
  172. break;
  173. }
  174. }
  175. break;
  176. default:
  177. break;
  178. }
  179. }
  180. void Th_SubPoller()
  181. {
  182. while ( !this.threadCancel.Canceled )
  183. {
  184. LockUtils.Wait( 1000 );
  185. //this.pub.SendMoreFrame( "1000" ).SendFrame( "Test" );
  186. LockUtils.Wait( 100 );
  187. NetMQMessage msg = new NetMQMessage();
  188. if ( this.sub.TryReceiveMultipartMessage( TimeSpan.FromSeconds( 1 ), ref msg ) )
  189. {
  190. var m = msg;
  191. }
  192. }
  193. }
  194. bool Request( string topic, string value, out string response )
  195. {
  196. List<string> repll = new List<string>();
  197. response = string.Empty;
  198. if ( !this.IsReqConnected )
  199. return false;
  200. if ( !this.req.HasIn )
  201. this.req.SendMoreFrame( topic ).SendFrame( value );
  202. if ( this.req.TryReceiveMultipartStrings( TimeSpan.FromSeconds( 5 ), ref repll ) )
  203. return true;
  204. else
  205. return false;
  206. }
  207. bool SetRequest(string index, string value )
  208. {
  209. List<string> repll = new List<string>();
  210. if ( !this.IsReqConnected )
  211. return false;
  212. if ( !this.req.HasIn )
  213. this.req.SendMoreFrame( "setm" ).SendFrame( index + "/" + value );
  214. if ( !this.req.TryReceiveMultipartStrings( TimeSpan.FromSeconds( 5 ), ref repll ) )
  215. return false;
  216. return true;
  217. }
  218. bool GetRequst( string index, out List<string> vll)
  219. {
  220. vll = new List<string>();
  221. if ( !this.IsReqConnected )
  222. return false;
  223. if ( !this.req.HasIn )
  224. this.req.SendMoreFrame( "getm" ).SendFrame( index );
  225. List<string> repll = new List<string>();
  226. if ( this.req.TryReceiveMultipartStrings( TimeSpan.FromSeconds( 5 ), ref repll ) )
  227. {
  228. repll.RemoveAt( 0 );
  229. var ret = repll[0].Split( '/' );
  230. repll.Clear();
  231. ret.ForEach( s =>
  232. {
  233. if ( s.Equals( "ok" ) || s.Equals( "nok" ) || s.Equals( index ) )
  234. repll.Add( s );
  235. } );
  236. vll = repll;
  237. return true;
  238. }
  239. else
  240. return false;
  241. }
  242. #region Get Request Method
  243. public eOperatationMode GetOperationMode()
  244. {
  245. List<string> rll;
  246. this.GetRequst( "111", out rll );
  247. if ( rll[0].Equals( "1" ) )
  248. return eOperatationMode.AutoMode;
  249. else
  250. return eOperatationMode.ManualMode;
  251. }
  252. public int CurrentPointNo()
  253. {
  254. List<string> rll;
  255. this.GetRequst( "111", out rll );
  256. int ret = 0;
  257. int.TryParse( rll[1], out ret );
  258. return ret;
  259. }
  260. #endregion
  261. #region Set Request Method
  262. internal void SetObstruction( eObstacleState state )
  263. {
  264. string outStr = string.Empty;
  265. switch ( state )
  266. {
  267. case eObstacleState.Normal:
  268. this.Request( "setm", "5001/0", out outStr );
  269. break;
  270. case eObstacleState.Abnormal:
  271. this.Request( "setm", "5001/3", out outStr );
  272. break;
  273. case eObstacleState.Blocked:
  274. this.Request( "setm", "5001/2", out outStr );
  275. break;
  276. case eObstacleState.Decelerate:
  277. this.Request( "setm", "5001/1", out outStr );
  278. break;
  279. default:
  280. break;
  281. }
  282. }
  283. internal void SetOperationSate(eOperatationMode mode)
  284. {
  285. string outStr = string.Empty;
  286. if ( mode == eOperatationMode.AutoMode )
  287. this.Request( "set", "112/1", out outStr );
  288. else if ( mode == eOperatationMode.ManualMode )
  289. this.Request( "set", "112/0", out outStr );
  290. else
  291. { }
  292. }
  293. internal void SetMCState(bool isOn )
  294. {
  295. string outStr = string.Empty;
  296. if ( isOn )
  297. this.Request( "setm", "5000/1", out outStr );
  298. else
  299. this.Request( "setm", "5000/0", out outStr );
  300. }
  301. internal void SetCurrentSteeringState( eSteeringState state )
  302. {
  303. string outStr = string.Empty;
  304. bool ret = false;
  305. switch ( state )
  306. {
  307. case eSteeringState.None:
  308. ret = this.Request( "set", "3060/0/0", out outStr );
  309. break;
  310. case eSteeringState.Left:
  311. ret = this.Request( "set", "3060/0/1", out outStr );
  312. break;
  313. case eSteeringState.Right:
  314. ret = this.Request( "set", "3060/0/-1", out outStr );
  315. break;
  316. default:
  317. break;
  318. }
  319. }
  320. #endregion
  321. }
  322. }