roboticsexpert / feature-flag
Easy way to add feature flag functionality to your laravel application
Installs: 22 881
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 1
Forks: 1
Open Issues: 0
This package is not auto-updated.
Last update: 2024-11-17 03:51:45 UTC
README
bring feature flag functionality to your project simple as possible
if you want to know what feature flag is, check martin fowler topic about it: https://martinfowler.com/articles/feature-toggles.html
Installation
composer require roboticsexpert/feature-flag
after instaling composer package, if you use auto discovery for service providers, everything ok, but if you blocked
that just add this line to config/app.php
in providers
section:
Roboticsexpert\FeatureFlag\FeatureFlagServiceProvider::class
after that you should run
php artisan migrate
Usage
you can use this project with 2 strategy,Facade or Dependency injection!
I suggest to you to use it with dependecy injection for IDE auto complete feature but use it as you prefer!
Facade
you can get feature flag service like this:
use Roboticsexpert\FeatureFlag\FeatureFlagFacade as FeatureFlag; FeatureFlag::getTypes()
Dependecy Injection
you can get feature flag service like this:
use Roboticsexpert\FeatureFlag\Services\FeatureFlagService; $featureFlag=app(\Roboticsexpert\FeatureFlag\Services\FeatureFlagService::class); //or you can get this service from input of controller method $featureFlag->getTypes();
Methods
Create Feature flag
$featureFlagModel=$featureFlagService->createFeatureFlag('FEATURE_NAME'); dd($featureFlagModel->name);
Change type of feature flag (Admin)
//OPTIONS: DISABLED , PRIVATE , PUBLIC $featureFlagModel=$featureFlagService->changeFeatureFlagType('FEATURE_NAME','DISABLED'); //or $featureFlagModel=$featureFlagService->changeFeatureFlagType('FEATURE_NAME',\Roboticsexpert\FeatureFlag\Models\FeatureFlag::TYPE_DISABLED);
Delete feature flag (Admin)
$featureFlagService->destroyFeatureFlag('FEATURE_1');
Get all Feature flags (Admin)
$featureFlags=$featureFlagService->getAllFeatureFlags();
Attach / Detach a user to/from a feature flag
$featureFlagService->attachUserToFeatureFlag(1,'FEATURE_1'); $featureFlagService->detachUserToFeatureFlag(1,'FEATURE_1');
Get List of not active features for a user or public user
first of all is should explain why you should user disabled features intead of enabled features !
- when a feature became public for all users, we should to tell all clients that the feature is enable until clients be update, but old clients need to have that feature for ever!!!
- if you return enabled features, your list of features became large and large!
finally i prefred to implement disabled features and you should return this list to client !
//It will return array of names of features (string) //No input for not logged in users $featureFlagService->getDisabledFeatureFlagsName(); //User identifier for logged in users $featureFlags=$featureFlagService->getDisabledFeatureFlagsName(1);