BarcodePayModel.cs 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. using System.Collections.Generic;
  2. using System.ComponentModel.DataAnnotations;
  3. using Newtonsoft.Json;
  4. using Newtonsoft.Json.Serialization;
  5. namespace PaySharp.Alipay.Domain
  6. {
  7. /// <summary>
  8. /// 条码支付模型
  9. /// </summary>
  10. [JsonObject(NamingStrategyType = typeof(SnakeCaseNamingStrategy))]
  11. public class BarcodePayModel
  12. {
  13. /// <summary>
  14. /// 商户订单号,64个字符以内、可包含字母、数字、下划线;需保证在商户端不重复
  15. /// </summary>
  16. [StringLength(64, ErrorMessage = "商户订单号最大长度为64位")]
  17. [Required(ErrorMessage = "请设置商户订单号")]
  18. public string OutTradeNo { get; set; }
  19. /// <summary>
  20. /// 支付场景
  21. /// </summary>
  22. public string Scene => "bar_code";
  23. /// <summary>
  24. /// 支付授权码,25~30开头的长度为16~24位的数字,实际字符串长度以开发者获取的付款码长度为准
  25. /// </summary>
  26. [StringLength(32, ErrorMessage = "支付授权码最大长度为32位")]
  27. public string AuthCode { get; set; }
  28. /// <summary>
  29. /// 销售产品码,与支付宝签约的产品码名称。
  30. /// </summary>
  31. public string ProductCode => "FACE_TO_FACE_PAYMENT";
  32. /// <summary>
  33. /// 订单标题
  34. /// </summary>
  35. [StringLength(256, ErrorMessage = "订单标题最大长度为256位")]
  36. [Required(ErrorMessage = "请设置订单标题")]
  37. public string Subject { get; set; }
  38. /// <summary>
  39. /// 买家的支付宝用户id,如果为空,会从传入了码值信息中获取买家ID
  40. /// </summary>
  41. [StringLength(28, ErrorMessage = "买家的支付宝用户id最大长度为28位")]
  42. public string BuyerId { get; set; }
  43. /// <summary>
  44. /// 卖家支付宝用户号,如果该值为空,则默认为商户签约账号对应的支付宝用户ID
  45. /// </summary>
  46. [StringLength(28, ErrorMessage = "卖家支付宝用户号最大长度为28位")]
  47. public string SellerId { get; set; }
  48. /// <summary>
  49. /// 订单总金额,单位为元
  50. /// </summary>
  51. [Required(ErrorMessage = "请设置订单总金额")]
  52. public double TotalAmount { get; set; }
  53. /// <summary>
  54. /// 标价币种, total_amount 对应的币种单位。支持英镑:GBP、港币:HKD、美元:USD、新加坡元:SGD、日元:JPY、加拿大元:CAD、澳元:AUD、欧元:EUR、新西兰元:NZD、韩元:KRW、泰铢:THB、瑞士法郎:CHF、瑞典克朗:SEK、丹麦克朗:DKK、挪威克朗:NOK、马来西亚林吉特:MYR、印尼卢比:IDR、菲律宾比索:PHP、毛里求斯卢比:MUR、以色列新谢克尔:ILS、斯里兰卡卢比:LKR、俄罗斯卢布:RUB、阿联酋迪拉姆:AED、捷克克朗:CZK、南非兰特:ZAR、人民币:CNY
  55. /// </summary>
  56. [StringLength(8, ErrorMessage = "标价币种最大长度为8位")]
  57. public string TransCurrency { get; set; }
  58. /// <summary>
  59. /// 商户指定的结算币种,支持英镑:GBP、港币:HKD、美元:USD、新加坡元:SGD、日元:JPY、加拿大元:CAD、澳元:AUD、欧元:EUR、新西兰元:NZD、韩元:KRW、泰铢:THB、瑞士法郎:CHF、瑞典克朗:SEK、丹麦克朗:DKK、挪威克朗:NOK、马来西亚林吉特:MYR、印尼卢比:IDR、菲律宾比索:PHP、毛里求斯卢比:MUR、以色列新谢克尔:ILS、斯里兰卡卢比:LKR、俄罗斯卢布:RUB、阿联酋迪拉姆:AED、捷克克朗:CZK、南非兰特:ZAR、人民币:CNY
  60. /// </summary>
  61. [StringLength(8, ErrorMessage = "结算币种最大长度为8位")]
  62. public string SettleCurrency { get; set; }
  63. /// <summary>
  64. /// 参与优惠计算的金额,单位为元,精确到小数点后两位,取值范围[0.01,100000000]。
  65. /// 如果该值未传入,但传入了【订单总金额】和【不可打折金额】,则该值默认为【订单总金额】-【不可打折金额】
  66. /// </summary>
  67. public double DiscountableAmount { get; set; }
  68. /// <summary>
  69. /// 订单描述
  70. /// </summary>
  71. [StringLength(128, ErrorMessage = "商户订单号最大长度为128位")]
  72. public string Body { get; set; }
  73. /// <summary>
  74. /// 订单包含的商品列表信息
  75. /// </summary>
  76. public List<Goods> GoodsDetail { get; set; }
  77. /// <summary>
  78. /// 卖家端自定义的的操作员编号
  79. /// </summary>
  80. [StringLength(28, ErrorMessage = "卖家端自定义的的操作员编号最大长度为28位")]
  81. public string OperatorId { get; set; }
  82. /// <summary>
  83. /// 商户门店编号。该参数用于请求参数中以区分各门店,非必传项。
  84. /// </summary>
  85. [StringLength(32, ErrorMessage = "商户门店编号最大长度为32位")]
  86. public string StoreId { get; set; }
  87. /// <summary>
  88. /// 商户的终端编号
  89. /// </summary>
  90. [StringLength(32, ErrorMessage = "终端编号最大长度为32位")]
  91. public string TerminalId { get; set; }
  92. /// <summary>
  93. /// 业务扩展参数,详见业务扩展参数说明 https://docs.open.alipay.com/#kzcs
  94. /// </summary>
  95. public ExtendParam ExtendParams { get; set; }
  96. /// <summary>
  97. /// 该笔订单允许的最晚付款时间,逾期将关闭交易。
  98. /// 取值范围:1m~15d。m-分钟,h-小时,d-天,1c-当天(1c-当天的情况下,无论交易何时创建,都在0点关闭)。
  99. /// 该参数数值不接受小数点, 如 1.5h,可转换为 90m。该参数在请求到支付宝时开始计时。
  100. /// </summary>
  101. [StringLength(6, ErrorMessage = "该笔订单允许的最晚付款时间最大长度为6位")]
  102. public string TimeoutExpress { get; set; }
  103. /// <summary>
  104. /// 预授权确认模式,授权转交易请求中传入,适用于预授权转交易业务使用,目前只支持PRE_AUTH(预授权产品码)
  105. /// COMPLETE:转交易支付完成结束预授权,解冻剩余金额; NOT_COMPLETE:转交易支付完成不结束预授权,不解冻剩余金额
  106. /// </summary>
  107. [StringLength(32, ErrorMessage = "预授权确认模式最大长度为32位")]
  108. public string AuthConfirmMode { get; set; }
  109. /// <summary>
  110. /// 商户传入终端设备相关信息,具体值要和支付宝约定
  111. /// </summary>
  112. [StringLength(2048, ErrorMessage = "商户传入终端设备相关信息最大长度为2048位")]
  113. public string TerminalParams { get; set; }
  114. }
  115. }