<?php

namespace _namespace_Policies;

use _namespace_Models\_class_;
use App\User;
use Illuminate\Auth\Access\HandlesAuthorization;

class _class_Policy
{
    use HandlesAuthorization;

    /**
     * Create a new policy instance.
     *
     * @return void
     */
    private $roleRepository, $permissionRepository;


    public function before($user, $ability)
    {
        // do something
    }

    public function view(User $user, _class_ $_table_)
    {
        if ($this->permissionRepository->is('view__name_')) {
            return true;
        }

        return $user->id === $_table_->user_id;
    }

    public function create(User $user)
    {
        if ($this->permissionRepository->is('create__name_')) {
            return true;
        }

        return false;
    }

    public function update(User $user, _class_ $_table_)
    {
        if ($this->permissionRepository->is('update__name_')) {
            return true;
        }

        return $user->id === $_table_->user_id;
    }

    public function delete($user, _class_ $_table_)
    {
        if ($this->permissionRepository->is('delete__name_')) {
            return true;
        }

        return $user->id === $_table_->user_id;
    }

}
