glhd / quartermaster
dev-main
2024-09-12 20:41 UTC
Requires
- ext-json: *
- illuminate/support: ^10|^11|dev-master
- laravel/pennant: ^1.11
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.34
- mockery/mockery: ^1.6
- orchestra/testbench: ^8|^9|10.x-dev|dev-master
- phpunit/phpunit: ^10.5
This package is auto-updated.
Last update: 2025-01-12 21:33:21 UTC
README
Quartermaster
Quartermaster makes it easy to use PHP enums with Laravel Pennant.
Installation
composer require glhd/quartermaster
Usage
Add the EnumeratesFeatures
trait to any enum to use it with Pennant:
enum BillingFeatures { use EnumeratesFeatures; case NextGenerationPortal; case LegacyPortal; // Define a "resolver" for each feature: public function resolveNextGenerationPortal(Team $team) { return $team->owner->isEnrolledInBetaFeatures(); } public function resolveLegacyPortal(Team $team) { return $team->created_at->lt('2022-06-01'); } }
Next, register your enum with Pennant:
// in a service provider's boot method: BillingFeatures::register();
Then, you can call many Pennant methods from the enum directly:
if (BillingFeatures::NextGenerationPortal->active()) { // Show next-gen billing portal } if (BillingFeatures::NextGenerationPortal->inactive()) { // Show opt-in for beta features }
For many checks, you may need a scope. You can use the for()
method
on the enum to do scoped checks:
if (BillingFeatures::LegacyPortal->for($team)->active()) { // Show legacy billing portal } // Enable next-gen portal for team BillingFeatures::NextGenerationPortal->for($team)->activate(); // Disable next-gen portal for team BillingFeatures::NextGenerationPortal->for($team)->deactivate(); // Reset flag status for team BillingFeatures::NextGenerationPortal->for($team)->forget();
Using with class-based features
Pennant already offers class-based features.
If you would like to use some of the Quartermaster convenience methods with
this API, you can extend the Glhd\Quartermaster\Feature
class:
namespace App\Features; use Glhd\Quartermaster\Feature; class NextGenerationBillingPortal extends Feature { public function resolve(Team $team) { return $team->owner->isEnrolledInBetaFeatures(); } }
Then you can call most of the same methods statically from this class:
if (NextGenerationBillingPortal::active()) { // Show next-gen portal } if (NextGenerationBillingPortal::for($team)->active()) { // ... }