Cash.php 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290
  1. <?php
  2. /**
  3. * 厦门云联储网络科技有限公司
  4. * https://www.baokuaiyun.com
  5. * Copyright (c) 2023 爆块云 All rights reserved.
  6. */
  7. namespace app\models;
  8. use Yii;
  9. use yii\db\ActiveRecord;
  10. use yii\behaviors\TimestampBehavior;
  11. /**
  12. * This is the model class for table "{{%cash}}".
  13. *
  14. * @property int $id
  15. * @property int $user_id 用户id
  16. * @property int $store_id 商城id
  17. * @property float $price 提现金额
  18. * @property int $status 申请状态 0--申请中 1--确认申请 2--已打款 3--驳回 5--余额通过
  19. * @property int $is_delete 是否删除
  20. * @property int|null $created_at 添加時間
  21. * @property int $pay_time 付款
  22. * @property int $type 支付方式 0--微信支付 1--支付宝 2--银行卡 3--余额
  23. * @property string|null $mobile 支付宝账号
  24. * @property string|null $name 支付宝姓名
  25. * @property string|null $bank_name 开户行名称
  26. * @property string|null $bank_branch 银行支行
  27. * @property int|null $pay_type 打款方式 0--之前未统计的 1--微信自动打款 2--手动打款
  28. * @property string|null $order_no 微信自动打款订单号
  29. * @property float $service_charge 提现手续费
  30. * @property int|null $cash_type 0、正常,1、自提点提现
  31. * @property int|null $updated_at 更新时间
  32. * @property int $md_id 门店id
  33. * @property int $wx_cash_status 微信转账状态:0无状态 1转账成功 2转账失败 3待确认 4转账中
  34. * @property string $wx_cash_error 微信转账失败错误原因
  35. */
  36. class Cash extends \yii\db\ActiveRecord
  37. {
  38. /**
  39. * {@inheritdoc}
  40. */
  41. public static function tableName()
  42. {
  43. return '{{%cash}}';
  44. }
  45. /**
  46. * 已删除
  47. */
  48. const IS_DELETE_YES = 1;
  49. /**
  50. * 未删除
  51. */
  52. const IS_DELETE_NO = 0;
  53. /**
  54. * 申请中
  55. */
  56. const STATUS_APPLY = 0;
  57. /**
  58. * 确认申请
  59. */
  60. const STATUS_CONFIRM = 1;
  61. /**
  62. * 已打款
  63. */
  64. const STATUS_GIVEN = 2;
  65. /**
  66. * 驳回
  67. */
  68. const STATUS_REFUSE = 3;
  69. /**
  70. * 手动打款
  71. */
  72. const STATUS_HAND = 4;
  73. /**
  74. * 余额通过
  75. */
  76. const STATUS_RECHARGE = 5;
  77. /**
  78. * 微信打款
  79. */
  80. const TYPE_WX = 0;
  81. /**
  82. * 支付宝打款
  83. */
  84. const TYPE_ALIPAY = 1;
  85. /**
  86. * 银行卡打款
  87. */
  88. const TYPE_BANK = 2;
  89. /**
  90. * 余额打款
  91. */
  92. const TYPE_RECHARGE = 3;
  93. /**
  94. * 之前未统计的
  95. */
  96. const PAY_TYPE_NO = 0;
  97. /**
  98. * 微信自动打款
  99. */
  100. const PAY_TYPE_WX = 1;
  101. /**
  102. * 手动拨款
  103. */
  104. const PAY_TYPE_HAND = 2;
  105. /**
  106. * 分销商
  107. */
  108. const IS_CASH_TYPE_SHARE = 0;
  109. /**
  110. * 自提点
  111. */
  112. const IS_CASH_TYPE_SHOP = 1;
  113. /**
  114. * 上门服务师傅分佣
  115. */
  116. const IS_CASH_TYPE_WORKER = 6;
  117. /**
  118. * 余额提现
  119. */
  120. const IS_CASH_TYPE_BALANCE = 7;
  121. /**
  122. * 区域代理佣金提现
  123. */
  124. const IS_CASH_TYPE_AREA_AGENT = 8;
  125. /**
  126. * 店铺内多商户提现
  127. */
  128. const IS_CASH_TYPE_MCH = 9;
  129. const WX_CASH_STATUS_INIT = 0;//初始态。 系统转账校验中
  130. const WX_CASH_STATUS_SUCCESS = 1;//成功
  131. const WX_CASH_STATUS_FAIL = 2;//失败
  132. const WX_CASH_STATUS_WAIT_PAY = 3;//待确认 。待商户确认, 符合免密条件时, 系统会自动扭转为转账中
  133. const WX_CASH_STATUS_PROCESSING = 4;//转账中。正在处理中,转账结果尚未明确
  134. /**
  135. * 微信转账状态
  136. */
  137. const WX_CASH_STATUS_ARR = [
  138. 'INIT' => 0,//初始态。 系统转账校验中
  139. 'SUCCESS' => 1,//成功
  140. 'FAIL' => 2,//失败
  141. 'WAIT_PAY' => 3,//待确认 。待商户确认, 符合免密条件时, 系统会自动扭转为转账中
  142. 'PROCESSING' => 4,//转账中。正在处理中,转账结果尚未明确
  143. ];
  144. const WX_CASH_FAIL_REASON = [
  145. "ACCOUNT_FROZEN" => "该用户账户被冻结",
  146. "REAL_NAME_CHECK_FAIL" => "收款人未实名认证,需要用户完成微信实名认证",
  147. "NAME_NOT_CORRECT" => "收款人姓名校验不通过,请核实信息",
  148. "OPENID_INVALID" => "Openid格式错误或者不属于商家公众账号",
  149. "TRANSFER_QUOTA_EXCEED" => "超过用户单笔收款额度,核实产品设置是否准确",
  150. "DAY_RECEIVED_QUOTA_EXCEED" => "超过用户单日收款额度,核实产品设置是否准确",
  151. "MONTH_RECEIVED_QUOTA_EXCEED" => "超过用户单月收款额度,核实产品设置是否准确",
  152. "DAY_RECEIVED_COUNT_EXCEED" => "超过用户单日收款次数,核实产品设置是否准确",
  153. "PRODUCT_AUTH_CHECK_FAIL" => "未开通该权限或权限被冻结,请核实产品权限状态",
  154. "OVERDUE_CLOSE" => "超过系统重试期,系统自动关闭",
  155. "ID_CARD_NOT_CORRECT" => "收款人身份证校验不通过,请核实信息",
  156. "ACCOUNT_NOT_EXIST" => "该用户账户不存在",
  157. "TRANSFER_RISK" => "该笔转账可能存在风险,已被微信拦截",
  158. "OTHER_FAIL_REASON_TYPE" => "其它失败原因",
  159. "REALNAME_ACCOUNT_RECEIVED_QUOTA_EXCEED" => "用户账户收款受限,请引导用户在微信支付查看详情",
  160. "RECEIVE_ACCOUNT_NOT_PERMMIT" => "未配置该用户为转账收款人,请在产品设置中调整,添加该用户为收款人",
  161. "PAYEE_ACCOUNT_ABNORMAL" => "用户账户收款异常,请联系用户完善其在微信支付的身份信息以继续收款",
  162. "PAYER_ACCOUNT_ABNORMAL" => "商户账户付款受限,可前往商户平台获取解除功能限制指引",
  163. "TRANSFER_SCENE_UNAVAILABLE" => "该转账场景暂不可用,请确认转账场景ID是否正确",
  164. "TRANSFER_SCENE_INVALID" => "你尚未获取该转账场景,请确认转账场景ID是否正确",
  165. "TRANSFER_REMARK_SET_FAIL" => "转账备注设置失败, 请调整后重新再试",
  166. "RECEIVE_ACCOUNT_NOT_CONFIGURE" => "请前往商户平台-商家转账到零钱-前往功能-转账场景中添加",
  167. "BLOCK_B2C_USERLIMITAMOUNT_BSRULE_MONTH" => "超出用户单月转账收款20w限额,本月不支持继续向该用户付款",
  168. "BLOCK_B2C_USERLIMITAMOUNT_MONTH" => "用户账户存在风险收款受限,本月不支持继续向该用户付款",
  169. "MERCHANT_REJECT" => "商户员工(转账验密人)已驳回转账",
  170. "MERCHANT_NOT_CONFIRM" => "商户员工(转账验密人)超时未验密"
  171. ];
  172. public static $status = [
  173. '待审核',
  174. '待打款',
  175. '已打款',
  176. '无效',
  177. '已打款',
  178. '已打款',
  179. ];
  180. public static $type = [
  181. self::TYPE_WX => '微信',
  182. self::TYPE_ALIPAY => '支付宝',
  183. self::TYPE_BANK => '银行卡',
  184. self::TYPE_RECHARGE => '余额',
  185. ];
  186. public function behaviors()
  187. {
  188. return [
  189. [
  190. 'class' => TimestampBehavior::class,
  191. 'attributes' => [
  192. ActiveRecord::EVENT_BEFORE_INSERT => ['created_at'],
  193. ActiveRecord::EVENT_BEFORE_UPDATE => ['updated_at']
  194. ]
  195. ]
  196. ];
  197. }
  198. /**
  199. * {@inheritdoc}
  200. */
  201. public function rules()
  202. {
  203. return [
  204. [['user_id', 'store_id', 'pay_time'], 'required'],
  205. [['md_id', 'mch_id', 'user_id', 'saas_id', 'store_id', 'status', 'is_delete', 'created_at', 'pay_time', 'type', 'pay_type', 'cash_type', 'updated_at'], 'integer'],
  206. [['price', 'service_charge'], 'number'],
  207. [['mobile', 'name', 'order_no', 'bank_branch'], 'string', 'max' => 255],
  208. [['bank_name'], 'string', 'max' => 30],
  209. ];
  210. }
  211. /**
  212. * {@inheritdoc}
  213. */
  214. public function attributeLabels()
  215. {
  216. return [
  217. 'id' => 'ID',
  218. 'user_id' => '用户id',
  219. 'saas_id' => '商盟用户id',
  220. 'store_id' => '商城id',
  221. 'price' => '提现金额',
  222. 'status' => '申请状态 0--申请中 1--确认申请 2--已打款 3--驳回 5--余额通过',
  223. 'is_delete' => '是否删除',
  224. 'created_at' => '添加時間',
  225. 'pay_time' => '付款',
  226. 'type' => '支付方式 0--微信支付 1--支付宝 2--银行卡 3--余额',
  227. 'mobile' => '支付宝账号',
  228. 'name' => '支付宝姓名',
  229. 'bank_name' => '开户行名称',
  230. 'pay_type' => '打款方式 0--之前未统计的 1--微信自动打款 2--手动打款',
  231. 'order_no' => '微信自动打款订单号',
  232. 'service_charge' => '提现手续费',
  233. 'cash_type' => '0、正常,1、自提点提现',
  234. 'updated_at' => '更新时间',
  235. 'bank_branch' => '银行支行',
  236. ];
  237. }
  238. public static function getServiceMoney($cash)
  239. {
  240. if($cash['service_charge'] == 0){
  241. $price = $cash['price'];
  242. }else{
  243. $cashPrice = floatval($cash['price']);
  244. $price = $cashPrice * (100 - $cash['service_charge']) / 100;
  245. }
  246. return round($price, 2);
  247. }
  248. public static function getTypeName($item)
  249. {
  250. if(($item instanceof self) || is_array($item)){
  251. $item = $item['type'];
  252. }
  253. return self::$type[$item] ?? '';
  254. }
  255. public static function getStatusName($item)
  256. {
  257. if(($item instanceof self) || is_array($item)){
  258. $item = $item['status'];
  259. }
  260. return self::$status[$item] ?? '';
  261. }
  262. }