Lot3Controller.cs 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333
  1. using EInk.Dtos;
  2. using EInk.Models;
  3. using Microsoft.AspNetCore.Mvc;
  4. using Newtonsoft.Json;
  5. using SqlSugar;
  6. using System;
  7. using System.ComponentModel;
  8. using System.Xml.Linq;
  9. using System;
  10. using System.Threading;
  11. using System.Text;
  12. using EInk.Dtos;
  13. using System.Reflection.Metadata;
  14. using Microsoft.AspNetCore.Mvc.Rendering;
  15. using EInk.Tools;
  16. using EInk.Lot2Lot3.Models;
  17. using Microsoft.Extensions.DependencyInjection;
  18. using Microsoft.Extensions.Options;
  19. using System.Reflection;
  20. using DataAcquisition;
  21. namespace EInk.Controllers
  22. {
  23. [Route("api/[controller]")]
  24. [ApiController]
  25. public class Lot3Controller : ControllerBase
  26. {
  27. private readonly ISqlSugarClient _db;
  28. private readonly IConfiguration _configuration = new ConfigurationBuilder().SetBasePath(Directory.GetCurrentDirectory()).AddJsonFile("appsettings.json", optional: true, reloadOnChange: true).Build();
  29. private readonly AppearancePixelEquivalent _appearancepixelequivalent;
  30. private readonly List<string> _Lot3AppearancePatternList;
  31. public Lot3Controller(ISqlSugarClient db)
  32. {
  33. _db = db;
  34. _appearancepixelequivalent = _configuration.GetSection("AppearancePixelEquivalent").Get<AppearancePixelEquivalent>();
  35. _Lot3AppearancePatternList = _configuration.GetValue<string>("Lot3AppearancePatternList").Split(",").ToList();
  36. }
  37. [HttpPost("UploadLot3")]
  38. public IActionResult Lot3Data([FromBody] Lot3Dto lot3Data)
  39. {
  40. LogerHelper.RecordLogTxt($"{DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff")} start, guid:{lot3Data.id} ,slidesNumber:{lot3Data.slidesNumber}");
  41. string jsonStr = JsonConvert.SerializeObject(lot3Data);
  42. try
  43. {
  44. try
  45. {
  46. lot3Data.Valid();
  47. }
  48. catch (Exception ex)
  49. {
  50. LogerHelper.RecordLogTxt($"UploadLot3, Valid Fail, Data:{jsonStr}, Message:{ex.Message}");
  51. return Ok(ResultDto.Fail(ex.Message));
  52. }
  53. //外观检像素当量
  54. if (_appearancepixelequivalent.enable && lot3Data.result == "NG")
  55. {
  56. foreach (var item in lot3Data.itemCheckDatas)
  57. {
  58. //像素 = 实际长度 / 像素当量
  59. switch (item.pattern)
  60. {
  61. case "PositiveAppearance":
  62. foreach (var detail_item in item.details)
  63. {
  64. var (flag, height, width) = detail_item.Valid_HeightWidth();
  65. if (flag)
  66. {
  67. detail_item.height = (Math.Round(height / _appearancepixelequivalent.PositiveAppearance, 2)).ToString();
  68. detail_item.width = (Math.Round(width / _appearancepixelequivalent.PositiveAppearance, 2)).ToString();
  69. }
  70. }
  71. break;
  72. case "BackAppearance":
  73. foreach (var detail_item in item.details)
  74. {
  75. var (flag, height, width) = detail_item.Valid_HeightWidth();
  76. if (flag)
  77. {
  78. detail_item.height = (Math.Round(height / _appearancepixelequivalent.BackAppearance, 2)).ToString();
  79. detail_item.width = (Math.Round(width / _appearancepixelequivalent.BackAppearance, 2)).ToString();
  80. }
  81. }
  82. break;
  83. case "BackFPC":
  84. foreach (var detail_item in item.details)
  85. {
  86. var (flag, height, width) = detail_item.Valid_HeightWidth();
  87. if (flag)
  88. {
  89. detail_item.height = (Math.Round(height / _appearancepixelequivalent.BackFPC, 2)).ToString();
  90. detail_item.width = (Math.Round(width / _appearancepixelequivalent.BackFPC, 2)).ToString();
  91. }
  92. }
  93. break;
  94. case "PositiveFPC":
  95. foreach (var detail_item in item.details)
  96. {
  97. var (flag, height, width) = detail_item.Valid_HeightWidth();
  98. if (flag)
  99. {
  100. detail_item.height = (Math.Round(height / _appearancepixelequivalent.PositiveFPC, 2)).ToString();
  101. detail_item.width = (Math.Round(width / _appearancepixelequivalent.PositiveFPC, 2)).ToString();
  102. }
  103. }
  104. break;
  105. default:
  106. break;
  107. }
  108. }
  109. }
  110. Lot2Lot3Model lot3model = new()
  111. {
  112. lot_id = lot3Data.id,
  113. is_send = 0,
  114. product_no = lot3Data.slidesNumber,
  115. create_time = DateTime.Now,
  116. is_repeatupload = Convert.ToInt32(lot3Data.isrepeatupload),
  117. operation_time = Convert.ToDateTime(lot3Data.createTime),
  118. content = JsonConvert.SerializeObject(new Lot2Lot3Dto(lot3Data))
  119. };
  120. //根据guid查看是否为重复插入
  121. if (GuidCache.GuidQueue.Contains(lot3Data.id) || lot3Data.slidesNumber == "NA")
  122. {
  123. lot3model.is_send = 3;
  124. }
  125. GuidCache.Add(lot3Data.id);
  126. _db.Insertable(lot3model).ExecuteCommand();
  127. LogerHelper.RecordLogTxt($"{DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff")} end, guid:{lot3Data.id} ,slidesNumber:{lot3Data.slidesNumber}");
  128. return Ok(ResultDto.Success());
  129. }
  130. catch (Exception ex)
  131. {
  132. LogerHelper.RecordLogTxt($"UploadLot3, Data:{jsonStr}, StackTrace:{ex.StackTrace}, Message:{ex.Message}");
  133. return Ok(ResultDto.Fail("error:" + ex.Message));
  134. }
  135. }
  136. [HttpPost("UploadLot3List")]
  137. public IActionResult Lot3DataList([FromBody] List<Lot3Dto> lot3Datalist)
  138. {
  139. Lot3Dto Lot3tempData = new Lot3Dto();
  140. try
  141. {
  142. foreach (var item in lot3Datalist)
  143. {
  144. Lot3tempData = item;
  145. item.Valid();
  146. }
  147. }
  148. catch (Exception ex)
  149. {
  150. LogerHelper.RecordLogTxt($"UploadLot3, Valid Fail, Data:{JsonConvert.SerializeObject(Lot3tempData)}, Message:{ex.Message}");
  151. //return Ok(ResultDto.Fail(ex.Message));
  152. return Ok(ResultDto.Fail($"Valid Fail, Data:{JsonConvert.SerializeObject(Lot3tempData)}, Message:{ex.Message}"));
  153. }
  154. try
  155. {
  156. _db.Ado.BeginTran();
  157. foreach (var Lot3item in lot3Datalist)
  158. {
  159. Lot3tempData = Lot3item;
  160. //外观检像素当量
  161. if (_appearancepixelequivalent.enable && Lot3item.result == "NG")
  162. {
  163. foreach (var item in Lot3item.itemCheckDatas)
  164. {
  165. //像素 = 实际长度 / 像素当量
  166. switch (item.pattern)
  167. {
  168. case "PositiveAppearance":
  169. foreach (var detail_item in item.details)
  170. {
  171. var (flag, height, width) = detail_item.Valid_HeightWidth();
  172. if (flag)
  173. {
  174. detail_item.height = (Math.Round(height / _appearancepixelequivalent.PositiveAppearance, 2)).ToString();
  175. detail_item.width = (Math.Round(width / _appearancepixelequivalent.PositiveAppearance, 2)).ToString();
  176. }
  177. }
  178. break;
  179. case "BackAppearance":
  180. foreach (var detail_item in item.details)
  181. {
  182. var (flag, height, width) = detail_item.Valid_HeightWidth();
  183. if (flag)
  184. {
  185. detail_item.height = (Math.Round(height / _appearancepixelequivalent.BackAppearance, 2)).ToString();
  186. detail_item.width = (Math.Round(width / _appearancepixelequivalent.BackAppearance, 2)).ToString();
  187. }
  188. }
  189. break;
  190. case "BackFPC":
  191. foreach (var detail_item in item.details)
  192. {
  193. var (flag, height, width) = detail_item.Valid_HeightWidth();
  194. if (flag)
  195. {
  196. detail_item.height = (Math.Round(height / _appearancepixelequivalent.BackFPC, 2)).ToString();
  197. detail_item.width = (Math.Round(width / _appearancepixelequivalent.BackFPC, 2)).ToString();
  198. }
  199. }
  200. break;
  201. case "PositiveFPC":
  202. foreach (var detail_item in item.details)
  203. {
  204. var (flag, height, width) = detail_item.Valid_HeightWidth();
  205. if (flag)
  206. {
  207. detail_item.height = (Math.Round(height / _appearancepixelequivalent.PositiveFPC, 2)).ToString();
  208. detail_item.width = (Math.Round(width / _appearancepixelequivalent.PositiveFPC, 2)).ToString();
  209. }
  210. }
  211. break;
  212. default:
  213. break;
  214. }
  215. }
  216. }
  217. Lot2Lot3Model lot3model = new()
  218. {
  219. lot_id = Lot3item.id,
  220. is_send = 0,
  221. product_no = Lot3item.slidesNumber,
  222. create_time = DateTime.Now,
  223. is_repeatupload = Convert.ToInt32(Lot3item.isrepeatupload),
  224. operation_time = Convert.ToDateTime(Lot3item.createTime),
  225. content = JsonConvert.SerializeObject(new Lot2Lot3Dto(Lot3item))
  226. };
  227. //根据guid查看是否为重复插入
  228. if (GuidCache.GuidQueue.Contains(Lot3item.id) || Lot3item.slidesNumber == "NA")
  229. {
  230. lot3model.is_send = 3;
  231. }
  232. GuidCache.Add(Lot3item.id);
  233. _db.Insertable(lot3model).ExecuteCommand();
  234. }
  235. _db.Ado.CommitTran();
  236. return Ok(ResultDto.Success());
  237. }
  238. catch (Exception ex)
  239. {
  240. _db.Ado.RollbackTran(); ;
  241. LogerHelper.RecordLogTxt($"UploadLot3, Data:{JsonConvert.SerializeObject(Lot3tempData)}, StackTrace:{ex.StackTrace}, Message:{ex.Message}");
  242. return Ok(ResultDto.Fail("error:" + ex.Message));
  243. }
  244. }
  245. [HttpPost("UploadColourCast")]
  246. public IActionResult ColourCastData([FromBody] ColourCastDto ColourCastData)
  247. {
  248. string jsonStr = JsonConvert.SerializeObject(ColourCastData);
  249. try
  250. {
  251. try
  252. {
  253. ColourCastData.Valid();
  254. }
  255. catch (Exception ex)
  256. {
  257. LogerHelper.RecordLogTxt($"UploadColourCast, Valid Fail, Data:{jsonStr}, Message:{ex.Message}");
  258. return Ok(ResultDto.Fail(ex.Message));
  259. };
  260. ColourCastModel colourcastmodel = new()
  261. {
  262. gid = ColourCastData.id,
  263. slidesNumber = ColourCastData.slidesNumber,
  264. is_send = 0,
  265. content = jsonStr,
  266. create_time = DateTime.Now
  267. };
  268. //根据guid查看是否为重复插入
  269. if (_db.Ado.GetInt(string.Format("select count(*) from colourcast_info where gid='{0}'", ColourCastData.id)) > 0)
  270. {
  271. colourcastmodel.is_send = 3;
  272. }
  273. _db.Insertable(colourcastmodel).ExecuteCommand();
  274. return Ok(ResultDto.Success());
  275. }
  276. catch (Exception ex)
  277. {
  278. LogerHelper.RecordLogTxt($"UploadColourCast, Data:{jsonStr}, StackTrace:{ex.StackTrace}, Message:{ex.Message}");
  279. return Ok(ResultDto.Fail("error:" + ex.Message));
  280. }
  281. }
  282. [HttpPost("UpdateDefectInfo")]
  283. public IActionResult UpdateDefectInfo(IFormFile file)
  284. {
  285. if (file == null || file.Length == 0)
  286. {
  287. return Ok(ResultDto.Fail("No file selected"));
  288. }
  289. string line;
  290. try
  291. {
  292. _db.Ado.BeginTran();
  293. _db.Deleteable<DefectModel>().ExecuteCommand();
  294. using (var reader = new StreamReader(file.OpenReadStream(), Encoding.GetEncoding("gb2312")))
  295. {
  296. var header = reader.ReadLine();
  297. var headers = header.Split(',');
  298. while ((line = reader.ReadLine()) != null)
  299. {
  300. string[] linelist = line.Split(",");
  301. _db.Insertable(new DefectModel
  302. {
  303. id = Convert.ToInt32(linelist[0]),
  304. defect_code = linelist[1],
  305. defect_name = linelist[2],
  306. classification = linelist[3].Replace(';', ',')
  307. }).ExecuteCommand();
  308. }
  309. }
  310. _db.Ado.CommitTran();
  311. }
  312. catch (Exception ex)
  313. {
  314. _db.Ado.RollbackTran();
  315. return Ok(ResultDto.Fail(ex.Message));
  316. }
  317. return Ok(ResultDto.Success());
  318. }
  319. }
  320. }