You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
dependabot[bot] f3252dc468
Bump github.com/spf13/viper from 1.7.1 to 1.8.0 (#483)
1 day ago
.devcontainer Dev Container (#474) 4 days ago
.github Update release.yml 3 days ago
.licenses/go Bump github.com/uber/jaeger-client-go from 2.25.0+incompatible to 2.27.0+incompatible (#412) 2 months ago
.vscode Dev Container (#474) 4 days ago
_tools Bump google.golang.org/grpc from 1.33.1 to 1.33.2 (#360) 7 months ago
bin Initial commit 2 years ago
build Native goreleaser (#482) 2 days ago
cmd/flipt Bump google.golang.org/grpc from 1.33.1 to 1.33.2 (#360) 7 months ago
config DB key/value config (#326) 11 months ago
errors Empty string constraint fixes (#193) 2 years ago
examples Devcontainer (#463) 2 weeks ago
rpc Dont error on disabled flag (#382) 4 months ago
script Native goreleaser (#482) 2 days ago
server Dont error on disabled flag (#382) 4 months ago
storage Bump google.golang.org/grpc from 1.33.1 to 1.33.2 (#360) 7 months ago
swagger Update swagger docs (#175) 2 years ago
test rm qawolf (#472) 7 days ago
ui Fix segment autocomplete (#475) 4 days ago
.all-contributorsrc docs: add edumucelli as a contributor (#389) 3 months ago
.dockerignore Devcontainer (#463) 2 weeks ago
.env Tools (#331) 10 months ago
.gitignore Codespaces (#465) 2 weeks ago
.golangci.yml Bump google.golang.org/protobuf from 1.25.0 to 1.26.0 (#398) 2 months ago
.goreleaser.yml Native goreleaser (#482) 2 days ago
.imgbotconfig Dont try to optimize svgs 2 years ago
.licensed.yml Bump github.com/prometheus/client_golang from 1.8.0 to 1.9.0 (#371) 6 months ago
Brewfile Native goreleaser (#482) 2 days ago
CHANGELOG.md Prep changelog for release (#481) 4 days ago
CHANGELOG.template.md Initial commit 2 years ago
CODE_OF_CONDUCT.md Create CoC [ci skip] 2 years ago
DEVELOPMENT.md Prep changelog for release (#481) 4 days ago
Dockerfile Dev Container (#474) 4 days ago
LICENSE Initial commit 2 years ago
Makefile Dev Container (#474) 4 days ago
README.md Devcontainer (#463) 2 weeks ago
cli.gif Add cli gif 8 months ago
codecov.yml Add batch eval test, bump protoc-gen-go (#298) 1 year ago
demo.gif [ImgBot] Optimize images (#317) 11 months ago
docker-compose.yml Create docker-compose.yml 2 years ago
flipt.png Readme/docs update 2 years ago
go.mod Bump github.com/spf13/viper from 1.7.1 to 1.8.0 (#483) 1 day ago
go.sum Bump github.com/spf13/viper from 1.7.1 to 1.8.0 (#483) 1 day ago
logo.svg [ImgBot] Optimize images (#179) 2 years ago

README.md

Flipt

An open-source, on-prem feature flag solution


Flipt

Flipt is an open source, on-prem feature flag application that allows you to run experiments across services in your environment.

Flipt can be deployed within your existing infrastructure so that you don't have to worry about your information being sent to a third party or the latency required to communicate across the internet.

Flipt supports use cases such as:

  • Simple on/off feature flags to toggle functionality in your applications
  • Rolling out features to a percentage of your customers
  • Using advanced segmentation to target and serve users based on custom properties that you define

Features

  • Fast. Written in Go. Optimized for performance
  • Stand alone, easy to run and configure
  • Ability to create advanced distribution rules to target segments of users
  • Native GRPC client SDKs to integrate with your applications
  • Simple REST API
  • Modern UI and debug console
  • Support for multiple databases (Postgres, MySQL, SQLite)
  • Data import and export to allow storing your flags as code

Values

  • 🔒 Security - HTTPS support. No data leaves your servers and you don't have to open your systems to the outside world to communicate with Flipt. It all runs within your existing infrastructure.
  • 🚀 Speed - Since Flipt is co-located with your existing services, you do not have to communicate across the internet which can add excessive latency and slow down your applications.
  • Simplicity - Flipt is a single binary with no external dependencies by default.
  • Privacy - No telemetry data is collected or sent by Flipt. Ever.
  • 👍 Compatibility - REST, GRPC, MySQL, Postgres, SQLite.. Flipt supports it all.

Examples

Check out the examples to see how Flipt works.

Here's a basic one to get started!

Try It

Flipt Docker

Try Flipt out yourself with Docker:

❯ docker run --rm -p 8080:8080 -p 9000:9000 -t markphelps/flipt:latest

Flipt UI will now be reachable at http://127.0.0.1:8080/.

For more permanent methods of running Flipt, see the Installation section.

GRPC Clients

Licensing

There are currently two types of licenses in place for Flipt:

  1. Client License
  2. Server License

Client License

All of the code required to generate GRPC clients in other languages as well as the existing GRPC Go client are licensed under the MIT License.

This code exists in the rpc/ directory.

The client code is the code that you would integrate into your applications, which is why a more permissive license is used.

Server License

The server code is licensed under the GPL 3.0 License.

See LICENSE.

Sponsors

If you use Flipt at your company, please consider becoming a sponsor today.

Enterprise

Need more features or support using Flipt within your Enterprise?

Please help me prioritize an Enterprise version of Flipt by filling out this short survey!

Potential Features

  • Business-friendly Licensing
  • User Management and Audit Trail
  • Multiple Environments (ex: dev/staging/prod)

Author

twitter/mark_a_phelps
Mark Phelps

Contributing

I would love your help! Before submitting a PR, please read over the Contributing guide.

No contribution is too small, whether it be bug reports/fixes, feature requests, documentation updates, or anything else that can help drive the project forward.

Contributors

Thanks goes to these wonderful people (emoji key):


Aaron Raff

💻

Rodrigo Chacon

💻

Christopher Diehl

💻

Andrew Z Allen

📖

Sebastien Armand

💻

Dat Tran

💻

Jon Perl

⚠️ 💻

Or Elimelech

💻

giddel

💻

Eduardo

📖 💻

This project follows the all-contributors specification. Contributions of any kind welcome!