v2board/app/Http/Controllers/V1/User/InviteController.php

89 lines
3.0 KiB
PHP
Raw Normal View History

2019-10-29 15:33:36 +08:00
<?php
2023-06-12 02:32:49 +08:00
namespace App\Http\Controllers\V1\User;
2019-10-29 15:33:36 +08:00
use App\Http\Controllers\Controller;
2022-02-07 14:37:04 +08:00
use App\Models\CommissionLog;
2019-10-29 15:33:36 +08:00
use App\Models\InviteCode;
2023-06-12 02:32:49 +08:00
use App\Models\Order;
use App\Models\User;
2019-10-29 15:33:36 +08:00
use App\Utils\Helper;
2023-06-12 02:32:49 +08:00
use Illuminate\Http\Request;
2019-10-29 15:33:36 +08:00
class InviteController extends Controller
{
2020-01-11 13:36:52 +08:00
public function save(Request $request)
{
2022-07-19 03:11:36 +08:00
if (InviteCode::where('user_id', $request->user['id'])->where('status', 0)->count() >= config('v2board.invite_gen_limit', 5)) {
2021-06-12 00:56:39 +08:00
abort(500, __('The maximum number of creations has been reached'));
2019-10-29 15:33:36 +08:00
}
$inviteCode = new InviteCode();
2022-07-19 03:11:36 +08:00
$inviteCode->user_id = $request->user['id'];
2019-10-29 15:33:36 +08:00
$inviteCode->code = Helper::randomChar(8);
return response([
'data' => $inviteCode->save()
]);
}
2020-01-11 13:36:52 +08: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();
2019-11-29 00:40:41 +08:00
return response([
'data' => $details,
'total' => $total
2019-11-29 00:40:41 +08:00
]);
}
2020-01-11 13:36:52 +08:00
public function fetch(Request $request)
{
2022-07-19 03:11:36 +08:00
$codes = InviteCode::where('user_id', $request->user['id'])
2019-10-29 15:33:36 +08:00
->where('status', 0)
->get();
2020-03-15 20:30:00 +08:00
$commission_rate = config('v2board.invite_commission', 10);
2022-07-19 03:11:36 +08:00
$user = User::find($request->user['id']);
2019-11-29 00:24:35 +08:00
if ($user->commission_rate) {
$commission_rate = $user->commission_rate;
}
2022-10-29 14:23:51 +08:00
$uncheck_commission_balance = (int)Order::where('status', 3)
->where('commission_status', 0)
->where('invite_user_id', $request->user['id'])
->sum('commission_balance');
if (config('v2board.commission_distribution_enable', 0)) {
$uncheck_commission_balance = $uncheck_commission_balance * (config('v2board.commission_distribution_l1') / 100);
}
2019-10-29 15:33:36 +08:00
$stat = [
//已注册用户数
2022-07-19 03:11:36 +08:00
(int)User::where('invite_user_id', $request->user['id'])->count(),
2019-10-29 15:33:36 +08:00
//有效的佣金
2022-10-29 14:23:51 +08:00
(int)CommissionLog::where('invite_user_id', $request->user['id'])
->sum('get_amount'),
2019-10-29 15:33:36 +08:00
//确认中的佣金
2022-10-29 14:23:51 +08:00
$uncheck_commission_balance,
2019-11-29 00:24:35 +08:00
//佣金比例
2020-01-30 16:59:52 +08:00
(int)$commission_rate,
//可用佣金
(int)$user->commission_balance
2019-10-29 15:33:36 +08:00
];
return response([
'data' => [
'codes' => $codes,
'stat' => $stat
]
]);
}
}