autoCheck(); $this->autoPayCommission(); } public function autoCheck() { if ((int)admin_setting('commission_auto_check_enable', 1)) { Order::where('commission_status', 0) ->where('invite_user_id', '!=', NULL) ->where('status', 3) ->where('updated_at', '<=', strtotime('-3 day', time())) ->update([ 'commission_status' => 1 ]); } } public function autoPayCommission() { $orders = Order::where('commission_status', 1) ->where('invite_user_id', '!=', NULL) ->get(); foreach ($orders as $order) { DB::beginTransaction(); if (!$this->payHandle($order->invite_user_id, $order)) { DB::rollBack(); continue; } $order->commission_status = 2; if (!$order->save()) { DB::rollBack(); continue; } DB::commit(); } } public function payHandle($inviteUserId, Order $order) { $level = 3; if ((int)admin_setting('commission_distribution_enable', 0)) { $commissionShareLevels = [ 0 => (int)admin_setting('commission_distribution_l1'), 1 => (int)admin_setting('commission_distribution_l2'), 2 => (int)admin_setting('commission_distribution_l3') ]; } else { $commissionShareLevels = [ 0 => 100 ]; } for ($l = 0; $l < $level; $l++) { $inviter = User::find($inviteUserId); if (!$inviter) continue; if (!isset($commissionShareLevels[$l])) continue; $commissionBalance = $order->commission_balance * ($commissionShareLevels[$l] / 100); if (!$commissionBalance) continue; if ((int)admin_setting('withdraw_close_enable', 0)) { $inviter->balance = $inviter->balance + $commissionBalance; } else { $inviter->commission_balance = $inviter->commission_balance + $commissionBalance; } if (!$inviter->save()) { DB::rollBack(); return false; } if (!CommissionLog::create([ 'invite_user_id' => $inviteUserId, 'user_id' => $order->user_id, 'trade_no' => $order->trade_no, 'order_amount' => $order->total_amount, 'get_amount' => $commissionBalance ])) { DB::rollBack(); return false; } $inviteUserId = $inviter->invite_user_id; // update order actual commission balance $order->actual_commission_balance = $order->actual_commission_balance + $commissionBalance; } return true; } }