I'am using klaravel/ntrust package for ACL in my laravel 5.3 application. Everything working fine except deleting permission.
config/ntrust.php
'admin' => [
User table name
'table' => 'cushbu_admin',
User model
'model' => 'Modules\Admin\Models\Admin',
Ntrust Role Model
'role' => 'Modules\Admin\Models\AdminRole',
Ntrust Roles Table
'roles_table' => 'cushbu_admin_roles',
Ntrust Permission Model
'permission' => 'Modules\Admin\Models\AdminPermission',
Ntrust Permissions Table
'permissions_table' => 'cushbu_admin_permissions',
Ntrust permission_role Table
'permission_role_table' => 'cushbu_admin_permission_role',
Ntrust role_user Table
'role_user_table' => 'cushbu_admin_role_user',
User Foreign key on Ntrust's role_user Table (Pivot)
'user_foreign_key' => 'user_id',
Role Foreign key on Ntrust's role_user and permission_role Tables
(Pivot)
'role_foreign_key' => 'role_id',
Permission Foreign key on Ntrust's permission_role Table (Pivot)
'permission_foreign_key' => 'permission_id',
],
when i try to delete i'am getting this error
SQLSTATE[42S22]: Column not found: 1054 Unknown column 'admin_role_id' in 'field list' (SQL: select
admin_role_id
fromadmin_permission_role
whereadmin_permission_id
= 3)
I haven't specified admin_role_id, admin_permission_id anywhere, rather exist role_id, permission_id.
Permission model
<?php
namespace Modules\Admin\Models;
use Illuminate\Database\Eloquent\Model;
use Klaravel\Ntrust\Traits\NtrustPermissionTrait;
use Vinkla\Hashids\Facades\Hashids;
class AdminPermission extends Model
{
use NtrustPermissionTrait;
/*
* Role profile to get value from ntrust config file.
*/
protected static $roleProfile = 'admin';
protected $table = 'cushbu_admin_permissions' ;
protected $fillable = ['name','display_name'];
//Get hashid
public function getRouteKey() {
return Hashids::encode($this->getKey());
}
}
id ,name, display_name, description
permission_id ,role_id
i changed permission_id, role_id to admin_permission_id, admin_role_id respectively in database.that solved the issue.