GYS_SyncService.cs 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206
  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 GYS_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_xx_idcontrast = ConfigurationManager.AppSettings["xx_idcontrast"];
  26. public static string _Static_pk_org_jt = ConfigurationManager.AppSettings["pk_org_jt"];
  27. public GYS_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();
  47. // NC ID对照表数据
  48. var ncDataIdList = _db_nc.Queryable<xx_idcontrast>().Where(w => w.bill_type == "supplier").ToList();
  49. // 获取当前最大Id
  50. var newId = 100000001;
  51. var maxData = ncDataIdList.OrderByDescending(obd => Convert.ToDateTime(obd.ts)).FirstOrDefault();
  52. if (maxData != null && maxData.pk_idcontra.Contains(_Static_PK_xx_idcontrast))
  53. {
  54. newId = Convert.ToInt32(maxData.pk_idcontra.Replace(_Static_PK_xx_idcontrast, "")) + 1;
  55. }
  56. #region 获取NC中选项数据的Id
  57. var pk_supplierclassDic = _db_nc.Queryable<bd_supplierclass>().ToList();
  58. #endregion
  59. #region 循环数据处理业务逻辑
  60. // 向NC插入数据
  61. foreach (var item in idList)
  62. {
  63. string createTime = "";
  64. string modifyTime = "";
  65. var ydDataSource = _dingTalkService.GetFormDataById(item, out createTime, out modifyTime);
  66. var suplinkmanDataList = new List<GYS_SyncServiceModel.DataModel.SuplinkmanItem>();
  67. //tableField_lrn5j23r
  68. var suplinkmanObjList = new List<object>();
  69. if (ydDataSource.FirstOrDefault(f => f.Key == "tableField_lrn5j24e").Value != null)
  70. suplinkmanObjList = (List<object>)ydDataSource["tableField_lrn5j24e"];
  71. foreach (var objItem in suplinkmanObjList)
  72. {
  73. suplinkmanDataList.Add(new GYS_SyncServiceModel.DataModel.SuplinkmanItem()
  74. {
  75. name = ((Dictionary<string, object>)objItem)["textField_lrn5j244"].ToString(),
  76. cell = ((Dictionary<string, object>)objItem)["textField_lrn5j245"].ToString(),
  77. });
  78. }
  79. var dataSource = new GYS_SyncServiceModel.DataModel()
  80. {
  81. pk_group = "0",
  82. pk_org = "0",
  83. code = ydDataSource["textField_lrhgjspd"].ToString(),
  84. name = ydDataSource["textField_lrhgjspc"].ToString(),
  85. taxpayerid = ydDataSource["textField_lrhgjspr"].ToString(),
  86. };
  87. if (!string.IsNullOrWhiteSpace(ydDataSource["selectField_lrn5j22q"].ToString()))
  88. {
  89. var a = pk_supplierclassDic.FirstOrDefault(f => f.name == ydDataSource["selectField_lrn5j22q"].ToString());
  90. if (a != null)
  91. dataSource.pk_supplierclass = a.code; // 分类s
  92. }
  93. if (!string.IsNullOrWhiteSpace(ydDataSource["selectField_lrn5j22p"].ToString()))
  94. {
  95. switch (ydDataSource["selectField_lrn5j22p"].ToString())
  96. {
  97. case "启用":
  98. dataSource.enablestate = ((int)EnumType.enablestate.已启用).ToString();
  99. break;
  100. case "未启用":
  101. dataSource.enablestate = ((int)EnumType.enablestate.已停用).ToString();
  102. break;
  103. }
  104. }
  105. dataSource.suplinkman = suplinkmanDataList;
  106. var xmlData = GYS_SyncServiceModel.ImportXml.Header(dataSource, item);
  107. XElement tempData = GYS_SyncServiceModel.ImportXml.TemplateHeade();
  108. var results = NCImportFunc.NCImport(tempData, xmlData, _NCApiUrl + "?account=01&groupcode=0");
  109. XElement xE = XElement.Parse(results);
  110. string resultcode = xE.Element("sendresult").Element("resultcode").Value;
  111. string resultdescription = xE.Element("sendresult").Element("resultdescription")?.Value;
  112. var ncResData = new YiDaResDto()
  113. {
  114. syncTime = DateTime.Now,
  115. };
  116. // NC接口执行完成后的处理
  117. if (resultcode == "1")
  118. {
  119. DBHelper.WriteLog($"Id为【{JsonConvert.SerializeObject(item)}】的单据操作成功!");
  120. ncResData.bSuccess = true;
  121. ncResData.ncNo = xE.Element("sendresult").Element("content").Value;
  122. ncResData.log = "同步成功!";
  123. }
  124. else
  125. {
  126. if (resultdescription.Contains("不允许重复"))
  127. {
  128. // 已存在数据,绑定Id
  129. var nowData = _db_nc.Queryable<bd_supplier>().First(f => f.code == dataSource.code && f.pk_org == _Static_pk_org_jt);
  130. var idcData = new xx_idcontrast()
  131. {
  132. bill_type = "supplier",
  133. dr = 0,
  134. file_id = item,
  135. pk_bill = nowData.pk_supplier,
  136. pk_idcontra = _Static_PK_xx_idcontrast + newId
  137. };
  138. _db_nc.Insertable(idcData).ExecuteCommand();
  139. newId++;
  140. ncResData.bSuccess = true;
  141. ncResData.ncNo = nowData.pk_supplier;
  142. ncResData.log = "数据已存在,无需同步,已自动对照!";
  143. }
  144. else
  145. {
  146. DBHelper.WriteLog($"Id为【{JsonConvert.SerializeObject(item)}】的单据操作失败!" + resultdescription + ";");
  147. ncResData.bSuccess = false;
  148. ncResData.ncNo = "";
  149. ncResData.log = "同步失败!原因为【" + resultdescription + "】";
  150. }
  151. //DBHelper.WriteLog($"Id为【{JsonConvert.SerializeObject(item)}】的单据操作失败!" + resultdescription + ";");
  152. //if (resultdescription.Contains("不允许重复"))
  153. //{
  154. // ncResData.bSuccess = true;
  155. // ncResData.ncNo = "";
  156. // ncResData.log = "数据已存在,无需同步!";
  157. //}
  158. //else
  159. //{
  160. // ncResData.bSuccess = false;
  161. // ncResData.ncNo = "";
  162. // ncResData.log = "同步失败!原因为【" + resultdescription + "】";
  163. //}
  164. }
  165. var ydRes = _dingTalkService.UpdateFormDataSyncDataById(ncResData, item);
  166. }
  167. #endregion
  168. }
  169. }
  170. }