getMessage()); DB::rollback(); //WithdrawCashService::updateWithdrawCashStatus($withdraw_cash_id, $userId, -1, $remark, $transactionSerialNumber); } } catch (\Exception $e){ //WithdrawCashService::updateWithdrawCashStatus($withdraw_cash_id, $userId, -1, $e->getMessage(), ''); } return true; } else { return false; } } /** * 创建人工打款 * @param $userId * @param $withdrawCashId * @param $amount * @param $remark * @param $tradeNo * @param int $amount_person * @return bool */ public static function makePersonMadePayment($userId, $withdrawCashId, $amount, $remark, $tradeNo, $amount_person = 0) { $withdrawCash = WithdrawCashService::getWithdrawCash($withdrawCashId); if(empty($withdrawCash)) { return false; } $channelId = $withdrawCash['distribution_channel_id']; $isCompany = $withdrawCash['is_company']; $isCompanyName = ""; if($isCompany == 0) { $isCompanyName = "对私"; } else if($isCompany == 1) { $isCompanyName = "对公"; } $remark = "[".$isCompanyName."]".$remark; DB::beginTransaction(); try { //插入人工打款记录 $payment = PaymentService::addPayment($withdrawCashId, $amount, $remark, "人工", $tradeNo, WithdrawCashService::getWithdrawCashStatusStr(32), "", $isCompany, $amount_person); if(!empty($payment)) { //更新当然提现记录为 人工打款成功状态 WithdrawCashService::updateWithdrawCashStatus($withdrawCashId, $userId, 32, $remark); $IgnoreSources = [config('common.officialpay'), config('common.tonglianpay')]; //优先 官方支付 通联支付 --[支付通道自动清算] foreach ($IgnoreSources as $IgnoreSource) { if($amount > 0) { $tempForeach = FinanceMerchantStatService::getFinanceMerchantStatSingle($channelId, $IgnoreSource); if($tempForeach && isset($tempForeach['distribution_channel_id']) && $tempForeach['distribution_channel_id']) { if($tempForeach['enable_withdrawal_amount'] >= $amount) { //当前通道可提现的余额 打款总额, FinanceMerchantStatService::createOrUpdate($tempForeach['distribution_channel_id'], $tempForeach['pay_merchant_source'], -$amount); $amount = 0; } else { //当前通道可提现的余额变为 0 FinanceMerchantStatService::createOrUpdate($tempForeach['distribution_channel_id'], $tempForeach['pay_merchant_source'], -$tempForeach['enable_withdrawal_amount']); $amount = $amount - $tempForeach['enable_withdrawal_amount']; } } } else { break; } } if($amount > 0) { //更新第三方 支付通道的可提现金额 $financeMerchantStats = FinanceMerchantStatService::getFinanceMerchantStatListIgnoreSourceArray($channelId, $IgnoreSources); if($financeMerchantStats && !empty($financeMerchantStats) && sizeof($financeMerchantStats) > 0) { //钱少的支付渠道优先 $payAmount = $amount;//总打款金额 if(is_array($financeMerchantStats) && !emptyempty($financeMerchantStats)){ foreach ($financeMerchantStats as $financeMerchantStat) { if($financeMerchantStat && isset($financeMerchantStat['distribution_channel_id']) && $financeMerchantStat['distribution_channel_id']) { $tempAmount = $financeMerchantStat['enable_withdrawal_amount'] - $payAmount; if($tempAmount < 0) { //更新 FinanceMerchantStat FinanceMerchantStatService::createOrUpdate($financeMerchantStat['distribution_channel_id'], $financeMerchantStat['pay_merchant_source'], -$payAmount); //更新 LiquidatedStat LiquidatedStatService::createOrUpdate($financeMerchantStat['pay_merchant_source'], $payAmount); //更新 Liquidation LiquidationService::addLiquidation($channelId, $financeMerchantStat['pay_merchant_source'], $payAmount, $payment['id'], $remark); $payAmount = -$tempAmount; } else { //更新 FinanceMerchantStat FinanceMerchantStatService::createOrUpdate($financeMerchantStat['distribution_channel_id'], $financeMerchantStat['pay_merchant_source'], -$payAmount); //更新 LiquidatedStat LiquidatedStatService::createOrUpdate($financeMerchantStat['pay_merchant_source'], $payAmount); //更新 Liquidation LiquidationService::addLiquidation($channelId, $financeMerchantStat['pay_merchant_source'], $payAmount, $payment['id'], $remark); break; } } } } } } } DB::commit(); } catch (\Exception $e){ Log::error("人工打款失败日志" . $e->getMessage()); DB::rollback(); return false; } return true; } /** * 保存打款信息 * @param $withdraw_cash_id * @param $amount * @param $remark * @param $pay_merchant_source 支付渠道 * @param $trade_no 交易流水号 * @param $status 打款状态 * @param $pay_merchant_source_msg 支付通道返回信息 * @param int $is_company 0:私人; 1:公司 * @param int $amount_person 人工打款金额 * @return mixed */ public static function addPayment($withdraw_cash_id, $amount, $remark, $pay_merchant_source, $trade_no, $status, $pay_merchant_source_msg, $is_company = 0, $amount_person = 0) { return Payment::addPayment($withdraw_cash_id, $amount, $remark, $pay_merchant_source, $trade_no, $status, $pay_merchant_source_msg, $is_company, $amount_person); } /** * 更新打款状态 * @param $id * @param String $status * @param $pay_merchant_source_msg * @param $pay_merchant_source_result * @return mixed */ public static function updatePaymentStatus($id, $status = '', $pay_merchant_source_msg, $pay_merchant_source_result) { return Payment::updatePaymentStatus($id, $status, $pay_merchant_source_msg, $pay_merchant_source_result); } /** * 获取打款信息列表 * @param string $withdraw_cash_id 可不传 * @param string $start_time 可不传 * @param string $end_time 可不传 * @param string $status 状态 可不传 * @param bool $is_all * @return mixed */ public static function getPaymentList($withdraw_cash_id = '', $start_time = '', $end_time = '', $status = '', $is_all=false) { $payments = Payment::getList($withdraw_cash_id, $start_time, $end_time, $status, $is_all); return $payments; } /** * 财务对账 * @param array $params[] * withdraw_cash_id : 提现ID 可选 * channel_id:渠道ID 可选 * channel_name:渠道名称 可选 * account_name: 打款人姓名 * start_date:开始时间 可选 * end_date:结束时间 可选 * search_name: 搜索名称 * is_company: 0:私人; 1:公司 * @param string $statusIn $statusIn 状态 查看接口 WithdrawCashService::getWithdrawCashStatusList 可不传 * @return mixed */ public static function getPaymentDetailList($params=[], $statusIn = '') { if(is_numeric($statusIn)) { $params['status'] = WithdrawCashService::getWithdrawCashStatusStrList($statusIn); } $payments = Payment::getListDetail($params); return $payments; } /** * 更新打款状态 * @param $id id * @param $status * @return mixed */ public static function updateSimplePaymentStatus($id, $status) { return Payment::updateSimplePaymentStatus($id,$status); } }