fixed dingo api conflict
This commit is contained in:
parent
9b7991011a
commit
5b2e24ee51
@ -2,13 +2,27 @@
|
||||
|
||||
namespace App\Abstracts\Http;
|
||||
|
||||
use App\Traits\Jobs;
|
||||
use App\Traits\Permissions;
|
||||
use App\Traits\Relationships;
|
||||
use Dingo\Api\Exception\ResourceException;
|
||||
use Dingo\Api\Routing\Helpers;
|
||||
use Illuminate\Foundation\Auth\Access\AuthorizesRequests;
|
||||
use Illuminate\Foundation\Validation\ValidatesRequests;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Routing\Controller as BaseController;
|
||||
|
||||
abstract class ApiController extends Controller
|
||||
abstract class ApiController extends BaseController
|
||||
{
|
||||
use Helpers;
|
||||
use AuthorizesRequests, Jobs, Helpers, Permissions, Relationships, ValidatesRequests;
|
||||
|
||||
/**
|
||||
* Instantiate a new controller instance.
|
||||
*/
|
||||
public function __construct()
|
||||
{
|
||||
$this->assignPermissionsToController();
|
||||
}
|
||||
|
||||
/**
|
||||
* Create the response for when a request fails validation.
|
||||
|
@ -4,6 +4,7 @@ namespace App\Abstracts\Http;
|
||||
|
||||
use App\Abstracts\Http\Response;
|
||||
use App\Traits\Jobs;
|
||||
use App\Traits\Permissions;
|
||||
use App\Traits\Relationships;
|
||||
use Illuminate\Database\Eloquent\Collection;
|
||||
use Illuminate\Foundation\Auth\Access\AuthorizesRequests;
|
||||
@ -11,73 +12,17 @@ use Illuminate\Foundation\Validation\ValidatesRequests;
|
||||
use Illuminate\Pagination\Paginator;
|
||||
use Illuminate\Pagination\LengthAwarePaginator;
|
||||
use Illuminate\Routing\Controller as BaseController;
|
||||
use Illuminate\Routing\Route;
|
||||
use Illuminate\Support\Str;
|
||||
|
||||
abstract class Controller extends BaseController
|
||||
{
|
||||
use AuthorizesRequests, Jobs, Relationships, ValidatesRequests;
|
||||
use AuthorizesRequests, Jobs, Permissions, Relationships, ValidatesRequests;
|
||||
|
||||
/**
|
||||
* Instantiate a new controller instance.
|
||||
*/
|
||||
public function __construct()
|
||||
{
|
||||
$this->setPermissions();
|
||||
}
|
||||
|
||||
/**
|
||||
* Assign permissions to methods.
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function setPermissions()
|
||||
{
|
||||
// No need to check for permission in console
|
||||
if (app()->runningInConsole()) {
|
||||
return;
|
||||
}
|
||||
|
||||
$route = app(Route::class);
|
||||
|
||||
// Get the controller array
|
||||
$arr = array_reverse(explode('\\', explode('@', $route->getAction()['uses'])[0]));
|
||||
|
||||
$controller = '';
|
||||
|
||||
// Add module
|
||||
if (isset($arr[3]) && isset($arr[4])) {
|
||||
if (strtolower($arr[4]) == 'modules') {
|
||||
$controller .= Str::kebab($arr[3]) . '-';
|
||||
} elseif (isset($arr[5]) && (strtolower($arr[5]) == 'modules')) {
|
||||
$controller .= Str::kebab($arr[4]) . '-';
|
||||
}
|
||||
}
|
||||
|
||||
// Add folder
|
||||
if (strtolower($arr[1]) != 'controllers') {
|
||||
$controller .= Str::kebab($arr[1]) . '-';
|
||||
}
|
||||
|
||||
// Add file
|
||||
$controller .= Str::kebab($arr[0]);
|
||||
|
||||
// Skip ACL
|
||||
$skip = ['portal-dashboard'];
|
||||
if (in_array($controller, $skip)) {
|
||||
return;
|
||||
}
|
||||
|
||||
// App\Http\Controllers\FooBar -->> foo-bar
|
||||
// App\Http\Controllers\FooBar\Main -->> foo-bar-main
|
||||
// Modules\Blog\Http\Controllers\Posts -->> blog-posts
|
||||
// Modules\Blog\Http\Controllers\Portal\Posts -->> blog-portal-posts
|
||||
|
||||
// Add CRUD permission check
|
||||
$this->middleware('permission:create-' . $controller)->only('create', 'store', 'duplicate', 'import');
|
||||
$this->middleware('permission:read-' . $controller)->only('index', 'show', 'edit', 'export');
|
||||
$this->middleware('permission:update-' . $controller)->only('update', 'enable', 'disable');
|
||||
$this->middleware('permission:delete-' . $controller)->only('destroy');
|
||||
$this->assignPermissionsToController();
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -6,6 +6,7 @@ use App\Models\Auth\Permission;
|
||||
use App\Models\Auth\Role;
|
||||
use App\Utilities\Reports;
|
||||
use App\Utilities\Widgets;
|
||||
use Illuminate\Routing\Route;
|
||||
use Illuminate\Support\Str;
|
||||
|
||||
trait Permissions
|
||||
@ -387,4 +388,58 @@ trait Permissions
|
||||
|
||||
return $this->getRoles('read-client-portal');
|
||||
}
|
||||
|
||||
/**
|
||||
* Assign permissions middleware to default controller methods.
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function assignPermissionsToController()
|
||||
{
|
||||
// No need to check for permission in console
|
||||
if (app()->runningInConsole()) {
|
||||
return;
|
||||
}
|
||||
|
||||
$route = app(Route::class);
|
||||
|
||||
// Get the controller array
|
||||
$arr = array_reverse(explode('\\', explode('@', $route->getAction()['uses'])[0]));
|
||||
|
||||
$controller = '';
|
||||
|
||||
// Add module
|
||||
if (isset($arr[3]) && isset($arr[4])) {
|
||||
if (strtolower($arr[4]) == 'modules') {
|
||||
$controller .= Str::kebab($arr[3]) . '-';
|
||||
} elseif (isset($arr[5]) && (strtolower($arr[5]) == 'modules')) {
|
||||
$controller .= Str::kebab($arr[4]) . '-';
|
||||
}
|
||||
}
|
||||
|
||||
// Add folder
|
||||
if (strtolower($arr[1]) != 'controllers') {
|
||||
$controller .= Str::kebab($arr[1]) . '-';
|
||||
}
|
||||
|
||||
// Add file
|
||||
$controller .= Str::kebab($arr[0]);
|
||||
|
||||
// Skip ACL
|
||||
$skip = ['portal-dashboard'];
|
||||
if (in_array($controller, $skip)) {
|
||||
return;
|
||||
}
|
||||
|
||||
// App\Http\Controllers\FooBar -->> foo-bar
|
||||
// App\Http\Controllers\FooBar\Main -->> foo-bar-main
|
||||
// Modules\Blog\Http\Controllers\Posts -->> blog-posts
|
||||
// Modules\Blog\Http\Controllers\Portal\Posts -->> blog-portal-posts
|
||||
|
||||
// Add CRUD permission check
|
||||
$this->middleware('permission:create-' . $controller)->only('create', 'store', 'duplicate', 'import');
|
||||
$this->middleware('permission:read-' . $controller)->only('index', 'show', 'edit', 'export');
|
||||
$this->middleware('permission:update-' . $controller)->only('update', 'enable', 'disable');
|
||||
$this->middleware('permission:delete-' . $controller)->only('destroy');
|
||||
}
|
||||
}
|
||||
|
1099
composer.lock
generated
1099
composer.lock
generated
File diff suppressed because it is too large
Load Diff
Loading…
x
Reference in New Issue
Block a user