mirror of
https://github.com/Bubka/2FAuth.git
synced 2025-01-07 15:00:17 +01:00
115 lines
3.9 KiB
PHP
115 lines
3.9 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers;
|
|
|
|
use App\Facades\Settings;
|
|
use App\Notifications\TestEmailSettingNotification;
|
|
use App\Services\ReleaseRadarService;
|
|
use Illuminate\Http\Request;
|
|
use Illuminate\Support\Carbon;
|
|
use Illuminate\Support\Facades\Artisan;
|
|
use Illuminate\Support\Facades\DB;
|
|
use Illuminate\Support\Facades\Log;
|
|
|
|
class SystemController extends Controller
|
|
{
|
|
/**
|
|
* Get detailed information about the current installation
|
|
*
|
|
* @return \Illuminate\Http\JsonResponse
|
|
*/
|
|
public function infos(Request $request)
|
|
{
|
|
$infos = [];
|
|
$infos['common']['Date'] = date(DATE_RFC2822);
|
|
$infos['common']['userAgent'] = $request->header('user-agent');
|
|
// App info
|
|
$infos['common']['Version'] = config('2fauth.version');
|
|
$infos['common']['Environment'] = config('app.env');
|
|
$infos['common']['Install path'] = '/' . config('2fauth.config.appSubdirectory');
|
|
$infos['common']['Debug'] = var_export(config('app.debug'), true);
|
|
$infos['common']['Cache driver'] = config('cache.default');
|
|
$infos['common']['Log channel'] = config('logging.default');
|
|
$infos['common']['Log level'] = env('LOG_LEVEL');
|
|
$infos['common']['DB driver'] = DB::getDriverName();
|
|
// PHP info
|
|
$infos['common']['PHP version'] = PHP_VERSION;
|
|
$infos['common']['Operating system'] = PHP_OS;
|
|
$infos['common']['interface'] = PHP_SAPI;
|
|
// Auth & Security infos
|
|
$infos['common']['Auth guard'] = config('auth.defaults.guard');
|
|
if ($infos['common']['Auth guard'] === 'reverse-proxy-guard') {
|
|
$infos['common']['Auth proxy logout url'] = config('2fauth.config.proxyLogoutUrl');
|
|
$infos['common']['Auth proxy header for user'] = config('auth.auth_proxy_headers.user');
|
|
$infos['common']['Auth proxy header for email'] = config('auth.auth_proxy_headers.email');
|
|
}
|
|
$infos['common']['webauthn user verification'] = config('webauthn.user_verification');
|
|
$infos['common']['Trusted proxies'] = config('2fauth.config.trustedProxies') ?: 'none';
|
|
$infos['common']['lastRadarScan'] = Carbon::parse(Settings::get('lastRadarScan'))->format('Y-m-d H:i:s');
|
|
|
|
return response()->json($infos);
|
|
}
|
|
|
|
/**
|
|
* Get latest release
|
|
*
|
|
* @return \Illuminate\Http\JsonResponse
|
|
*/
|
|
public function latestRelease(Request $request, ReleaseRadarService $releaseRadar)
|
|
{
|
|
$release = $releaseRadar->manualScan();
|
|
|
|
return response()->json(['newRelease' => $release]);
|
|
}
|
|
|
|
/**
|
|
* Send a test email
|
|
*
|
|
* @return \Illuminate\Http\JsonResponse
|
|
*/
|
|
public function testEmail(Request $request)
|
|
{
|
|
try {
|
|
$request->user()->notify(new TestEmailSettingNotification());
|
|
} catch (\Throwable $th) {
|
|
Log::error($th->getMessage());
|
|
}
|
|
|
|
return response()->json(['message' => 'Ok']);
|
|
}
|
|
|
|
/**
|
|
* Clears all app caches and rebuild them
|
|
*
|
|
* @return \Illuminate\Http\JsonResponse
|
|
*/
|
|
public function optimize(Request $request)
|
|
{
|
|
$configCode = Artisan::call('config:cache');
|
|
$routeCode = Artisan::call('route:cache');
|
|
$eventCode = Artisan::call('event:cache');
|
|
$viewCode = Artisan::call('view:cache');
|
|
|
|
return response()->json([
|
|
'config-exit-code' => $configCode,
|
|
'route-exit-code' => $routeCode,
|
|
'event-exit-code' => $eventCode,
|
|
'view-exit-code' => $viewCode,
|
|
], 200);
|
|
}
|
|
|
|
/**
|
|
* Clears application cache
|
|
*
|
|
* @return \Illuminate\Http\JsonResponse
|
|
*/
|
|
public function clear(Request $request)
|
|
{
|
|
$exitCode = Artisan::call('optimize:clear');
|
|
|
|
return response()->json(['exit-code' => $exitCode], 200);
|
|
}
|
|
|
|
|
|
}
|