mirror of
https://github.com/v2board/v2board.git
synced 2025-01-11 08:39:09 +08:00
56 lines
1.8 KiB
PHP
Executable File
56 lines
1.8 KiB
PHP
Executable File
<?php
|
|
|
|
namespace App\Http\Controllers\User;
|
|
|
|
use App\Http\Controllers\Controller;
|
|
use App\Models\User;
|
|
use Illuminate\Http\Request;
|
|
use App\Models\Plan;
|
|
use Illuminate\Support\Facades\DB;
|
|
|
|
class PlanController extends Controller
|
|
{
|
|
public function fetch(Request $request)
|
|
{
|
|
$user = User::find($request->session()->get('id'));
|
|
if ($request->input('id')) {
|
|
$plan = Plan::where('id', $request->input('id'))->first();
|
|
if (!$plan) {
|
|
abort(500, __('Subscription plan does not exist'));
|
|
}
|
|
if ((!$plan->show && !$plan->renew) || (!$plan->show && $user->plan_id !== $plan->id)) {
|
|
abort(500, __('Subscription plan does not exist'));
|
|
}
|
|
return response([
|
|
'data' => $plan
|
|
]);
|
|
} else {
|
|
$counts = User::select(
|
|
DB::raw("plan_id"),
|
|
DB::raw("count(*) as count")
|
|
)
|
|
->where('plan_id', '!=', NULL)
|
|
->where(function ($query) {
|
|
$query->where('expired_at', '>=', time())
|
|
->orWhere('expired_at', NULL);
|
|
})
|
|
->groupBy("plan_id")
|
|
->get()
|
|
->keyBy('plan_id');
|
|
}
|
|
$plans = Plan::where('show', 1)
|
|
->orderBy('sort', 'ASC')
|
|
->get();
|
|
if (isset($counts)) {
|
|
foreach ($plans as $k => $v) {
|
|
if ($plans[$k]->capacity_limit === NULL) continue;
|
|
if (!isset($counts[$plans[$k]->id])) continue;
|
|
$plans[$k]->capacity_limit = $plans[$k]->capacity_limit - $counts[$plans[$k]->id]->count;
|
|
}
|
|
}
|
|
return response([
|
|
'data' => $plans
|
|
]);
|
|
}
|
|
}
|