Download the PHP package casbin/laravel-authz without Composer

On this page you can find all versions of the php package casbin/laravel-authz. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.

FAQ

After the download, you have to make one include require_once('vendor/autoload.php');. After that you have to import the classes with use statements.

Example:
If you use only one package a project is not needed. But if you use more then one package, without a project it is not possible to import the classes with use statements.

In general, it is recommended to use always a project to download your libraries. In an application normally there is more than one library needed.
Some PHP packages are not free to download and because of that hosted in private repositories. In this case some credentials are needed to access such packages. Please use the auth.json textarea to insert credentials, if a package is coming from a private repository. You can look here for more information.

  • Some hosting areas are not accessible by a terminal or SSH. Then it is not possible to use Composer.
  • To use Composer is sometimes complicated. Especially for beginners.
  • Composer needs much resources. Sometimes they are not available on a simple webspace.
  • If you are using private repositories you don't need to share your credentials. You can set up everything on our site and then you provide a simple download link to your team member.
  • Simplify your Composer build process. Use our own command line tool to download the vendor folder as binary. This makes your build process faster and you don't need to expose your credentials for private repositories.
Please rate this library. Is it a good library?

Informations about the package laravel-authz

Laravel Authorization

Laravel-authz is an authorization library for the laravel framework.

PHPUnit Status Coverage Status Latest Stable Version Total Downloads License

It's based on Casbin, an authorization library that supports access control models like ACL, RBAC, ABAC.

All you need to learn to use Casbin first.

Installation

Require this package in the composer.json of your Laravel project. This will download the package.

The Lauthz\LauthzServiceProvider is auto-discovered and registered by default, but if you want to register it yourself:

Add the ServiceProvider in config/app.php

The Enforcer facade is also auto-discovered, but if you want to add it manually:

Add the Facade in config/app.php

To publish the config, run the vendor publish command:

This will create a new model config file named config/lauthz-rbac-model.conf and a new lauthz config file named config/lauthz.php.

To migrate the migrations, run the migrate command:

This will create a new table named rules

Usage

Quick start

Once installed you can do stuff like this:

You can check if a user has a permission like this:

By default, Gate checks will be automatically intercepted . You can check if a user has a permission with Laravel's default can function:

Using Enforcer Api

It provides a very rich api to facilitate various operations on the Policy:

Gets all roles:

Gets all the authorization rules in the policy.:

Gets the roles that a user has.

Gets the users that has a role.

Determines whether a user has a role.

Adds a role for a user.

Adds a permission for a user or role.

Deletes a role for a user.

Deletes all roles for a user.

Deletes a role.

Deletes a permission.

Deletes a permission for a user or role.

Deletes permissions for a user or role.

Gets permissions for a user or role.

Determines whether a user has a permission.

See Casbin API for more APIs.

Using a middleware

This package comes with EnforcerMiddleware, RequestMiddleware middlewares. You can add them inside your app/Http/Kernel.php file.

basic Enforcer Middleware

Then you can protect your routes using middleware rules:

HTTP Request Middleware ( RESTful is also supported )

If you need to authorize a Request,you need to define the model configuration first in config/lauthz-rbac-model.conf:

Then, using middleware rules:

Using Gates

You can use Laravel Gates to check if a user has a permission, provided that you have set an existing user instance as the currently authenticated user.

If you require custom Laravel Gates, you can disable the automatic registration by setting enabled_register_at_gates to false in the lauthz file. After that, you can use Gates::before or Gates::after in your ServiceProvider to register custom Gates. See Gates for more details.

Multiple enforcers

If you need multiple permission controls in your project, you can configure multiple enforcers.

In the lauthz file, it should be like this:

Then you can choose which enforcers to use.

Using artisan commands

You can create a policy from a console with artisan commands.

To user:

To Role:

Adds a role for a user:

Using cache

Authorization rules are cached to speed up performance. The default is off.

Sets your own cache configs in Laravel's config/lauthz.php.

Thinks

Casbin in Laravel. You can find the full documentation of Casbin on the website.

License

This project is licensed under the Apache 2.0 license.


All versions of laravel-authz with dependencies

PHP Build Version
Package Version
Requires php Version >=8.0
illuminate/support Version ~8.0|~9.0|~10.0|~11.0
illuminate/database Version ~8.0|~9.0|~10.0|~11.0
illuminate/console Version ~8.0|~9.0|~10.0|~11.0
casbin/casbin Version ~4.0
Composer command for our command line client (download client) This client runs in each environment. You don't need a specific PHP version etc. The first 20 API calls are free. Standard composer command

The package casbin/laravel-authz contains the following files

Loading the files please wait ....