2023-11-17 01:44:01 -05:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Http\Controllers\V1\User;
|
|
|
|
|
2023-12-04 07:40:49 -05:00
|
|
|
use App\Exceptions\ApiException;
|
2023-11-17 01:44:01 -05:00
|
|
|
use App\Http\Controllers\Controller;
|
|
|
|
use App\Models\CommissionLog;
|
|
|
|
use App\Models\InviteCode;
|
|
|
|
use App\Models\Order;
|
|
|
|
use App\Models\User;
|
|
|
|
use App\Utils\Helper;
|
|
|
|
use Illuminate\Http\Request;
|
|
|
|
|
|
|
|
class InviteController extends Controller
|
|
|
|
{
|
|
|
|
public function save(Request $request)
|
|
|
|
{
|
|
|
|
if (InviteCode::where('user_id', $request->user['id'])->where('status', 0)->count() >= admin_setting('invite_gen_limit', 5)) {
|
2023-12-06 15:01:32 -05:00
|
|
|
return $this->fail([400,__('The maximum number of creations has been reached')]);
|
2023-11-17 01:44:01 -05:00
|
|
|
}
|
|
|
|
$inviteCode = new InviteCode();
|
|
|
|
$inviteCode->user_id = $request->user['id'];
|
|
|
|
$inviteCode->code = Helper::randomChar(8);
|
2023-12-06 15:01:32 -05:00
|
|
|
return $this->success($inviteCode->save());
|
2023-11-17 01:44:01 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
public function details(Request $request)
|
|
|
|
{
|
|
|
|
$current = $request->input('current') ? $request->input('current') : 1;
|
|
|
|
$pageSize = $request->input('page_size') >= 10 ? $request->input('page_size') : 10;
|
|
|
|
$builder = CommissionLog::where('invite_user_id', $request->user['id'])
|
|
|
|
->where('get_amount', '>', 0)
|
|
|
|
->select([
|
|
|
|
'id',
|
|
|
|
'trade_no',
|
|
|
|
'order_amount',
|
|
|
|
'get_amount',
|
|
|
|
'created_at'
|
|
|
|
])
|
|
|
|
->orderBy('created_at', 'DESC');
|
|
|
|
$total = $builder->count();
|
|
|
|
$details = $builder->forPage($current, $pageSize)
|
|
|
|
->get();
|
|
|
|
return response([
|
|
|
|
'data' => $details,
|
|
|
|
'total' => $total
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function fetch(Request $request)
|
|
|
|
{
|
|
|
|
$codes = InviteCode::where('user_id', $request->user['id'])
|
|
|
|
->where('status', 0)
|
|
|
|
->get();
|
|
|
|
$commission_rate = admin_setting('invite_commission', 10);
|
|
|
|
$user = User::find($request->user['id']);
|
|
|
|
if ($user->commission_rate) {
|
|
|
|
$commission_rate = $user->commission_rate;
|
|
|
|
}
|
|
|
|
$uncheck_commission_balance = (int)Order::where('status', 3)
|
|
|
|
->where('commission_status', 0)
|
|
|
|
->where('invite_user_id', $request->user['id'])
|
|
|
|
->sum('commission_balance');
|
|
|
|
if (admin_setting('commission_distribution_enable', 0)) {
|
|
|
|
$uncheck_commission_balance = $uncheck_commission_balance * (admin_setting('commission_distribution_l1') / 100);
|
|
|
|
}
|
|
|
|
$stat = [
|
|
|
|
//已注册用户数
|
|
|
|
(int)User::where('invite_user_id', $request->user['id'])->count(),
|
|
|
|
//有效的佣金
|
|
|
|
(int)CommissionLog::where('invite_user_id', $request->user['id'])
|
|
|
|
->sum('get_amount'),
|
|
|
|
//确认中的佣金
|
|
|
|
$uncheck_commission_balance,
|
|
|
|
//佣金比例
|
|
|
|
(int)$commission_rate,
|
|
|
|
//可用佣金
|
|
|
|
(int)$user->commission_balance
|
|
|
|
];
|
2023-12-06 15:01:32 -05:00
|
|
|
$data = [
|
2023-11-17 01:44:01 -05:00
|
|
|
'data' => [
|
|
|
|
'codes' => $codes,
|
|
|
|
'stat' => $stat
|
|
|
|
]
|
2023-12-06 15:01:32 -05:00
|
|
|
];
|
|
|
|
return $this->success($data);
|
2023-11-17 01:44:01 -05:00
|
|
|
}
|
|
|
|
}
|