<?php

namespace {{ namespace }};

use Illuminate\Auth\Access\HandlesAuthorization;
use {{ namespacedModel }};
use {{ namespacedUserModel }};

class {{ class }}
{
    use HandlesAuthorization;

    /**
     * Determine whether the user can view any models.
     *
     * @param  \{{ namespacedUserModel }}  $user
     * @return mixed
     * @throws \Exception
     */
    public function viewAny({{ user }} $user)
    {
        return $user->hasAnyPermission('user-{{ modelVariable }}-index');
    }

    /**
     * Determine whether the user can view the model.
     *
     * @param  \{{ namespacedUserModel }}  $user
     * @param  \{{ namespacedModel }}  ${{ modelVariable }}
     * @return mixed
     * @throws \Exception
     */
    public function view({{ user }} $user, {{ model }} ${{ modelVariable }})
    {
        return $user->hasAnyPermission('user-{{ modelVariable }}-show');
    }

    /**
     * Determine whether the user can create models.
     *
     * @param  \{{ namespacedUserModel }}  $user
     * @return mixed
     * @throws \Exception
     */
    public function create({{ user }} $user)
    {
        return $user->hasAnyPermission('user-{{ modelVariable }}-create','user-{{ modelVariable }}-store');
    }

    /**
     * Determine whether the user can update the model.
     *
     * @param  \{{ namespacedUserModel }}  $user
     * @param  \{{ namespacedModel }}  ${{ modelVariable }}
     * @return mixed
     * @throws \Exception
     */
    public function update({{ user }} $user, {{ model }} ${{ modelVariable }})
    {
        return $user->hasAnyPermission('user-{{ modelVariable }}-edit','user-{{ modelVariable }}-update');
    }

    /**
     * Determine whether the user can delete the model.
     *
     * @param  \{{ namespacedUserModel }}  $user
     * @param  \{{ namespacedModel }}  ${{ modelVariable }}
     * @return mixed
     * @throws \Exception
     */
    public function delete({{ user }} $user, {{ model }} ${{ modelVariable }})
    {
        return $user->hasAnyPermission('user-{{ modelVariable }}-delete');
    }

    /**
     * Determine whether the user can restore the model.
     *
     * @param  \{{ namespacedUserModel }}  $user
     * @param  \{{ namespacedModel }}  ${{ modelVariable }}
     * @return mixed
     * @throws \Exception
     */
    public function restore({{ user }} $user, {{ model }} ${{ modelVariable }})
    {
        return $user->hasAnyPermission('user-{{ modelVariable }}-restore');
    }

    /**
     * Determine whether the user can permanently delete the model.
     *
     * @param  \{{ namespacedUserModel }}  $user
     * @param  \{{ namespacedModel }}  ${{ modelVariable }}
     * @return mixed
     * @throws \Exception
     */
    public function forceDelete({{ user }} $user, {{ model }} ${{ modelVariable }})
    {
        return $user->hasAnyPermission('user-{{ modelVariable }}-forceDelete');
    }
}
