ScanPayModel.cs 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  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. [JsonObject(NamingStrategyType = typeof(SnakeCaseNamingStrategy))]
  8. public class ScanPayModel
  9. {
  10. /// <summary>
  11. /// 商户订单号,64个字符以内、可包含字母、数字、下划线;需保证在商户端不重复
  12. /// </summary>
  13. [StringLength(64, ErrorMessage = "商户订单号最大长度为64位")]
  14. [Required(ErrorMessage = "请设置商户订单号")]
  15. public string OutTradeNo { get; set; }
  16. /// <summary>
  17. /// 卖家支付宝用户ID。 如果该值为空,则默认为商户签约账号对应的支付宝用户ID
  18. /// </summary>
  19. [StringLength(28, ErrorMessage = "卖家支付宝用户ID最大长度为28位")]
  20. public string SellerId { get; set; }
  21. /// <summary>
  22. /// 订单总金额,单位为元
  23. /// </summary>
  24. [Required(ErrorMessage = "请设置订单总金额")]
  25. public double TotalAmount { get; set; }
  26. /// <summary>
  27. /// 可打折金额. 参与优惠计算的金额,单位为元,精确到小数点后两位,取值范围[0.01,100000000] 如果该值未传入,但传入了【订单总金额】,【不可打折金额】则该值默认为【订单总金额】-【不可打折金额】
  28. /// </summary>
  29. public double DiscountableAmount { get; set; }
  30. /// <summary>
  31. /// 订单标题
  32. /// </summary>
  33. [StringLength(256, ErrorMessage = "订单标题最大长度为256位")]
  34. [Required(ErrorMessage = "请设置订单标题")]
  35. public string Subject { get; set; }
  36. /// <summary>
  37. /// 订单包含的商品列表信息
  38. /// </summary>
  39. public List<Goods> GoodsDetail { get; set; }
  40. /// <summary>
  41. /// 订单描述
  42. /// </summary>
  43. [StringLength(128, ErrorMessage = "商户订单号最大长度为128位")]
  44. public string Body { get; set; }
  45. /// <summary>
  46. /// 卖家端自定义的的操作员编号
  47. /// </summary>
  48. [StringLength(28, ErrorMessage = "卖家端自定义的的操作员编号最大长度为28位")]
  49. public string OperatorId { get; set; }
  50. /// <summary>
  51. /// 商户门店编号。该参数用于请求参数中以区分各门店,非必传项。
  52. /// </summary>
  53. [StringLength(32, ErrorMessage = "商户门店编号最大长度为32位")]
  54. public string StoreId { get; set; }
  55. /// <summary>
  56. /// 禁用渠道,用户不可用指定渠道支付,当有多个渠道时用“,”分隔
  57. /// 注:与enable_pay_channels互斥 https://docs.open.alipay.com/#qdsm
  58. /// </summary>
  59. [StringLength(128, ErrorMessage = "禁用渠道最大长度为128位")]
  60. public string DisablePayChannels { get; set; }
  61. /// <summary>
  62. /// 可用渠道,用户只能在指定渠道范围内支付,当有多个渠道时用“,”分隔
  63. /// 注:与disable_pay_channels互斥 https://docs.open.alipay.com/#qdsm
  64. /// </summary>
  65. [StringLength(128, ErrorMessage = "可用渠道最大长度为128位")]
  66. public string EnablePayChannels { get; set; }
  67. /// <summary>
  68. /// 商户的终端编号
  69. /// </summary>
  70. [StringLength(32, ErrorMessage = "终端编号最大长度为32位")]
  71. public string TerminalId { get; set; }
  72. /// <summary>
  73. /// 业务扩展参数,详见业务扩展参数说明 https://docs.open.alipay.com/#kzcs
  74. /// </summary>
  75. public ExtendParam ExtendParams { get; set; }
  76. /// <summary>
  77. /// 该笔订单允许的最晚付款时间,逾期将关闭交易。
  78. /// 取值范围:1m~15d。m-分钟,h-小时,d-天,1c-当天(1c-当天的情况下,无论交易何时创建,都在0点关闭)。
  79. /// 该参数数值不接受小数点, 如 1.5h,可转换为 90m。该参数在请求到支付宝时开始计时。
  80. /// </summary>
  81. [StringLength(6, ErrorMessage = "该笔订单允许的最晚付款时间最大长度为6位")]
  82. public string TimeoutExpress { get; set; }
  83. /// <summary>
  84. /// 商户传入业务信息,具体值要和支付宝约定
  85. /// 将商户传入信息分发给相应系统,应用于安全,营销等参数直传场景
  86. /// 格式为json格式
  87. /// </summary>
  88. [StringLength(512, ErrorMessage = "商户传入业务信息最大长度为512位")]
  89. public string BusinessParams { get; set; }
  90. }
  91. }