bizley/yii2-podium

View on GitHub
src/filters/PermissionDeniedRule.php

Summary

Maintainability
A
0 mins
Test Coverage
<?php

namespace bizley\podium\filters;

use bizley\podium\models\User;
use bizley\podium\Podium;
use Yii;

/**
 * Permission denied access rule
 * Redirects user with error message in case of no permission granted.
 *
 * @author Paweł Bizley Brzozowski <pawel@positive.codes>
 * @since 0.6
 */
class PermissionDeniedRule extends PodiumRoleRule
{
    /**
     * @var boolean whether this is an 'allow' rule or 'deny' rule.
     */
    public $allow = false;

    /**
     * @var string permission name.
     */
    public $perm;

    /**
     * @var string redirect route.
     */
    public $redirect;

    /**
     * Sets match and deny callbacks.
     */
    public function init()
    {
        parent::init();
        $this->matchCallback = function () {
            return !User::can($this->perm);
        };
        $this->denyCallback = function () {
            Yii::$app->session->addFlash('danger', Yii::t('podium/flash', 'You are not allowed to perform this action.'), true);
            return Yii::$app->response->redirect([Podium::getInstance()->prepareRoute($this->redirect)]);
        };
    }
}