XMD_SyncService.cs 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166
  1. using HH.YiDaSyncNC.Dtos;
  2. using HH.YiDaSyncNC.Dtos.NC;
  3. using HH.YiDaSyncNC.Helper;
  4. using HH.YiDaSyncNC.Models;
  5. using Newtonsoft.Json;
  6. using SqlSugar;
  7. using System;
  8. using System.Collections.Generic;
  9. using System.Configuration;
  10. using System.Linq;
  11. using System.Text;
  12. using System.Threading.Tasks;
  13. using System.Xml.Linq;
  14. namespace HH.YiDaSyncNC.DataSync
  15. {
  16. class XMD_SyncService
  17. {
  18. public string _AppType;
  19. public string _SystemToken;
  20. public string _UserId;
  21. public string _FormId;
  22. public SqlSugarClient _db;
  23. public SqlSugarClient _db_nc;
  24. public string _NCApiUrl;
  25. public static string _Static_PK_bd_project = ConfigurationManager.AppSettings["bd_project"];
  26. public static string _Static_pk_org_jt = ConfigurationManager.AppSettings["pk_org_jt"];
  27. public XMD_SyncService(string AppType, string SystemToken, string UserId, string FormId, SqlSugarClient db, SqlSugarClient db_nc, string NCApiUrl)
  28. {
  29. _AppType = AppType;
  30. _SystemToken = SystemToken;
  31. _UserId = UserId;
  32. _FormId = FormId;
  33. _db = db;
  34. _db_nc = db_nc;
  35. _NCApiUrl = NCApiUrl;
  36. }
  37. public class IdCodeModel
  38. {
  39. public int sourceId { get; set; }
  40. public string Id { get; set; }
  41. }
  42. public void DataSync()
  43. {
  44. DingTalkService _dingTalkService = new DingTalkService(_AppType, _SystemToken, _UserId, _FormId);
  45. // 宜搭全量数据Id
  46. var idList = _dingTalkService.GetFormIdList("{\"radioField_lycrvvtk\":\"Y\",\"textField_ltxrn8h1\":\"PM00408\"}");
  47. //var idList = _dingTalkService.GetFormIdList("");
  48. // 获取当前最大Id
  49. var newId = 100000001;
  50. var maxData = _db_nc.Queryable<bd_project>().OrderByDescending(obd => obd.pk_project).First();
  51. if (maxData != null && maxData.pk_project.Contains(_Static_PK_bd_project))
  52. {
  53. newId = Convert.ToInt32(maxData.pk_project.Replace(_Static_PK_bd_project, "")) + 1;
  54. }
  55. #region 获取NC中选项数据的Id
  56. var bd_projectclassDic = _db_nc.Queryable<bd_projectclass>().ToList();
  57. var bd_stordocDic = _db_nc.Queryable<bd_stordoc>().ToList();
  58. #endregion
  59. #region 循环数据处理业务逻辑
  60. foreach (var item in idList)
  61. {
  62. // 获取此条数据详情
  63. string createTime = "";
  64. string modifyTime = "";
  65. var ydDataSource = _dingTalkService.GetFormDataById(item, out createTime, out modifyTime);
  66. if (ydDataSource["radioField_lycrvvtk"].ToString() == "Y")
  67. {
  68. #region 构建数据体
  69. var data = new bd_project();
  70. data.begin_flag = "N";
  71. data.bill_type = "4D10";
  72. data.creationtime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
  73. data.ts = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
  74. data.creator = "1001G1100000000B6553";
  75. data.def6 = ydDataSource["textField_lrim7i38"].ToString(); // 项目地址
  76. data.def7 = ydDataSource["textField_lrn2oy4n"].ToString(); // 体系
  77. data.enablestate = 2;
  78. data.pk_eps = "";
  79. data.pk_group = _Static_pk_org_jt;
  80. data.pk_org = _Static_pk_org_jt;
  81. // data.pk_projectclass = "";
  82. if (ydDataSource.FirstOrDefault(f => f.Key == "selectField_lrhjdu45").Value != null)
  83. {
  84. if (!string.IsNullOrWhiteSpace(ydDataSource["selectField_lrhjdu45"].ToString()))
  85. {
  86. var tempData = bd_projectclassDic.FirstOrDefault(f => f.type_name == ydDataSource["selectField_lrhjdu45"].ToString());
  87. if (tempData != null)
  88. {
  89. data.pk_projectclass = tempData.pk_projectclass; // 项目类型
  90. }
  91. }
  92. }
  93. //if (ydDataSource.FirstOrDefault(f => f.Key == "selectField_lrn2oy4c").Value != null)
  94. //{
  95. // if (!string.IsNullOrWhiteSpace(ydDataSource["selectField_lrn2oy4c"].ToString()))
  96. // {
  97. // var tempData = bd_stordocDic.FirstOrDefault(f => f.name == ydDataSource["selectField_lrn2oy4c"].ToString());
  98. // if (tempData != null)
  99. // {
  100. // data.pk_stordoc1 = tempData.pk_stordoc; // 仓库
  101. // }
  102. // }
  103. //}
  104. data.project_code = ydDataSource["textField_ltxrn8h1"].ToString();
  105. data.project_name = ydDataSource["textField_lrr3rg6i"].ToString();
  106. data.transi_type = "4D10-01";
  107. #endregion
  108. #region 数据传入NC并获取结果
  109. var nowData = _db_nc.Queryable<bd_project>().First(f => f.project_code == data.project_code);
  110. if (nowData == null)
  111. {
  112. data.pk_project = _Static_PK_bd_project + newId;
  113. _db_nc.Insertable(data).ExecuteCommand();
  114. newId++;
  115. }
  116. else
  117. {
  118. data.pk_project = nowData.pk_project;
  119. _db_nc.Updateable(data).ExecuteCommand();
  120. }
  121. #endregion
  122. #region 回写状态
  123. var ncResData = new YiDaResDto()
  124. {
  125. syncTime = DateTime.Now,
  126. };
  127. DBHelper.WriteLog($"Id为【{JsonConvert.SerializeObject(item)}】的单据操作成功!");
  128. ncResData.bSuccess = true;
  129. ncResData.ncNo = data.pk_project;
  130. ncResData.log = "同步成功!";
  131. var ydRes = _dingTalkService.UpdateFormDataSyncDataById(ncResData, item);
  132. #endregion
  133. }
  134. }
  135. #endregion
  136. }
  137. }
  138. }