Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up

A package to integrate rollout into your Laravel project.

NotificationsYou must be signed in to change notification settings

Jaspaul/laravel-rollout

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

68 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

A Laravel package foropensoft/rollout

Build StatusCoverage StatusCode Climate

Installation

Composer

composer require jaspaul/laravel-rollout

Configuring the Service Provider

Package discovery will configure the service provider automatically.

Setting up Storage

Publish the Configuration

php artisan vendor:publish --provider'Jaspaul\LaravelRollout\ServiceProvider'

Setting up a Cache

If you intend to use cache to store the settings for rollout, be sure toenable the cache for your Laravel application. Note if you are using the cache, a cache clear during deployment will cause your rollout settings to be purged. If you require persistence for these settings use the option below.

Setting up Persistent Storage

This will allow you to have rollout settings be persisted even if you clear the application cache for every deployment.

Running the Migrations
php artisan migrate
Configuring your Environment
ROLLOUT_STORAGE=databaseROLLOUT_TABLE=rollout

Implementing Interfaces

User

Your rollout users must implement the\Jaspaul\LaravelRollout\Contracts\User interface. Often this will be your main user object:

<?phpuseJaspaul\LaravelRollout\Helpers\UserasContract;class Userimplements Contract{/**     * @return string     */publicfunctiongetRolloutIdentifier()    {return$this->id;    }}

Group

Your rollout groups must implement the\Jaspaul\LaravelRollout\Contracts\Group interface.

<?phpuseJaspaul\LaravelRollout\Contracts\Group;class BetaUsersGroupimplements Group{/**     * The name of the group.     *     * @return string     */publicfunctiongetName():string    {return'beta-users';    }/**     * Defines the rule membership in the group.     *     * @return boolean     */publicfunctionhasMember($user =null):bool    {if (!is_null($user)) {return$user->hasOptedIntoBeta();        }returnfalse;    }}

and you should update your locallaravel-rollout.php configuration to include the group in the groups array:

laravel-rollout.php

return [    ...'groups' => [        BetaUsersGroup::class    ],    ...]

Commands

Add Group

php artisan rollout:add-group {feature} {group}

Swap{feature} with the name of the feature, and{group} with the name you defined in the group class.

Add User

php artisan rollout:add-user {feature} {user}

Swap{feature} with the name of the feature, and{user} with a unique identifier for the user in your system.

Create

php artisan rollout:create {feature}

Swap{feature} with the name of the feature you'd like to create a feature flag for.

Deactivate

php artisan rollout:deactivate {feature}

Swap{feature} with the name of the feature you'd like to deactivate globally. Note this will also reset the user whitelist.

Delete

php artisan rollout:delete {feature}

Swap{feature} with the name of the feature you'd like to permanently delete from rollout.

Everyone

php artisan rollout:everyone {feature}

Swap{feature} with the name of the feature you'd like to rollout to 100% of your user base.

List

php artisan rollout:list

Percentage

php artisan rollout:percentage {feature} {percentage}

Swap{feature} with the name of the feature you'd like to rollout, and{percentage} with the percentage of users to rollout the feature to.

Remove Group

php artisan rollout:remove-group {feature} {group}

Swap{feature} with the name of the feature, and{group} with the name you defined in the group class.

Remove User

php artisan rollout:remove-user {feature} {user}

Swap{feature} with the name of the feature, and{user} with a unique identifier for the user in your system to remove the feature from.


[8]ページ先頭

©2009-2025 Movatter.jp