MerchantChangeSettlementCardRecordController.cs 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using Microsoft.AspNetCore.Mvc;
  5. using Microsoft.AspNetCore.Http;
  6. using Microsoft.Extensions.Logging;
  7. using Microsoft.Extensions.Options;
  8. using Microsoft.AspNetCore.Authorization;
  9. using System.Web;
  10. using MySystem.Models.Main2;
  11. using MySystem.Service.Main2;
  12. using LitJson;
  13. using Library;
  14. namespace MySystem.Areas.Api.Controllers.v1.Main2
  15. {
  16. [Area("Api")]
  17. [Route("/v1/QrCodePlateMain/[controller]/[action]")]
  18. public class MerchantChangeSettlementCardRecordController : BaseController
  19. {
  20. public MerchantChangeSettlementCardRecordController(IHttpContextAccessor accessor) : base(accessor)
  21. {
  22. }
  23. #region 商户管理-银联商户修改结算卡记录
  24. [Authorize]
  25. public JsonResult UnionPayChangeSettlementCardList(string value)
  26. {
  27. value = PublicFunction.DesDecrypt(value);
  28. JsonData data = JsonMapper.ToObject(value);
  29. Dictionary<string, object> Other = new Dictionary<string, object>();
  30. List<Dictionary<string, object>> dataList = UnionPayChangeSettlementCardListDo(value, out Other);
  31. return Json(new AppResultJson() { Status = "1", Info = "", Data = dataList, Other = Other });
  32. }
  33. private List<Dictionary<string, object>> UnionPayChangeSettlementCardListDo(string value, out Dictionary<string, object> Other)
  34. {
  35. JsonData data = JsonMapper.ToObject(value);
  36. string MerchantName = data["MerchantName"].ToString(); //商户名称
  37. string MchtNo = data["MchtNo"].ToString(); //商户号
  38. string CreateDate = data["CreateDate"].ToString(); //创建时间
  39. int pageSize = int.Parse(function.CheckInt(data["page_size"].ToString()));
  40. int pageNum = int.Parse(function.CheckInt(data["page_num"].ToString()));
  41. string condition = " and Status>-1";
  42. if (!string.IsNullOrEmpty(data["MerchantName"].ToString()))
  43. {
  44. condition += " and MerchantName='" + MerchantName + "'";
  45. }
  46. if (!string.IsNullOrEmpty(data["MchtNo"].ToString()))
  47. {
  48. condition += " and MchtNo='" + MchtNo + "'";
  49. }
  50. if (!string.IsNullOrEmpty(data["CreateDate"].ToString()))
  51. {
  52. string[] datelist = CreateDate.Split(new string[] { " - " }, StringSplitOptions.None);
  53. string start = datelist[0];
  54. string end = datelist[1];
  55. condition += " and CreateDate>='" + start + " 00:00:00' and CreateDate<='" + end + " 23:59:59'";
  56. }
  57. List<RelationData> relationData = new List<RelationData>();
  58. List<Dictionary<string, object>> dataList = new List<Dictionary<string, object>>();
  59. Other = new Dictionary<string, object>();
  60. int count = 0;
  61. List<Dictionary<string, object>> source = MerchantChangeSettlementCardRecordService.List(relationData, condition, out count, pageNum, pageSize);
  62. foreach (Dictionary<string, object> subdata in source)
  63. {
  64. Dictionary<string, object> curData = new Dictionary<string, object>();
  65. curData.Add("Id", int.Parse(subdata["Id"].ToString())); //Id
  66. curData.Add("MerchantId", int.Parse(subdata["MerchantId"].ToString())); //商户Id
  67. curData.Add("MerchantName", subdata["MerchantName"].ToString()); //商户名称
  68. curData.Add("Status", int.Parse(subdata["Status"].ToString())); //Status(1 待审核 3 审核拒绝 4 任务失效 5 审核通过))
  69. curData.Add("Remark", subdata["Remark"].ToString()); //审核备注
  70. curData.Add("CreateDate", subdata["CreateDate"].ToString() == "" ? "" : DateTime.Parse(subdata["CreateDate"].ToString()).ToString("yyyy-MM-dd HH:mm:ss")); //交易时间
  71. curData.Add("MchtNo", subdata["MchtNo"].ToString()); //商户号
  72. curData.Add("AccountName", subdata["AccountName"].ToString()); //开户名
  73. curData.Add("AccountNo", subdata["AccountNo"].ToString()); //卡号
  74. curData.Add("ZBankNo", subdata["ZBankNo"].ToString()); //支行号
  75. curData.Add("AlterType", subdata["AlterType"].ToString()); //结算类型
  76. curData.Add("AcctZBankCode", subdata["AcctZBankCode"].ToString()); //开户支行地区码
  77. curData.Add("IdCard", subdata["IdCard"].ToString()); //非法人身份证号
  78. curData.Add("AgentCardStartDate", subdata["AgentCardStartDate"].ToString()); //非法人身份证有效开始时间
  79. curData.Add("AgentCardEndDate", subdata["AgentCardEndDate"].ToString()); //非法人身份证有效结束时间
  80. curData.Add("TaskId", subdata["TaskId"].ToString()); //任务Id
  81. curData.Add("BankCard", subdata["BankCard"].ToString()); //银行卡正面照片
  82. curData.Add("OpenAccountLicenses", subdata["OpenAccountLicenses"].ToString()); //开户许可证
  83. curData.Add("PriLicAgreement", subdata["PriLicAgreement"].ToString()); //企业法人对私授权书
  84. curData.Add("AgentProtocol", subdata["AgentProtocol"].ToString()); //委托结算授权书
  85. curData.Add("AgentIdCardFront", subdata["AgentIdCardFront"].ToString()); //被委托人身份证人像面
  86. curData.Add("AgentIdCardBack", subdata["AgentIdCardBack"].ToString()); //被委托人身份证国徽面
  87. curData.Add("HoldAgentProtocol", subdata["HoldAgentProtocol"].ToString()); //法人手持委托结算授权书
  88. dataList.Add(curData);
  89. }
  90. Other.Add("Count", count); //总数
  91. //批量提交待审核数据
  92. RedisDbconn.Instance.AddList("UpdateMerchantChangeCardStatus", "1");
  93. return dataList;
  94. }
  95. #endregion
  96. #region 商户管理-银联查询商户结算卡信息
  97. [Authorize]
  98. public JsonResult UnionPaySearchSettlementCardInfo(string value)
  99. {
  100. value = PublicFunction.DesDecrypt(value); ;
  101. JsonData data = JsonMapper.ToObject(value);
  102. Dictionary<string, object> Obj = UnionPaySearchSettlementCardInfoDo(value);
  103. return Json(new AppResultJson() { Status = "1", Info = "", Data = Obj });
  104. }
  105. private Dictionary<string, object> UnionPaySearchSettlementCardInfoDo(string value)
  106. {
  107. JsonData data = JsonMapper.ToObject(value);
  108. int MerchantId = int.Parse(function.CheckInt(data["MerchantId"].ToString())); //商户Id
  109. Dictionary<string, object> Obj = new Dictionary<string, object>();
  110. var merchantAddInfo = MerchantAddInfoService.Query(MerchantId);
  111. var IsChange = 0;
  112. var check = MerchantChangeSettlementCardRecordService.Query(MerchantId);
  113. if (check.Id > 0) IsChange = 1;
  114. Obj.Add("AlterType", merchantAddInfo.AccountType); //结算类型(0 对公结算银行卡 法人1 对私结算银行卡 2 非法人结算)
  115. Obj.Add("AcctZBankAreas", merchantAddInfo.BankAddressCode); //开户支行地区
  116. Obj.Add("AcctZBankName", merchantAddInfo.BankName); //开户支行名称
  117. Obj.Add("MchtNo", merchantAddInfo.MchtNo); //商户号
  118. Obj.Add("AcctName", merchantAddInfo.AccountName); //开户名称
  119. Obj.Add("AccountNo", merchantAddInfo.AccountNumber); //卡号(0-对公 时填写对公账号,1-对私 时填写银行卡号)
  120. Obj.Add("IdCard", ""); //非法人身份证号(结算类型为2时必填,默认传空字符串)
  121. Obj.Add("AgentCardStartDate", ""); //非法人身份证有效开始时间(yyyy-MM-dd,结算类型为2时必填,默认传空字符串)
  122. Obj.Add("AgentCardEndDate", ""); //非法人身份证有效结束时间(yyyy-MM-dd,结算类型为2时必填,默认传空字符串)
  123. Obj.Add("BankCard", merchantAddInfo.BankCard); //银行卡正面照片(结算类型为1和2时必填,默认传空字符串)
  124. Obj.Add("OpenAccountLicenses", merchantAddInfo.OpenAccountLicenses); //开户许可证(企业类型商户或结算类型为0时必填,默认传空字符串)
  125. Obj.Add("PriLicAgreement", ""); //企业法人对私授权书(结算类型为1且为企业商户时必填,默认传空字符串)
  126. Obj.Add("AgentProtocol", ""); //委托结算授权书(结算类型为2时必填,默认传空字符串)
  127. Obj.Add("AgentIdCardFront", ""); //被委托人身份证人像面(结算类型为2时必填,默认传空字符串)
  128. Obj.Add("AgentIdCardBack", ""); //被委托人身份证国徽面(结算类型为2时必填,默认传空字符串)
  129. Obj.Add("HoldAgentProtocol", ""); //法人手持委托结算授权书(结算类型为2时必填,默认传空字符串)
  130. Obj.Add("MerchantId", MerchantId); //商户Id
  131. Obj.Add("MerchantName", merchantAddInfo.CertMerchantName); //商户名称
  132. Obj.Add("AccountType", merchantAddInfo.AccountType); //账户类型(0 对公 1 对私)
  133. Obj.Add("IsChange", IsChange); //是否已提交修改结算卡(0 否 1 是)
  134. Obj.Add("CreateDate", check.Id == 0 ? "" : check.CreateDate.Value.ToString("yyyy-MM-dd HH:mm:ss")); //提交修改时间
  135. Obj.Add("UpdateDate", check.Id == 0 ? "" : check.UpdateDate.Value.ToString("yyyy-MM-dd HH:mm:ss")); //提交更新时间
  136. Obj.Add("ChangeStatus", check.Status); //提交修改状态(1 待审核 3 审核拒绝 4 任务失效 5 审核通过)
  137. Obj.Add("Remark", check.Remark); //提交备注
  138. return Obj;
  139. }
  140. #endregion
  141. #region 商户管理-银联提交商户修改结算卡申请
  142. [Authorize]
  143. public JsonResult UnionPaySendChangeSettlementCard(string value)
  144. {
  145. value = PublicFunction.DesDecrypt(value);
  146. JsonData data = JsonMapper.ToObject(value);
  147. AppResultJson result = UnionPaySendChangeSettlementCardDo(value);
  148. return Json(new AppResultJson() { Status = result.Status, Info = result.Info, Data = result.Data });
  149. }
  150. private AppResultJson UnionPaySendChangeSettlementCardDo(string value)
  151. {
  152. JsonData data = JsonMapper.ToObject(value);
  153. int MerchantId = int.Parse(function.CheckInt(data["MerchantId"].ToString())); //商户Id
  154. string MerchantName = data["MerchantName"].ToString(); //商户名称
  155. string MchtNo = data["MchtNo"].ToString(); //商户号
  156. string AlterType = data["AlterType"].ToString(); //结算类型(0 对公结算银行卡 法人1 对私结算银行卡 2 非法人结算)
  157. string AcctZBankAreas = data["AcctZBankAreas"].ToString(); //开户支行地区
  158. string AcctZBankName = data["AcctZBankName"].ToString(); //开户支行名称
  159. string AcctName = data["AcctName"].ToString(); //开户名称
  160. string AccountNo = data["AccountNo"].ToString(); //卡号
  161. string IdCard = data["IdCard"].ToString(); //非法人身份证号(结算类型为2时必填,默认传空字符串)
  162. string AgentCardStartDate = data["AgentCardStartDate"].ToString(); //非法人身份证有效开始时间(yyyy-MM-dd,结算类型为2时必填,默认传空字符串)
  163. string AgentCardEndDate = data["AgentCardEndDate"].ToString(); //非法人身份证有效结束时间(yyyy-MM-dd,结算类型为2时必填,默认传空字符串)
  164. string BankCard = data["BankCard"].ToString(); //银行卡正面照片(结算类型为1和2时必填,默认传空字符串)
  165. string OpenAccountLicenses = data["OpenAccountLicenses"].ToString(); //开户许可证(企业类型商户或结算类型为0时必填,默认传空字符串)
  166. string PriLicAgreement = data["PriLicAgreement"].ToString(); //企业法人对私授权书(结算类型为1且为企业商户时必填,默认传空字符串)
  167. string AgentProtocol = data["AgentProtocol"].ToString(); //委托结算授权书(结算类型为2时必填,默认传空字符串)
  168. string AgentIdCardFront = data["AgentIdCardFront"].ToString(); //被委托人身份证人像面(结算类型为2时必填,默认传空字符串)
  169. string AgentIdCardBack = data["AgentIdCardBack"].ToString(); //被委托人身份证国徽面(结算类型为2时必填,默认传空字符串)
  170. string HoldAgentProtocol = data["HoldAgentProtocol"].ToString(); //法人手持委托结算授权书(结算类型为2时必填,默认传空字符串)
  171. Dictionary<string, object> Obj = new Dictionary<string, object>();
  172. //添加或修改银联商户修改结算卡记录
  173. var info = MerchantChangeSettlementCardRecordUtil.AddOrEditMerchantChangeSettlementCardRecord(MerchantId, MerchantName, Operator, AlterType, AcctZBankAreas, AcctZBankName, MchtNo, AcctName, AccountNo, IdCard, AgentCardStartDate, AgentCardEndDate, BankCard, OpenAccountLicenses, PriLicAgreement, AgentProtocol, AgentIdCardFront, AgentIdCardBack, HoldAgentProtocol);
  174. if (info == "success")
  175. {
  176. return new AppResultJson() { Status = "1", Info = "操作成功", Data = Obj };
  177. }
  178. else
  179. {
  180. return new AppResultJson() { Status = "-1", Info = info, Data = Obj };
  181. }
  182. }
  183. #endregion
  184. }
  185. }