Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ylsideas/feature-flags
A Laravel package for handling feature flags
https://github.com/ylsideas/feature-flags
dark-launch dark-launching feature feature-flags feature-toggles flags hacktoberfest laravel laravel-feature-flags laravel10 laravel11 laravel9 php php8 toggles
Last synced: about 7 hours ago
JSON representation
A Laravel package for handling feature flags
- Host: GitHub
- URL: https://github.com/ylsideas/feature-flags
- Owner: ylsideas
- License: mit
- Created: 2019-07-14T13:24:00.000Z (over 5 years ago)
- Default Branch: main
- Last Pushed: 2024-11-24T18:49:52.000Z (2 months ago)
- Last Synced: 2025-01-16T18:17:06.850Z (7 days ago)
- Topics: dark-launch, dark-launching, feature, feature-flags, feature-toggles, flags, hacktoberfest, laravel, laravel-feature-flags, laravel10, laravel11, laravel9, php, php8, toggles
- Language: PHP
- Homepage: https://feature-flags.docs.ylsideas.co/
- Size: 225 KB
- Stars: 610
- Watchers: 12
- Forks: 38
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: .github/CONTRIBUTING.md
- Funding: .github/FUNDING.yml
- License: LICENSE.md
- Codeowners: .github/CODEOWNERS
- Security: .github/SECURITY.md
Awesome Lists containing this project
README
![Feature Flags - The extendable and adaptable Laravel Feature Flags package for managing flags within code](banner.png "Feature Flags")
[![Latest Version on Packagist](https://img.shields.io/packagist/v/ylsideas/feature-flags.svg?style=flat-square)](https://packagist.org/packages/ylsideas/feature-flags)
[![Tests](https://github.com/ylsideas/feature-flags/actions/workflows/run-tests.yml/badge.svg)](https://github.com/ylsideas/feature-flags/actions/workflows/run-tests.yml)
[![Check & fix styling](https://github.com/ylsideas/feature-flags/actions/workflows/pint.yml/badge.svg)](https://github.com/ylsideas/feature-flags/actions/workflows/pint.yml)
[![codecov](https://codecov.io/github/ylsideas/feature-flags/branch/main/graph/badge.svg)](https://codecov.io/github/ylsideas/feature-flags)
[![Total Downloads](https://img.shields.io/packagist/dt/ylsideas/feature-flags.svg?style=flat-square)](https://packagist.org/packages/ylsideas/feature-flags)
[![Help Fund](https://img.shields.io/github/sponsors/peterfox?style=flat-square)](https://github.com/sponsors/peterfox)A Feature flag is at times referred to as a feature toggle or feature switch. Ultimately it's a coding strategy
to be used along with source control to make it easier to continuously integrate and deploy. The idea of
the flags works by essentially safe guarding sections of code from executing if a feature flag isn't in a switched
on state.This package aims to make implementing such flags across your application a great deal easier by providing solutions
that work with not only your code but your routes, blade files, task scheduling and validations.## The Feature flagging dashboard for Laravel
[![flagfox - the power to deploy features form your own dashboard via a single Laravel package](https://www.flagfox.dev/img/github-readme-image.png "Flagfox")](https://www.flagfox.dev/?utm_campaign=waitlist&utm_source=github&utm_content=featureflags)
In late 2022 we decided to start work on a dashboard that will work on top of all the awesomeness that [Feature flags
for Laravel](https://github.com/ylsideas/feature-flags) gives you. Right now you can
[join the waiting list](https://www.flagfox.dev/?utm_campaign=waitlist&utm_source=github&utm_content=featureflags#waitlist).## How adding feature flags looks with this package
It's pretty simple, you can start of with just simple calls to check if a flag's state is on or off.
```php
Features::accessible('my-feature') // returns true or false
```One of the unique features of this package is that it integrates heavily into Laravel by allowing you to
configure different things such as access to route, schedule tasks or modifying the query builder.To get a full understanding, it's best to [read the docs](https://feature-flags.docs.ylsideas.co/).
## Upgrading
This project is currently at version 2 and is somewhat different to version 1. If you are using Laravel 9 and PHP8
you should aim to use version 2. Version 1 is no longer supported. There is an [upgrade guide for moving
from version 1 to version 2](UPGRADE.md).## Installation
You can install the package via composer:
```bash
composer require ylsideas/feature-flags:^2.0
```Once installed you should publish the config with the following command.
```bash
php artisan vendor:publish --provider="YlsIdeas\FeatureFlags\FeatureFlagsServiceProvider" --tag=config
```You can customise the `features.php` config in a number of ways.
## Documentation
For the complete documentation, visit [https://feature-flags.docs.ylsideas.co/](https://feature-flags.docs.ylsideas.co/).
## Package Development
If you wish to develop new features for this package you may run the tests using the following command.
``` bash
composer test
```Make sure any code you work on is linted as well.
```bash
composer lint
```and that the code doesn't introduce errors with PHPStan.
```bash
composer analyse
```Please make sure you *follow the Pull Request template* for all proposed changes. Ignoring it
will mean the PR will be ignored.### Changelog
Please see [CHANGELOG](CHANGELOG.md) for more information what has changed recently.
## Contributing
Please see [CONTRIBUTING](CONTRIBUTING.md) for details.
### Security
If you discover any security related issues, please email [email protected] instead of using the issue tracker.
## Credits
- [Peter Fox](https://github.com/ylsideas)
- [All Contributors](../../contributors)## License
The MIT License (MIT). Please see [License File](LICENSE.md) for more information.