Skip to content

Latest commit

 

History

History
104 lines (78 loc) · 2.94 KB

Policies.md

File metadata and controls

104 lines (78 loc) · 2.94 KB

Policies

Policies are classes that resolve permissions for a given object. You can create policies for any class in your application that you wish to apply permissions checks to.

Creating Policies

You can create policies in your src/Policy directory. Policy classes don't have a common base class or interface they are expected to implement. Application classes are then 'resolved' to a matching policy class. See the Policy Resolvers section for how policies can be resolved.

Generally you'll want to put your policies in src/Policy and use the Policy class suffix. For now we'll create a policy class for the Article entity in our application. In src/Policy/ArticlePolicy.php put the following content:

<?php
namespace App\Policy;

use App\Model\Entity\Article;
use Phauthentic\Authorization\IdentityInterface;

class ArticlePolicy
{
}

In addition to entities, table objects and queries can have policies resolved. These objects use the following conventions:

Writing Policy Methods

The policy class we just created doesn't do much right now. Lets define a method that allows us to check if a user can update an article.

public function canUpdate(IdentityInterface $user, Article $article)
{
    return $user->id == $article->user_id;
}

Policy methods must return true to indicate success. All other values will be interpreted as failure.

Policy methods will get null for the $user parameter when handling unauthencticated users. If you want to automatically fail policy methods for anonymous users you can use the IdentityInterface typehint.

Policy Scopes

In addition to policies being able to define pass/fail authorization checks, they can also define 'scopes'. Scope methods allow you to modify another object applying authorization conditions. A perfect use case for this is restricting a list view to the current user:

namespace App\Policy;

class ArticlesPolicy
{
    public function scopeIndex($user, $query)
    {
        return $query->where(['Articles.user_id' => $user->getIdentifier()]);
    }
}

Policy Pre-conditions

In some policies you may wish to apply common checks across all operations in a policy. This is useful when you need to deny all actions to the provided resource. To use pre-conditions you need to implement the BeforePolicyInterface in your policy:

namespace App\Policy;

use Phauthentic\Authorization\Policy\BeforePolicyInterface;

class ArticlesPolicy implements BeforePolicyInterface
{
    public function before($user, $resource, $action)
    {
        if ($user->getOriginalData()->is_admin) {
            return true;
        }
        // fall through
    }
}

Before hooks are expected to one of 3 return values:

  • true The user is allowed to proceed with the action.
  • false The user is not allowed to proceed with the action.
  • null The before hook did not make a decision, and the authorization method will be invoked.