defstudio / enum-features
A simple trait to enable a feature system using Enums and Laravel Pennant
Fund package maintenance!
fabio-ivona
defstudio
paypal.me/bdmstore
Installs: 1 342
Dependents: 0
Suggesters: 0
Security: 0
Stars: 15
Watchers: 2
Forks: 0
Open Issues: 1
Requires
- php: ^8.3
- illuminate/support: ^v11.4.0
- laravel/pennant: ^v1.7.0
- spatie/laravel-package-tools: ^1.16.4
Requires (Dev)
- larastan/larastan: ^v2.9.5
- laravel/pint: ^v1.15.1
- nunomaduro/collision: ^v8.1.1
- orchestra/testbench: ^v9.0.4
- pestphp/pest: ^v2.34.7
- pestphp/pest-plugin-laravel: ^v2.3.0
- phpstan/extension-installer: ^1.3.1
- phpstan/phpstan-deprecation-rules: ^1.1.4
- phpstan/phpstan-phpunit: ^1.3.16
- spatie/invade: ^2.0
README
A simple trait to enable a feature system using Enums:
if(AppFeature::welcome_email->active()){ Mail::to($newUser)->send(new WelcomeEmail($newUser)); }
Installation
You can install the package via composer:
composer require defstudio/enum-features
Usage
Features can be enabled on any enum by using the DefinesFeatures
trait:
use DefStudio\EnumFeatures\EnumFeatures; enum AppFeature { use DefinesFeatures; // ← simply add this case multi_language; case impersonate; case welcome_email; /* Feature resolution */ //with a single method: protected function resolve(Authenticatable $user = null) { match($this){ case self::multi_language => true, case self::impersonate => $user->isAdmin(), default => false; } } //or with a dedicated method: protected function resolveImpersonate(Authenticatable $user = null){ return $user->isSuperAdmin(); } }
and should be registered in your Provider
class AppServiceProvider extends ServiceProvider { //.. public function boot(): void { AppFeature::defineFeatures(); } }
then, in code, a feature could be checked to be enabled:
if(AppFeature::multi_language->active()){ //.. multi language specific code }
An extensive documentation is available at
https://docs.defstudio.it/enum-features
Testing
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently. Follow Us on Twitter for more updates about this package.
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
Credits
License
The MIT License (MIT). Please see License File for more information.
Support us
We at def:studio strongly believe that open source is the foundation of all our business and we try to contribute to it by helping other projects to grow along with developing and maintaining our packages. You can support our work by sponsoring us on github!