izniburak / bit-permission
simple PHP bitwise control to check somethings like Permissions, Roles, etc.
v1.0.0
2024-06-04 22:19 UTC
Requires
- php: ^8.1
Requires (Dev)
- pestphp/pest: ^1.21
README
Check something like Permission, Roles, etc.. by using bitwise operations.
_ _ _ _ _
| | (_) | (_) (_)
| |__ _| |_ ______ _ __ ___ _ __ _ __ ___ _ ___ ___ _ ___ _ __
| '_ \| | __|______| '_ \ / _ \ '__| '_ ` _ \| / __/ __| |/ _ \| '_ \
| |_) | | |_ | |_) | __/ | | | | | | | \__ \__ \ | (_) | | | |
|_.__/|_|\__| | .__/ \___|_| |_| |_| |_|_|___/___/_|\___/|_| |_|
| |
|_|
Install
composer.json file:
{ "require": { "izniburak/bit-permission": "^1.0" } }
after run the install command.
$ composer install
OR run the following command directly.
$ composer require izniburak/bit-permission
Example Usage
require 'vendor/autoload.php'; use Buki\BitPermission\Binary; use Buki\BitPermission\Sequent; // FOR ROLE MANAGEMENT class Role { const GUEST = 0; const USER = 1; const EDITOR = 2; const AUTHOR = 3; const ADMIN = 4; const ROOT = 5; } $role = new Sequent; $role->add([Role::USER, Role::AUTHOR]); $role->has(ROLE::USER); // true $role->has(ROLE::AUTHOR); // true $role->has(ROLE::EDITOR); // false // FOR PERMISSION MANAGEMENT class Permission { // Each permission is represented by a single bit. const NONE = 0x0000; // 0000 const READ = 0x0001; // 0001 const WRITE = 0x0002; // 0010 const UPDATE = 0x0004; // 0100 const DELETE = 0x0008; // 1000 const SUPER = 0x000f; // 1111 } $permission = new Binary; $permission->add([Permission::READ, Permission::WRITE]); $permission->has(Permission::READ); // true $permission->has(Permission::DELETE); // false
Also, you can use Enum
for your permission or role definitions. (or another things)
Please check out the tests to review more use cases.
Support
Licence
Contributing
- Fork it ( https://github.com/izniburak/bit-permission/fork )
- Create your feature branch (git checkout -b my-new-feature)
- Commit your changes (git commit -am 'Add some feature')
- Push to the branch (git push origin my-new-feature)
- Create a new Pull Request
Contributors
- izniburak İzni Burak Demirtaş - creator, maintainer