SmartDeviceService.cs 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485
  1. /*******************************************************************************
  2. * Copyright(c) 2014 DongkeSoft All rights reserved. / Confidential
  3. * 类的信息:
  4. * 1.程序名称:SmartDeviceService.cs
  5. * 2.功能描述:接收智能设备请求
  6. * 编辑履历:
  7. * 作者 日期 版本 修改内容
  8. * 陈晓野 2018/10/25 1.00 新建
  9. *******************************************************************************/
  10. using System;
  11. using System.Data;
  12. using System.ServiceModel;
  13. using System.ServiceModel.Activation;
  14. using Dongke.IBOSS.PRD.Basics.BaseResources;
  15. using Dongke.IBOSS.PRD.Basics.Library;
  16. using Dongke.IBOSS.PRD.Service.DataModels;
  17. using Dongke.IBOSS.PRD.Service.PMModuleLogic;
  18. using Dongke.IBOSS.PRD.Service.SmartDeviceService;
  19. using Dongke.IBOSS.PRD.WCF.Contracts;
  20. using Dongke.IBOSS.PRD.WCF.DataModels;
  21. using Newtonsoft.Json.Linq;
  22. namespace Dongke.IBOSS.PRD.WCF.Services
  23. {
  24. /// <summary>
  25. /// 智能设备对接服务
  26. /// </summary>
  27. [AspNetCompatibilityRequirements(RequirementsMode = AspNetCompatibilityRequirementsMode.Allowed)]
  28. [ServiceBehavior(ConfigurationName = "SmartDeviceService",
  29. InstanceContextMode = InstanceContextMode.PerCall,
  30. ConcurrencyMode = ConcurrencyMode.Multiple,
  31. UseSynchronizationContext = false)]
  32. public class SmartDeviceService : ISmartDevice
  33. {
  34. /// <summary>
  35. /// 连接测试
  36. /// </summary>
  37. /// <param name="message"></param>
  38. /// <returns></returns>
  39. public string Test(string message)
  40. {
  41. return message + " is ok";
  42. }
  43. /// <summary>
  44. /// 自动扫描计件
  45. /// </summary>
  46. /// <returns></returns>
  47. public void AddWorkPiece(string accountCode, string userCode, string userPassword,
  48. int procedureID, string barcode)
  49. {
  50. try
  51. {
  52. DataTable userInfo = SmartDeviceLogic.CheckUserCode(accountCode, userCode);
  53. if (userInfo == null)
  54. {
  55. OutputLog.TraceLog(LogPriority.Warning,
  56. this.ToString(),
  57. System.Reflection.MethodBase.GetCurrentMethod().Name,
  58. " userInfo is null " + userPassword + System.Environment.NewLine +
  59. " accountCode:" + accountCode + " userCode:" + userCode + " procedureID:" + procedureID + " barcode:" + barcode,
  60. LocalPath.LogExePath + "SmartDevice\\");
  61. return;
  62. }
  63. SUserInfo sUserInfo = new SUserInfo();
  64. sUserInfo.AccountID = Convert.ToInt32(userInfo.Rows[0]["AccountID"]);
  65. sUserInfo.AccountCode = accountCode;
  66. sUserInfo.UserID = Convert.ToInt32(userInfo.Rows[0]["userid"]);
  67. sUserInfo.UserCode = userCode;
  68. //DataTable barcodeTable = new DataTable();
  69. //barcodeTable.TableName = "barcodeTable";
  70. //barcodeTable.Columns.Add("BarCode");
  71. //barcodeTable.Columns.Add("UserID");
  72. //barcodeTable.Columns.Add("UserCode");
  73. //barcodeTable.Columns.Add("UserName");
  74. //barcodeTable.Columns.Add("LogoID");
  75. //DataRow drCollectType = barcodeTable.NewRow();
  76. //drCollectType["BarCode"] = barcode;
  77. //drCollectType["UserID"] = sUserInfo.UserID;
  78. //drCollectType["UserCode"] = sUserInfo.UserCode;
  79. //drCollectType["UserName"] = userInfo.Rows[0]["UserName"].ToString();
  80. //barcodeTable.Rows.Add(drCollectType);
  81. DataTable barcodeTable = userInfo;
  82. barcodeTable.Columns.Add("LogoID");
  83. barcodeTable.Columns.Add("BarCode");
  84. barcodeTable.Rows[0]["BarCode"] = barcode;
  85. ProcedureEntity procedureInfo = null;
  86. DataTable dt = PMModuleLogicDAL.AddWorkPiece(procedureID, barcodeTable, sUserInfo, out procedureInfo);
  87. if (dt != null && dt.Rows.Count > 0 && !string.IsNullOrWhiteSpace(dt.Rows[0]["out_errMsg"].ToString()))
  88. {
  89. OutputLog.TraceLog(LogPriority.Warning,
  90. this.ToString(),
  91. System.Reflection.MethodBase.GetCurrentMethod().Name + System.Environment.NewLine +
  92. userPassword + System.Environment.NewLine +
  93. " accountCode:" + accountCode + " userCode:" + userCode + " procedureID:" + procedureID + " barcode:" + barcode,
  94. JsonHelper.ToJson(dt),
  95. LocalPath.LogExePath + "SmartDevice\\");
  96. }
  97. }
  98. catch (Exception ex)
  99. {
  100. OutputLog.TraceLog(LogPriority.Error,
  101. this.ToString(),
  102. System.Reflection.MethodBase.GetCurrentMethod().Name + System.Environment.NewLine +
  103. userPassword + System.Environment.NewLine +
  104. " accountCode:" + accountCode + " userCode:" + userCode + " procedureID:" + procedureID + " barcode:" + barcode,
  105. ex.ToString(),
  106. LocalPath.LogExePath);
  107. }
  108. }
  109. /// <summary>
  110. /// 自动扫描计件
  111. /// </summary>
  112. /// <returns></returns>
  113. public string AddWorkPieceByStatus(string accountCode, string userCode, string userPassword,
  114. int procedureID, string barcode, string remarks)
  115. {
  116. try
  117. {
  118. DataTable userInfo = SmartDeviceLogic.CheckUserCode(accountCode, userCode);
  119. if (userInfo == null)
  120. {
  121. OutputLog.TraceLog(LogPriority.Warning,
  122. this.ToString(),
  123. System.Reflection.MethodBase.GetCurrentMethod().Name,
  124. " userInfo is null " + userPassword + System.Environment.NewLine +
  125. " accountCode:" + accountCode + " userCode:" + userCode + " procedureID:" + procedureID + " barcode:" + barcode,
  126. LocalPath.LogExePath + "SmartDevice\\");
  127. return "EU-01";
  128. }
  129. SUserInfo sUserInfo = new SUserInfo();
  130. sUserInfo.AccountID = Convert.ToInt32(userInfo.Rows[0]["AccountID"]);
  131. sUserInfo.AccountCode = accountCode;
  132. sUserInfo.UserID = Convert.ToInt32(userInfo.Rows[0]["userid"]);
  133. sUserInfo.UserCode = userCode;
  134. DataTable barcodeTable = userInfo;
  135. barcodeTable.Columns.Add("LogoID");
  136. barcodeTable.Columns.Add("BarCode");
  137. barcodeTable.Columns.Add("Remarks");
  138. barcodeTable.Rows[0]["BarCode"] = barcode;
  139. barcodeTable.Rows[0]["Remarks"] = remarks;
  140. ProcedureEntity procedureInfo = null;
  141. DataTable dt = PMModuleLogicDAL.AddWorkPiece(procedureID, barcodeTable, sUserInfo, out procedureInfo);
  142. if (dt != null && dt.Rows.Count > 0)
  143. {
  144. string out_msg = dt.Rows[0]["out_errMsg"].ToString();
  145. if (!string.IsNullOrWhiteSpace(out_msg))
  146. {
  147. OutputLog.TraceLog(LogPriority.Warning,
  148. this.ToString(),
  149. System.Reflection.MethodBase.GetCurrentMethod().Name + System.Environment.NewLine +
  150. userPassword + System.Environment.NewLine +
  151. " accountCode:" + accountCode + " userCode:" + userCode + " procedureID:" + procedureID + " barcode:" + barcode,
  152. JsonHelper.ToJson(dt),
  153. LocalPath.LogExePath + "SmartDevice\\");
  154. if (out_msg.StartsWith("无效条码"))
  155. {
  156. return "EP-01";
  157. }
  158. if (out_msg.Contains("不能到达该工序"))
  159. {
  160. return "EP-02";
  161. }
  162. return "EP-00";
  163. }
  164. }
  165. return "OK";
  166. }
  167. catch (Exception ex)
  168. {
  169. OutputLog.TraceLog(LogPriority.Error,
  170. this.ToString(),
  171. System.Reflection.MethodBase.GetCurrentMethod().Name + System.Environment.NewLine +
  172. userPassword + System.Environment.NewLine +
  173. " accountCode:" + accountCode + " userCode:" + userCode + " procedureID:" + procedureID + " barcode:" + barcode,
  174. ex.ToString(),
  175. LocalPath.LogExePath);
  176. return "EE";
  177. }
  178. }
  179. /// <summary>
  180. /// 自动扫描计件(3车间)
  181. /// </summary>
  182. /// <returns></returns>
  183. public string AddWorkPieceByStatus3(string accountCode, string userCode, string userPassword,
  184. int procedureID, string barcode, string remarks)
  185. {
  186. string inputCode = $" accountCode:{accountCode} userCode:{userCode} userPassword:{userPassword} procedureID:{procedureID} barcode:{barcode} remarks:{remarks}";
  187. try
  188. {
  189. DataTable userInfo = SmartDeviceLogic.CheckUserCode(accountCode, userCode);
  190. if (userInfo == null)
  191. {
  192. OutputLog.TraceLog(LogPriority.Warning,
  193. this.ToString(),
  194. System.Reflection.MethodBase.GetCurrentMethod().Name,
  195. " userInfo is null " + inputCode,
  196. LocalPath.LogExePath + "SmartDevice\\");
  197. return "EU-01";
  198. }
  199. SUserInfo sUserInfo = new SUserInfo();
  200. sUserInfo.AccountID = Convert.ToInt32(userInfo.Rows[0]["AccountID"]);
  201. sUserInfo.AccountCode = accountCode;
  202. sUserInfo.UserID = Convert.ToInt32(userInfo.Rows[0]["userid"]);
  203. sUserInfo.UserCode = userCode;
  204. DataTable barcodeTable = userInfo;
  205. barcodeTable.Columns.Add("LogoID");
  206. barcodeTable.Columns.Add("BarCode");
  207. barcodeTable.Columns.Add("Remarks");
  208. barcodeTable.Rows[0]["BarCode"] = barcode;
  209. barcodeTable.Rows[0]["Remarks"] = remarks;
  210. ProcedureEntity procedureInfo = null;
  211. DataTable dt = PMModuleLogicDAL.AddWorkPiece(procedureID, barcodeTable, sUserInfo, out procedureInfo);
  212. if (dt != null && dt.Rows.Count > 0)
  213. {
  214. string out_msg = dt.Rows[0]["out_errMsg"].ToString();
  215. if (!string.IsNullOrWhiteSpace(out_msg))
  216. {
  217. OutputLog.TraceLog(LogPriority.Warning,
  218. this.ToString(),
  219. System.Reflection.MethodBase.GetCurrentMethod().Name,
  220. inputCode + JsonHelper.ToJson(dt),
  221. LocalPath.LogExePath + "SmartDevice\\");
  222. //if (out_msg.StartsWith("无效条码"))
  223. //{
  224. // return "EP-01=" + out_msg;
  225. //}
  226. //if (out_msg.Contains("不能到达该工序"))
  227. //{
  228. // return "EP-02=" + out_msg;
  229. //}
  230. return "EP-00=" + out_msg;
  231. }
  232. }
  233. return "OK";
  234. }
  235. catch (Exception ex)
  236. {
  237. OutputLog.TraceLog(LogPriority.Error,
  238. this.ToString(),
  239. System.Reflection.MethodBase.GetCurrentMethod().Name,
  240. inputCode+ex.ToString(),
  241. LocalPath.LogExePath);
  242. return "EE";
  243. }
  244. }
  245. /// <summary>
  246. /// 注浆接口 xuwei add 2019-11-19
  247. /// </summary>
  248. /// <param name="accountCode"></param>
  249. /// <param name="userCode"></param>
  250. /// <param name="groutingData"></param>
  251. /// <returns></returns>
  252. public string SetGroutingLineDetail(string accountCode, string userCode, string lineCode,
  253. string groutingData, string remarks)
  254. {
  255. string inputCode = $" accountCode:{accountCode} userCode:{userCode} lineCode:{lineCode} groutingData:{groutingData} remarks:{remarks}";
  256. try
  257. {
  258. #region 验证用户 并配置参数 sUserInfo
  259. DataTable userInfo = SmartDeviceLogic.CheckUserCode(accountCode, userCode);
  260. if (userInfo == null)
  261. {
  262. OutputLog.TraceLog(LogPriority.Warning,
  263. this.ToString(),
  264. System.Reflection.MethodBase.GetCurrentMethod().Name,
  265. " userInfo is null " + inputCode,
  266. LocalPath.LogExePath + "SmartDevice\\");
  267. return "EU-01";
  268. }
  269. SUserInfo sUserInfo = new SUserInfo();
  270. sUserInfo.AccountID = Convert.ToInt32(userInfo.Rows[0]["AccountID"]);
  271. sUserInfo.AccountCode = accountCode;
  272. sUserInfo.UserID = Convert.ToInt32(userInfo.Rows[0]["userid"]);
  273. sUserInfo.UserCode = userCode;
  274. #endregion
  275. ServiceResultEntity sre = SmartDeviceLogic.SetGroutingLineDetail(lineCode, groutingData, sUserInfo);
  276. if (sre.Status == Constant.ServiceResultStatus.Success)
  277. {
  278. return "OK";
  279. }
  280. else
  281. {
  282. OutputLog.TraceLog(LogPriority.Warning,
  283. this.ToString(),
  284. System.Reflection.MethodBase.GetCurrentMethod().Name,
  285. inputCode + sre.Message,
  286. LocalPath.LogExePath + "SmartDevice\\");
  287. return $"EG={sre.Message}";
  288. }
  289. }
  290. catch (Exception ex)
  291. {
  292. OutputLog.TraceLog(LogPriority.Error,
  293. this.ToString(),
  294. System.Reflection.MethodBase.GetCurrentMethod().Name,
  295. inputCode+ex.ToString(),
  296. LocalPath.LogExePath);
  297. return "EE";
  298. }
  299. }
  300. /// <summary>
  301. /// 登窑、入窑、出窑 接口 xuwei add 2019-11-19
  302. /// </summary>
  303. /// <param name="accountCode"></param>
  304. /// <param name="userCode"></param>
  305. /// <param name="groutingData"></param>
  306. /// <returns></returns>
  307. public string AddWorkPieceKiln(string accountCode, string userCode, int procedureID,
  308. string kilnCarCode, string barCodeAndPosition, string remarks)
  309. {
  310. string inputCode = $" accountCode:{accountCode} userCode:{userCode} procedureID:{procedureID} kilnCarCode:{kilnCarCode} barCodeAndPosition:{barCodeAndPosition} remarks:{remarks}";
  311. try
  312. {
  313. #region 验证用户 并配置参数 sUserInfo
  314. DataTable userInfo = SmartDeviceLogic.CheckUserCode(accountCode, userCode);
  315. if (userInfo == null)
  316. {
  317. OutputLog.TraceLog(LogPriority.Warning,
  318. this.ToString(),
  319. System.Reflection.MethodBase.GetCurrentMethod().Name,
  320. " userInfo is null " + inputCode,
  321. LocalPath.LogExePath + "SmartDevice\\");
  322. return "EU-01";
  323. }
  324. SUserInfo sUserInfo = new SUserInfo();
  325. sUserInfo.AccountID = Convert.ToInt32(userInfo.Rows[0]["AccountID"]);
  326. sUserInfo.AccountCode = accountCode;
  327. sUserInfo.UserID = Convert.ToInt32(userInfo.Rows[0]["userid"]);
  328. sUserInfo.UserCode = userCode;
  329. #endregion
  330. #region 按窑车号取窑车信息
  331. DataTable carInfo = SmartDeviceLogic.getKilnCarByCode(kilnCarCode);
  332. if (carInfo == null || carInfo.Rows.Count == 0)
  333. {
  334. OutputLog.TraceLog(LogPriority.Warning,
  335. this.ToString(),
  336. System.Reflection.MethodBase.GetCurrentMethod().Name,
  337. "窑车不存在" + inputCode,
  338. LocalPath.LogExePath + "SmartDevice\\");
  339. return "EP-01";
  340. }
  341. #endregion
  342. #region 配置参数 barcodeTable
  343. //入窑参数
  344. //"Barcode": "11100000012",
  345. //"KilnCarName": "TK21",
  346. //"KilnCode": "TK2",
  347. //"UserCode": "F8",
  348. //"UserID": 55,
  349. //"UserName": "胡贤万",
  350. //"KilnCarID": 35,
  351. //"KilnName": "新窑炉",
  352. //"KilnCarPosition": 2,
  353. //"KilnCarCode": "TK21",
  354. //"KilnID": 3
  355. DataTable barcodeTable = new DataTable();
  356. //入窑 卸窑 配置参数 barcodeTable
  357. if (string.IsNullOrWhiteSpace(barCodeAndPosition))
  358. {
  359. barcodeTable.TableName = "barcodeTable";
  360. barcodeTable.Columns.Add("UserID");
  361. barcodeTable.Columns.Add("UserCode");
  362. barcodeTable.Columns.Add("UserName");
  363. barcodeTable.Columns.Add("KilnID");
  364. barcodeTable.Columns.Add("KilnCode");
  365. barcodeTable.Columns.Add("KilnName");
  366. barcodeTable.Columns.Add("KilnCarCode");
  367. barcodeTable.Columns.Add("KilnCarID");
  368. barcodeTable.Columns.Add("KilnCarName");
  369. barcodeTable.Columns.Add("Remarks");
  370. DataRow drCollectType = barcodeTable.NewRow();
  371. drCollectType["UserID"] = userInfo.Rows[0]["UserID"].ToString();
  372. drCollectType["UserCode"] = userInfo.Rows[0]["UserCode"].ToString();
  373. drCollectType["UserName"] = userInfo.Rows[0]["UserName"].ToString();
  374. drCollectType["KilnID"] = carInfo.Rows[0]["KilnID"].ToString();
  375. drCollectType["KilnCode"] = carInfo.Rows[0]["KilnCode"].ToString();
  376. drCollectType["KilnName"] = carInfo.Rows[0]["KilnName"].ToString();
  377. drCollectType["KilnCarID"] = carInfo.Rows[0]["KilnCarID"].ToString();
  378. drCollectType["KilnCarCode"] = carInfo.Rows[0]["KilnCarCode"].ToString();
  379. drCollectType["KilnCarName"] = carInfo.Rows[0]["KilnCarName"].ToString();
  380. drCollectType["Remarks"] = remarks;
  381. barcodeTable.Rows.Add(drCollectType);
  382. }
  383. else
  384. {
  385. //登窑 添加数据 配置参数 barcodeTable
  386. barcodeTable.TableName = "barcodeTable";
  387. barcodeTable.Columns.Add("UserID");
  388. barcodeTable.Columns.Add("UserCode");
  389. barcodeTable.Columns.Add("UserName");
  390. barcodeTable.Columns.Add("BarCode");
  391. barcodeTable.Columns.Add("KilnID");
  392. barcodeTable.Columns.Add("KilnCode");
  393. barcodeTable.Columns.Add("KilnName");
  394. barcodeTable.Columns.Add("KilnCarID");
  395. barcodeTable.Columns.Add("KilnCarCode");
  396. barcodeTable.Columns.Add("KilnCarName");
  397. barcodeTable.Columns.Add("KilnCarPosition");
  398. barcodeTable.Columns.Add("Remarks");
  399. JArray barCodeArray = JArray.Parse(barCodeAndPosition);
  400. for (int i = 0; i < barCodeArray.Count; i++)
  401. {
  402. DataRow drCollectType = barcodeTable.NewRow();
  403. drCollectType["BarCode"] = barCodeArray[i]["barCode"].ToString();
  404. drCollectType["UserID"] = userInfo.Rows[0]["UserID"].ToString();
  405. drCollectType["UserCode"] = userInfo.Rows[0]["UserCode"].ToString();
  406. drCollectType["UserName"] = userInfo.Rows[0]["UserName"].ToString();
  407. drCollectType["KilnID"] = carInfo.Rows[0]["KilnID"].ToString();
  408. drCollectType["KilnCode"] = carInfo.Rows[0]["KilnCode"].ToString();
  409. drCollectType["KilnName"] = carInfo.Rows[0]["KilnName"].ToString();
  410. drCollectType["KilnCarID"] = carInfo.Rows[0]["KilnCarID"].ToString();
  411. drCollectType["KilnCarCode"] = carInfo.Rows[0]["KilnCarCode"].ToString();
  412. drCollectType["KilnCarName"] = carInfo.Rows[0]["KilnCarName"].ToString();
  413. drCollectType["KilnCarPosition"] = barCodeArray[i]["kilnCarPosition"].ToString();
  414. drCollectType["Remarks"] = remarks;
  415. barcodeTable.Rows.Add(drCollectType);
  416. }
  417. }
  418. #endregion
  419. #region 调用原始业务逻辑
  420. DataTable dt = SmartDeviceLogic.AddWorkPieceKiln(procedureID, barcodeTable, sUserInfo);
  421. #endregion
  422. #region 输出结果
  423. if (dt != null && dt.Rows.Count > 0)
  424. {
  425. string out_msg = dt.Rows[0]["out_errMsg"].ToString();
  426. if (!string.IsNullOrWhiteSpace(out_msg))
  427. {
  428. OutputLog.TraceLog(LogPriority.Warning,
  429. this.ToString(),
  430. System.Reflection.MethodBase.GetCurrentMethod().Name,
  431. inputCode + JsonHelper.ToJson(dt),
  432. LocalPath.LogExePath + "SmartDevice\\");
  433. //if (out_msg.StartsWith("无效条码"))
  434. //{
  435. // return "EP-01";
  436. //}
  437. //if (out_msg.Contains("不能到达该工序"))
  438. //{
  439. // return "EP-02=" + out_msg;
  440. //}
  441. return "EP-00=" + out_msg;
  442. }
  443. }
  444. return "OK";
  445. #endregion
  446. }
  447. catch (Exception ex)
  448. {
  449. OutputLog.TraceLog(LogPriority.Error,
  450. this.ToString(),
  451. System.Reflection.MethodBase.GetCurrentMethod().Name,
  452. inputCode + ex.ToString(),
  453. LocalPath.LogExePath);
  454. return "EE";
  455. }
  456. }
  457. }
  458. }