add policy

This commit is contained in:
annajwasz 2025-04-30 12:23:16 +07:00
parent ca6a95571e
commit b5e1e005be
5 changed files with 286 additions and 0 deletions

66
.env .example Normal file
View File

@ -0,0 +1,66 @@
APP_NAME=Laravel
APP_ENV=local
APP_KEY=base64:YOUR_APP_KEY
APP_DEBUG=true
APP_TIMEZONE=Asia/Jakarta
APP_URL=http://localhost:8000
APP_LOCALE=id
APP_FALLBACK_LOCALE=en
APP_FAKER_LOCALE=en_US
APP_MAINTENANCE_DRIVER=file
# APP_MAINTENANCE_STORE=database
PHP_CLI_SERVER_WORKERS=4
BCRYPT_ROUNDS=12
LOG_CHANNEL=stack
LOG_STACK=single
LOG_DEPRECATIONS_CHANNEL=null
LOG_LEVEL=debug
DB_CONNECTION=mysql
DB_HOST=127.0.0.1
DB_PORT=3306
DB_DATABASE=your_database
DB_USERNAME=your_username
DB_PASSWORD=your_password
SESSION_DRIVER=database
SESSION_LIFETIME=120
SESSION_ENCRYPT=false
SESSION_PATH=/
SESSION_DOMAIN=null
BROADCAST_CONNECTION=log
FILESYSTEM_DISK=local
QUEUE_CONNECTION=database
CACHE_STORE=database
CACHE_PREFIX=
MEMCACHED_HOST=127.0.0.1
REDIS_CLIENT=phpredis
REDIS_HOST=127.0.0.1
REDIS_PASSWORD=null
REDIS_PORT=6379
MAIL_MAILER=log
MAIL_SCHEME=null
MAIL_HOST=127.0.0.1
MAIL_PORT=2525
MAIL_USERNAME=null
MAIL_PASSWORD=null
MAIL_FROM_ADDRESS="hello@example.com"
MAIL_FROM_NAME="${APP_NAME}"
AWS_ACCESS_KEY_ID=
AWS_SECRET_ACCESS_KEY=
AWS_DEFAULT_REGION=us-east-1
AWS_BUCKET=
AWS_USE_PATH_STYLE_ENDPOINT=false
VITE_APP_NAME="${APP_NAME}"

View File

@ -0,0 +1,108 @@
<?php
namespace App\Policies;
use App\Models\User;
use App\Models\Parameter;
use Illuminate\Auth\Access\HandlesAuthorization;
class HasilPolicy
{
use HandlesAuthorization;
/**
* Determine whether the user can view any models.
*/
public function viewAny(User $user): bool
{
return $user->can('view_any_hasil');
}
/**
* Determine whether the user can view the model.
*/
public function view(User $user, Parameter $parameter): bool
{
return $user->can('view_hasil');
}
/**
* Determine whether the user can create models.
*/
public function create(User $user): bool
{
return $user->can('create_hasil');
}
/**
* Determine whether the user can update the model.
*/
public function update(User $user, Parameter $parameter): bool
{
return $user->can('update_hasil');
}
/**
* Determine whether the user can delete the model.
*/
public function delete(User $user, Parameter $parameter): bool
{
return $user->can('delete_hasil');
}
/**
* Determine whether the user can bulk delete.
*/
public function deleteAny(User $user): bool
{
return $user->can('delete_any_hasil');
}
/**
* Determine whether the user can permanently delete.
*/
public function forceDelete(User $user, Parameter $parameter): bool
{
return $user->can('force_delete_hasil');
}
/**
* Determine whether the user can permanently bulk delete.
*/
public function forceDeleteAny(User $user): bool
{
return $user->can('force_delete_any_hasil');
}
/**
* Determine whether the user can restore.
*/
public function restore(User $user, Parameter $parameter): bool
{
return $user->can('restore_hasil');
}
/**
* Determine whether the user can bulk restore.
*/
public function restoreAny(User $user): bool
{
return $user->can('restore_any_hasil');
}
/**
* Determine whether the user can replicate.
*/
public function replicate(User $user, Parameter $parameter): bool
{
return $user->can('replicate_hasil');
}
/**
* Determine whether the user can reorder.
*/
public function reorder(User $user): bool
{
return $user->can('reorder_hasil');
}
}

View File

@ -0,0 +1,108 @@
<?php
namespace App\Policies;
use App\Models\User;
use App\Models\Parameter;
use Illuminate\Auth\Access\HandlesAuthorization;
class PengumumanPolicy
{
use HandlesAuthorization;
/**
* Determine whether the user can view any models.
*/
public function viewAny(User $user): bool
{
return $user->can('view_any_pengumuman');
}
/**
* Determine whether the user can view the model.
*/
public function view(User $user, Parameter $parameter): bool
{
return $user->can('view_pengumuman');
}
/**
* Determine whether the user can create models.
*/
public function create(User $user): bool
{
return $user->can('create_pengumuman');
}
/**
* Determine whether the user can update the model.
*/
public function update(User $user, Parameter $parameter): bool
{
return $user->can('update_pengumuman');
}
/**
* Determine whether the user can delete the model.
*/
public function delete(User $user, Parameter $parameter): bool
{
return $user->can('delete_pengumuman');
}
/**
* Determine whether the user can bulk delete.
*/
public function deleteAny(User $user): bool
{
return $user->can('delete_any_pengumuman');
}
/**
* Determine whether the user can permanently delete.
*/
public function forceDelete(User $user, Parameter $parameter): bool
{
return $user->can('force_delete_pengumuman');
}
/**
* Determine whether the user can permanently bulk delete.
*/
public function forceDeleteAny(User $user): bool
{
return $user->can('force_delete_any_pengumuman');
}
/**
* Determine whether the user can restore.
*/
public function restore(User $user, Parameter $parameter): bool
{
return $user->can('restore_pengumuman');
}
/**
* Determine whether the user can bulk restore.
*/
public function restoreAny(User $user): bool
{
return $user->can('restore_any_pengumuman');
}
/**
* Determine whether the user can replicate.
*/
public function replicate(User $user, Parameter $parameter): bool
{
return $user->can('replicate_pengumuman');
}
/**
* Determine whether the user can reorder.
*/
public function reorder(User $user): bool
{
return $user->can('reorder_pengumuman');
}
}

View File

@ -61,6 +61,9 @@ public function panel(Panel $panel): Panel
]) ])
->authMiddleware([ ->authMiddleware([
Authenticate::class, Authenticate::class,
])
->plugins([
\BezhanSalleh\FilamentShield\FilamentShieldPlugin::make(),
]); ]);
} }
} }

View File

@ -18,6 +18,7 @@ public function run(): void
SubKriteriaSeeder::class, SubKriteriaSeeder::class,
MahasiswaSeeder::class, MahasiswaSeeder::class,
SuperAdminPermissionSeeder::class, SuperAdminPermissionSeeder::class,
PermissionSeeder::class,
]); ]);
} }
} }