ScheduleMaintenanceDataManager.cs 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Data;
  4. using Aitex.Core.RT.DBCore;
  5. using Aitex.Core.RT.Event;
  6. using Aitex.Core.RT.Log;
  7. using Aitex.Core.RT.OperationCenter;
  8. using Aitex.Core.Util;
  9. using MECF.Framework.Common.DBCore;
  10. namespace MECF.Framework.Common.DataCenter
  11. {
  12. public class ScheduleMaintenanceData
  13. {
  14. public ScheduleMaintenanceDataItem DataItem { get; private set; }
  15. public ScheduleMaintenanceData(string item, string display, string unit, float startValue, float limitValue, string maintenanceProcessing, string path, string additionInformationName = "", string additionInformationDisplay = "")
  16. {
  17. ScheduleMaintenanceDataManager.Instance.Subscribe(item, display, unit, startValue, limitValue, maintenanceProcessing, path, additionInformationName, additionInformationDisplay);
  18. DataItem = ScheduleMaintenanceDataManager.Instance.GetItem(item);
  19. }
  20. public float SetLimitValue(float value)
  21. {
  22. return ScheduleMaintenanceDataManager.Instance.SetLimitValue(DataItem.Item, value);
  23. }
  24. public string SetMaintenanceProcessing(string value)
  25. {
  26. return ScheduleMaintenanceDataManager.Instance.SetMaintenanceProcessing(DataItem.Item, value);
  27. }
  28. public void SetValue(float value)
  29. {
  30. ScheduleMaintenanceDataManager.Instance.SetValue(DataItem.Item, value);
  31. }
  32. public float GetValue()
  33. {
  34. return ScheduleMaintenanceDataManager.Instance.GetValue(DataItem.Item);
  35. }
  36. public float Increase(float additionValue = 1)
  37. {
  38. return ScheduleMaintenanceDataManager.Instance.Increase(DataItem.Item, additionValue);
  39. }
  40. }
  41. public class ScheduleMaintenanceDataItem
  42. {
  43. public string Unit { get; set; }
  44. public string Item { get; set; }
  45. public float CurrentValue { get; set; }
  46. public float StartValue { get; set; }
  47. public float LimitValue { get; set; }
  48. public string MaintenanceProcessing { get; set; }
  49. public string Display { get; set; }
  50. public string Path { get; set; }
  51. public string AdditionInformationName { get; set; }
  52. public string AdditionInformationDisplay { get; set; }
  53. }
  54. public class ScheduleMaintenanceDataManager : Singleton<ScheduleMaintenanceDataManager>
  55. {
  56. private Dictionary<string, ScheduleMaintenanceDataItem> _items = new Dictionary<string, ScheduleMaintenanceDataItem>();
  57. public Dictionary<string, ScheduleMaintenanceDataItem> Item { get => _items; }
  58. private object _locker = new object();
  59. public ScheduleMaintenanceDataManager()
  60. {
  61. }
  62. public void Initialize()
  63. {
  64. try
  65. {
  66. OP.Subscribe("System.ScheduleMaintenance.SetCurrentValue", (method, args) =>
  67. {
  68. float.TryParse(args[1].ToString(), out float value);
  69. SetValue((string)args[0], value);
  70. return true;
  71. });
  72. OP.Subscribe("System.ScheduleMaintenance.SetMaintenanceName", (method, args) =>
  73. {
  74. SetMaintenanceName((string)args[0], args[1].ToString());
  75. return true;
  76. });
  77. OP.Subscribe("System.ScheduleMaintenance.SetMaintenanceProcessing", (method, args) =>
  78. {
  79. SetMaintenanceProcessing((string)args[0], args[1].ToString());
  80. return true;
  81. });
  82. OP.Subscribe("System.ScheduleMaintenance.SetLimitValue", (method, args) =>
  83. {
  84. float.TryParse(args[1].ToString(), out float value);
  85. SetLimitValue((string)args[0], value);
  86. return true;
  87. });
  88. OP.Subscribe("System.ScheduleMaintenance.SetStartValue", (method, args) =>
  89. {
  90. float.TryParse(args[1].ToString(), out float value);
  91. SetStartValue((string)args[0], value);
  92. return true;
  93. });
  94. OP.Subscribe("System.ScheduleMaintenance.SetAdditionInformationDisplayName", (method, args) =>
  95. {
  96. SetMaintenanceName((string)args[0], args[1].ToString());
  97. return true;
  98. });
  99. DataTable dt = DataQuery.Query("select * from \"schedule_maintenance\"");
  100. for (int i = 0; i < dt.Rows.Count; i++)
  101. {
  102. ScheduleMaintenanceDataItem item = new ScheduleMaintenanceDataItem();
  103. item.Item = dt.Rows[i]["maintenance_item"].ToString();
  104. item.Display = dt.Rows[i]["maintenance_display"].ToString();
  105. item.Unit = dt.Rows[i]["unit"].ToString();
  106. item.MaintenanceProcessing = dt.Rows[i]["maintenance_processing"].ToString();
  107. item.Path = dt.Rows[i]["path"].ToString();
  108. item.AdditionInformationName = dt.Rows[i]["addition_information_name"].ToString();
  109. item.AdditionInformationDisplay = dt.Rows[i]["addition_information_display"].ToString();
  110. if (float.TryParse(dt.Rows[i]["current_value"].ToString(), out float value))
  111. item.CurrentValue = value;
  112. if (float.TryParse(dt.Rows[i]["scheduling_start_value"].ToString(), out value))
  113. item.StartValue = value;
  114. if (float.TryParse(dt.Rows[i]["maintenance_limit_value"].ToString(), out value))
  115. item.LimitValue = value;
  116. _items[item.Item] = item;
  117. }
  118. }
  119. catch (Exception ex)
  120. {
  121. LOG.Error("init stats data manager failed", ex);
  122. }
  123. }
  124. public string SetMaintenanceName(string name, string display)
  125. {
  126. lock (_locker)
  127. {
  128. if (!_items.ContainsKey(name))
  129. {
  130. LOG.Error($"Can not set {name} maintenanceName value, not defined item");
  131. return "";
  132. }
  133. string preValue = _items[name].Display;
  134. _items[name].Display = display;
  135. string sql = string.Format(
  136. "UPDATE \"schedule_maintenance\" SET \"maintenance_processing\"='{0}'WHERE \"maintenance_item\"='{1}';", display,
  137. name);
  138. DB.Insert(sql);
  139. EV.PostInfoLog("System", $"{name} schedule maintenance maintenanceName value changed from {preValue} to {display}");
  140. return display;
  141. }
  142. }
  143. public string SetAdditionInformationDisplayName(string name, string display)
  144. {
  145. lock (_locker)
  146. {
  147. if (!_items.ContainsKey(name))
  148. {
  149. LOG.Error($"Can not set {name} AdditionInformationDispla value, not defined item");
  150. return "";
  151. }
  152. string preValue = _items[name].AdditionInformationDisplay;
  153. _items[name].AdditionInformationDisplay = display;
  154. string sql = string.Format(
  155. "UPDATE \"schedule_maintenance\" SET \"addition_information_display\"='{0}'WHERE \"maintenance_item\"='{1}';", display,
  156. name);
  157. DB.Insert(sql);
  158. EV.PostInfoLog("System", $"{name} schedule maintenance AdditionInformationDisplay value changed from {preValue} to {display}");
  159. return display;
  160. }
  161. }
  162. public string SetMaintenanceProcessing(string name, string maintenanceProcessing)
  163. {
  164. lock (_locker)
  165. {
  166. if (!_items.ContainsKey(name))
  167. {
  168. LOG.Error($"Can not set {name} maintenanceProcessing value, not defined item");
  169. return "";
  170. }
  171. string preValue = _items[name].MaintenanceProcessing;
  172. _items[name].MaintenanceProcessing = maintenanceProcessing;
  173. string sql = string.Format(
  174. "UPDATE \"schedule_maintenance\" SET \"maintenance_processing\"='{0}'WHERE \"maintenance_item\"='{1}';", maintenanceProcessing,
  175. name);
  176. DB.Insert(sql);
  177. EV.PostInfoLog("System", $"{name} schedule maintenance MaintenanceProcessing value changed from {preValue} to {maintenanceProcessing}");
  178. return maintenanceProcessing;
  179. }
  180. }
  181. public float SetLimitValue(string name, float value)
  182. {
  183. lock (_locker)
  184. {
  185. if (!_items.ContainsKey(name))
  186. {
  187. LOG.Error($"Can not set {name} limit value, not defined item");
  188. return -1;
  189. }
  190. float preValue = _items[name].LimitValue;
  191. _items[name].LimitValue = value;
  192. string sql = string.Format(
  193. "UPDATE \"schedule_maintenance\" SET \"maintenance_limit_value\"='{0}'WHERE \"maintenance_item\"='{1}';", _items[name].LimitValue,
  194. name);
  195. DB.Insert(sql);
  196. EV.PostInfoLog("System", $"{name} schedule maintenance limit value changed from {preValue} to {value}");
  197. return preValue;
  198. }
  199. }
  200. public void Terminate()
  201. {
  202. }
  203. public void Subscribe(string item, string display, string unit, float startValue, float limitValue, string maintenanceProcessing, string path, string additionInformationName, string additionInformationDisplay)
  204. {
  205. lock (_locker)
  206. {
  207. if (!_items.ContainsKey(item))
  208. {
  209. _items[item] = new ScheduleMaintenanceDataItem()
  210. { Display = display, Item = item };
  211. string executeInsert = string.Format(
  212. @"Insert into ""schedule_maintenance""(""maintenance_item"",
  213. ""maintenance_display"",
  214. ""scheduling_start_value"",
  215. ""maintenance_limit_value"",
  216. ""maintenance_processing"",
  217. ""unit"",
  218. ""path"",
  219. ""addition_information_name"",
  220. ""addition_information_display""
  221. ) values('{0}','{1}','{2}','{3}','{4}','{5}','{6}','{7}','{8}')",
  222. item, display, startValue, limitValue, maintenanceProcessing, unit, path, additionInformationName, additionInformationDisplay);
  223. DB.Insert(executeInsert);
  224. }
  225. }
  226. }
  227. public void SetValue(string name, float value)
  228. {
  229. lock (_locker)
  230. {
  231. if (!_items.ContainsKey(name))
  232. {
  233. LOG.Error($"Can not set {name} value, not defined item");
  234. return;
  235. }
  236. _items[name].CurrentValue = value;
  237. string sql = string.Format(
  238. "UPDATE \"schedule_maintenance\" SET \"current_value\"='{0}' WHERE \"maintenance_item\"='{1}';",
  239. _items[name].CurrentValue,
  240. name);
  241. DB.Insert(sql);
  242. }
  243. }
  244. public void SetStartValue(string name, float value)
  245. {
  246. lock (_locker)
  247. {
  248. if (!_items.ContainsKey(name))
  249. {
  250. LOG.Error($"Can not set {name} scheduling_start_value, not defined item");
  251. return;
  252. }
  253. _items[name].StartValue = value;
  254. string sql = string.Format(
  255. "UPDATE \"schedule_maintenance\" SET \"scheduling_start_value\"='{0}' WHERE \"maintenance_item\"='{1}';",
  256. _items[name].StartValue,
  257. name);
  258. DB.Insert(sql);
  259. }
  260. }
  261. public float GetValue(string name)
  262. {
  263. lock (_locker)
  264. {
  265. if (_items.ContainsKey(name))
  266. {
  267. return _items[name].CurrentValue;
  268. }
  269. }
  270. LOG.Error($"Can not get {name} value, not defined item");
  271. return 0;
  272. }
  273. public ScheduleMaintenanceDataItem GetItem(string name)
  274. {
  275. lock (_locker)
  276. {
  277. if (_items.ContainsKey(name))
  278. {
  279. return _items[name];
  280. }
  281. }
  282. LOG.Error($"Can not get {name} value, not defined item");
  283. return null;
  284. }
  285. public bool CheckHasItem(string name)
  286. {
  287. if (_items.ContainsKey(name))
  288. return true;
  289. else
  290. return false;
  291. }
  292. public float Increase(string name, float additionValue = 1)
  293. {
  294. lock (_locker)
  295. {
  296. if (!_items.ContainsKey(name))
  297. {
  298. LOG.Error($"Can not increase {name} value, not defined item");
  299. return -1;
  300. }
  301. _items[name].CurrentValue += additionValue;
  302. string sql = string.Format(
  303. "UPDATE \"schedule_maintenance\" SET \"current_value\"='{0}' WHERE \"maintenance_item\"='{1}';",
  304. _items[name].CurrentValue,
  305. name);
  306. DB.Insert(sql);
  307. return _items[name].CurrentValue;
  308. }
  309. }
  310. }
  311. }