SystemController.php 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Facades\Settings;
  4. use App\Services\ReleaseRadarService;
  5. use Illuminate\Http\Request;
  6. use Illuminate\Support\Facades\DB;
  7. class SystemController extends Controller
  8. {
  9. /**
  10. * Get detailed information about the current installation
  11. *
  12. * @return \Illuminate\Http\JsonResponse
  13. */
  14. public function infos(Request $request)
  15. {
  16. $infos = [];
  17. $infos['Date'] = date(DATE_RFC2822);
  18. $infos['userAgent'] = $request->header('user-agent');
  19. // App info
  20. $infos['Version'] = config('2fauth.version');
  21. $infos['Environment'] = config('app.env');
  22. $infos['Debug'] = var_export(config('app.debug'), true);
  23. $infos['Cache driver'] = config('cache.default');
  24. $infos['Log channel'] = config('logging.default');
  25. $infos['Log level'] = env('LOG_LEVEL');
  26. $infos['DB driver'] = DB::getDriverName();
  27. // PHP info
  28. $infos['PHP version'] = PHP_VERSION;
  29. $infos['Operating system'] = PHP_OS;
  30. $infos['interface'] = PHP_SAPI;
  31. // Auth info
  32. if ($request->user()) {
  33. $infos['Auth guard'] = config('auth.defaults.guard');
  34. if ($infos['Auth guard'] === 'reverse-proxy-guard') {
  35. $infos['Auth proxy header for user'] = config('auth.auth_proxy_headers.user');
  36. $infos['Auth proxy header for email'] = config('auth.auth_proxy_headers.email');
  37. }
  38. $infos['webauthn user verification'] = config('larapass.login_verify');
  39. $infos['Trusted proxies'] = config('2fauth.trustedProxies') ?: 'none';
  40. }
  41. // User info
  42. if ($request->user()) {
  43. $infos['options'] = Settings::all()->toArray();
  44. }
  45. return response()->json($infos);
  46. }
  47. /**
  48. * Get latest release
  49. *
  50. * @return \Illuminate\Http\JsonResponse
  51. */
  52. public function latestRelease(Request $request, ReleaseRadarService $releaseRadar)
  53. {
  54. $release = $releaseRadar->manualScan();
  55. return response()->json(['newRelease' => $release]);
  56. }
  57. }