BookStack/app/Http/Controllers/Controller.php

71 lines
1.7 KiB
PHP
Raw Normal View History

2015-07-13 03:01:42 +08:00
<?php
namespace Oxbow\Http\Controllers;
2015-08-29 22:03:42 +08:00
use HttpRequestException;
2015-07-13 03:01:42 +08:00
use Illuminate\Foundation\Bus\DispatchesJobs;
2015-08-29 22:03:42 +08:00
use Illuminate\Http\Exception\HttpResponseException;
2015-07-13 03:01:42 +08:00
use Illuminate\Routing\Controller as BaseController;
use Illuminate\Foundation\Validation\ValidatesRequests;
2015-08-25 04:10:04 +08:00
use Illuminate\Support\Facades\Auth;
2015-08-29 22:03:42 +08:00
use Illuminate\Support\Facades\Session;
2015-08-25 04:10:04 +08:00
use Oxbow\User;
2015-07-13 03:01:42 +08:00
abstract class Controller extends BaseController
{
use DispatchesJobs, ValidatesRequests;
2015-08-25 04:10:04 +08:00
2015-08-29 22:03:42 +08:00
/**
* @var User static
*/
protected $currentUser;
/**
* @var bool
*/
protected $signedIn;
2015-08-25 04:10:04 +08:00
/**
* Controller constructor.
*/
public function __construct()
{
2015-08-29 22:03:42 +08:00
// Get a user instance for the current user
$user = auth()->user();
2015-09-06 00:42:05 +08:00
if (!$user) $user = User::getDefault();
2015-08-29 22:03:42 +08:00
// Share variables with views
view()->share('signedIn', auth()->check());
2015-08-29 22:03:42 +08:00
view()->share('currentUser', $user);
2015-09-06 00:42:05 +08:00
2015-08-29 22:03:42 +08:00
// Share variables with controllers
$this->currentUser = $user;
$this->signedIn = auth()->check();
2015-08-29 22:03:42 +08:00
}
/**
* Checks for a permission.
*
* @param $permissionName
* @return bool|\Illuminate\Http\RedirectResponse
*/
protected function checkPermission($permissionName)
{
if (!$this->currentUser || !$this->currentUser->can($permissionName)) {
Session::flash('error', trans('errors.permission'));
throw new HttpResponseException(
2015-09-06 00:42:05 +08:00
redirect('/')
2015-08-29 22:03:42 +08:00
);
}
return true;
}
protected function checkPermissionOr($permissionName, $callback)
{
$callbackResult = $callback();
if ($callbackResult === false) $this->checkPermission($permissionName);
return true;
2015-08-25 04:10:04 +08:00
}
2015-07-13 03:01:42 +08:00
}