ZC_SyncService.cs 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  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 ZC_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_fa_card = ConfigurationManager.AppSettings["fa_card"];
  26. public static string _Static_pk_org_jt = ConfigurationManager.AppSettings["pk_org_jt"];
  27. public ZC_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\"}");
  47. // 获取当前最大Id
  48. var newId = 100000001;
  49. var maxData = _db_nc.Queryable<fa_card>().OrderByDescending(obd => Convert.ToDateTime(obd.creationtime)).First();
  50. if (maxData != null && maxData.pk_card.Contains(_Static_PK_fa_card))
  51. {
  52. newId = Convert.ToInt32(maxData.pk_card.Replace(_Static_PK_fa_card, "")) + 1;
  53. }
  54. #region 获取NC中选项数据的Id
  55. var pam_addreducestyleDic = _db_nc.Queryable<pam_addreducestyle>().ToList();
  56. #endregion
  57. // 资产部门ID textField_lydsc49c
  58. // 管理部门ID textField_lydsc49b
  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. #region 构建数据体
  67. var data = new fa_card();
  68. data.archarea = 0;
  69. data.asset_code = ydDataSource["textField_lty0oyv4"].ToString();
  70. data.asset_name = ydDataSource["textField_lty0oyuj"].ToString();
  71. data.begin_date = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
  72. data.bill_source = "handin";
  73. data.bill_type = "H1";
  74. data.billmaker = "1001G110000000000ADH";
  75. data.billmaketime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
  76. data.business_date = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
  77. data.creationtime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
  78. data.creator = "1001G110000000000ADH";
  79. data.currmoney = 0;
  80. data.dismant_cost = 0;
  81. data.dy_flag = "N";
  82. data.install_fee = 0;
  83. data.machinepower = 0;
  84. data.machinequan = 0;
  85. data.nettonnage = 0;
  86. data.other_cost = 0;
  87. data.pk_group = _Static_pk_org_jt;
  88. data.pk_org = "0001G110000000001MVP";
  89. data.pk_org_v = "0001G110000000001MVO";
  90. data.card_code = "0000001242";
  91. data.assetsuit_code = "营运部(项目)0354";
  92. // 主键
  93. data.pk_currency = "1002Z0100000000001K1";
  94. data.pk_transitype = "0001G110000000001B48";
  95. data.transi_type = "H1-00";
  96. data.ts = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
  97. var ncResData = new YiDaResDto()
  98. {
  99. syncTime = DateTime.Now,
  100. };
  101. ncResData.bSuccess = false;
  102. ncResData.ncNo = "";
  103. ncResData.log = "同步失败【使用部门为空!】";
  104. var ydRes = _dingTalkService.UpdateFormDataSyncDataById(ncResData, item);
  105. if (ydDataSource.FirstOrDefault(f => f.Key == "selectField_lwk48b8s").Value != null)
  106. {
  107. if (!string.IsNullOrWhiteSpace(ydDataSource["selectField_lwk48b8s"].ToString()))
  108. {
  109. var tempData = pam_addreducestyleDic.FirstOrDefault(f => f.style_name == ydDataSource["selectField_lwk48b8s"].ToString());
  110. if (tempData != null)
  111. {
  112. data.pk_addreducestyle = tempData.pk_addreducestyle; // 增加方式
  113. }
  114. }
  115. }
  116. #endregion
  117. #region 数据传入NC并获取结果
  118. var nowData = _db_nc.Queryable<fa_card>().First(f => f.asset_code == data.asset_code);
  119. if (nowData == null)
  120. {
  121. data.pk_card = "DINGTALKFAC100000006"; //_Static_PK_fa_card + newId;
  122. _db_nc.Insertable(data).ExecuteCommand();
  123. newId++;
  124. }
  125. else
  126. {
  127. data.pk_card = nowData.pk_card;
  128. _db_nc.Updateable(data).ExecuteCommand();
  129. }
  130. #endregion
  131. }
  132. #endregion
  133. }
  134. }
  135. }