50
app/Policies/VideoPolicy.php
Executable file
50
app/Policies/VideoPolicy.php
Executable file
@@ -0,0 +1,50 @@
|
||||
<?php
|
||||
|
||||
namespace App\Policies;
|
||||
|
||||
use App\Models\User;
|
||||
use App\Models\Video;
|
||||
use Illuminate\Auth\Access\HandlesAuthorization;
|
||||
|
||||
class VideoPolicy
|
||||
{
|
||||
use HandlesAuthorization;
|
||||
|
||||
public function vote(User $user)
|
||||
{
|
||||
return $user->hasPermission('videos.rate');
|
||||
}
|
||||
|
||||
public function index(User $user, int $userId = null)
|
||||
{
|
||||
return $user->hasPermission('videos.view') || $user->id === $userId;
|
||||
}
|
||||
|
||||
public function show(User $user, Video $video = null)
|
||||
{
|
||||
return $user->hasPermission('videos.view') || ($video && $video->user_id === $user->id);
|
||||
}
|
||||
|
||||
public function store(User $user)
|
||||
{
|
||||
return $user->hasPermission('videos.create');
|
||||
}
|
||||
|
||||
public function update(User $user)
|
||||
{
|
||||
return $user->hasPermission('videos.update');
|
||||
}
|
||||
|
||||
public function destroy(User $user, $videoIds)
|
||||
{
|
||||
if ($user->hasPermission('videos.delete')) {
|
||||
return true;
|
||||
} else {
|
||||
$dbCount = app(Video::class)
|
||||
->whereIn('id', $videoIds)
|
||||
->where('user_id', $user->id)
|
||||
->count();
|
||||
return $dbCount === (is_countable($videoIds) ? count($videoIds) : 0);
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user