environment('testing')) { return $next($request); } if (in_array($request->route()->getName(), self::ALLOWED_ROUTES)) { return $next($request); } if ( config('app.self_hosted') && $request->user() && !$this->isInitialSetupComplete() ) { return response()->json([ 'message' => 'You must change your credentials when in self-hosted mode', 'type' => 'error', ], Response::HTTP_FORBIDDEN); } return $next($request); } private function isInitialSetupComplete(): bool { return (bool) Cache::remember('initial_user_setup_complete', 60 * 60, function () { $maxUserId = $this->getMaxUserId(); if ($maxUserId === 0) { return false; } return !User::where('email', 'admin@opnform.com')->exists(); }); } private function getMaxUserId(): int { return (int) Cache::remember('max_user_id', 60 * 60, function () { return User::max('id') ?? 0; }); } }