mirror of
https://github.com/Unleash/unleash.git
synced 2025-01-20 00:08:02 +01:00
3325b2d09e
And fixed a couple of typos in the Ruby tutorial 😄
---------
Co-authored-by: Melinda Fekete <melinda.fekete@getunleash.io>
196 lines
6.9 KiB
Markdown
196 lines
6.9 KiB
Markdown
---
|
||
title: How to Implement Feature Flags in Rails
|
||
description: "How to use Unleash feature flags with Rails."
|
||
slug: /feature-flag-tutorials/rails
|
||
---
|
||
|
||
Hello! In this tutorial, we’ll show you how to add feature flags to your Ruby on Rails app, using [Unleash](https://www.getunleash.io/) and the official [Unleash Ruby SDK](https://docs.getunleash.io/reference/sdks/ruby). With Unleash, an open-source feature flag service, you can use our tooling to add feature flags to your application and release new features faster.
|
||
|
||
In a classic tutorial fashion, we’ll add feature flags to a blog app made with Ruby on Rails. We’ll use feature flags to decide how many blog posts to show on the index page.
|
||
|
||
- [Prerequisites](#prerequisites)
|
||
- [1. Best practices for back-end apps with Unleash](#1-best-practices-for-back-end-apps-with-unleash)
|
||
- [2. Install a local feature flag provider](#2-install-a-local-feature-flag-provider)
|
||
- [3. Setup the Rails app](#3-setup-the-rails-app)
|
||
- [Install dependencies](#install-dependencies)
|
||
- [Setup DB](#setup-db)
|
||
- [Run the server](#run-the-server)
|
||
- [4. Restrict the number of posts](#4-restrict-the-number-of-posts)
|
||
- [5. Add Unleash to your Rails app](#5-add-unleash-to-your-rails-app)
|
||
- [6. Verify the toggle experience](#6-verify-the-toggle-experience)
|
||
- [Conclusion](#conclusion)
|
||
|
||
## Prerequisites
|
||
|
||
For this tutorial, you’ll need the following:
|
||
|
||
- Rails v7+
|
||
- Git
|
||
- Docker and Docker Compose
|
||
|
||
![architecture diagram for our implementation](./diagram.png)
|
||
|
||
The Unleash Server is a **Feature Flag Control Service**, which manages your feature flags and lets you retrieve flag data. Unleash has a UI for creating and managing projects and feature flags. There are also [API commands available](https://docs.getunleash.io/reference/api/unleash) to perform the same actions straight from your CLI or server-side app.
|
||
|
||
## 1. Best practices for back-end apps with Unleash
|
||
|
||
Rails is a back-end framework, so there are special considerations to plan around when implementing feature flags.
|
||
|
||
Most importantly, you must:
|
||
|
||
- Limit feature flag payloads for scalability, security, and efficiency
|
||
- Use graceful degradation where possible to improve the resiliency of your architecture
|
||
|
||
For a complete list of architectural guidelines, including caching strategies, see our [best practices for building and scaling feature flag systems](https://docs.getunleash.io/topics/feature-flags/feature-flag-best-practices).
|
||
|
||
## 2. Install a local feature flag provider
|
||
|
||
In this section, we’ll install Unleash, run the instance locally, log in, and create a feature flag. If you prefer, you can use other tools instead of Unleash, but you’ll need to update the code accordingly. The basic steps will probably be the same.
|
||
|
||
Use Git to clone the Unleash repository and Docker to build and run it. Open a terminal window and run the following commands:
|
||
|
||
```
|
||
git clone https://github.com/unleash/unleash.git
|
||
cd unleash
|
||
docker compose up -d
|
||
|
||
```
|
||
|
||
You will now have Unleash installed onto your machine and running in the background. You can access this instance in your web browser at [http://localhost:4242](http://localhost:4242).
|
||
|
||
Log in to the platform using these credentials:
|
||
|
||
```
|
||
Username: admin
|
||
Password: unleash4all
|
||
```
|
||
|
||
Click the ‘New feature flag’ button to create a new feature flag.
|
||
|
||
![Create a new feature flag](../ruby/new-ff.png)
|
||
|
||
Call it `top-3` and enable it in the `development` environment.
|
||
|
||
![A feature flag called `top-3` is now visible.](./enable-ff.png)
|
||
|
||
Everything’s now set up on the Unleash side. Let’s set up the Rails application.
|
||
|
||
## 3. Setup the Rails app
|
||
|
||
Let's clone a basic blog repository and get it up and running. We don't want to waste time setting up a Rails codebase from scratch.
|
||
|
||
```sh
|
||
git clone https://github.com/alvinometric/rails-basic-blog
|
||
cd rails-basic-blog
|
||
```
|
||
|
||
#### Install dependencies
|
||
|
||
```sh
|
||
bundle install
|
||
```
|
||
|
||
#### Setup DB
|
||
|
||
This repository uses SQLite, so no additional dependencies are required.
|
||
|
||
Run the migration
|
||
|
||
```sh
|
||
rails db:migrate
|
||
```
|
||
|
||
Seed the DB
|
||
|
||
```sh
|
||
rails db:seed
|
||
```
|
||
|
||
#### Run the server
|
||
|
||
```sh
|
||
rails server
|
||
```
|
||
|
||
Go to [http://localhost:3000](http://localhost:3000) and check that you see the following:
|
||
|
||
![A blog app with a list of posts](./blog-app.png)
|
||
|
||
## 4. Restrict the number of posts
|
||
|
||
Right now all the blog posts are displayed on the index page. We want to use a feature flag to change that and restrict it to the three most recent posts.
|
||
|
||
Let’s create a static boolean flag, for now.
|
||
|
||
Modify the `index` method in `app/controllers/posts_controller.rb` to look like this:
|
||
|
||
```ruby
|
||
# GET /posts or /posts.json
|
||
def index
|
||
is_top3 = true
|
||
@posts = is_top3 ? Post.order(created_at: :desc).limit(3) : Post.all
|
||
end
|
||
|
||
```
|
||
|
||
Reload your browser and you should see only the 3 most recent posts.
|
||
|
||
## 5. Add Unleash to your Rails app
|
||
|
||
Now, let’s connect our project to Unleash so that you can toggle the feature flag at runtime. If you wanted to, you could also do a gradual rollout, and use it for A/B testing or more advanced functionality.
|
||
|
||
You’ll need 2 things:
|
||
|
||
- The URL of your Unleash instance’s API. It’s `http://localhost:4242/api/` for your local version. You’ll want to replace it with your remote instance.
|
||
- The API token we created on our Unleash instance.
|
||
|
||
First, install the `unleash` gem.
|
||
|
||
```sh
|
||
gem install unleash
|
||
```
|
||
|
||
Now you can initialize your Unleash client as follows:
|
||
|
||
```ruby
|
||
@unleash = Unleash::Client.new(app_name: 'rails-blog', url: 'http://localhost:4242/api/', custom_http_headers: {
|
||
'Authorization': 'YOUR_API_KEY'
|
||
})
|
||
```
|
||
|
||
You can check our [API tokens and client keys documentation](https://docs.getunleash.io/reference/api-tokens-and-client-keys) for more information.
|
||
|
||
Now, let’s add the Unleash client to our Rails controller, grab the feature flag from our local instance, and update our conditional statement. Don't forget to also update the config with your API key.
|
||
|
||
```ruby
|
||
require 'unleash'
|
||
|
||
class PostsController < ApplicationController
|
||
def index
|
||
@unleash = Unleash::Client.new(app_name: 'rails-blog', url: 'http://localhost:4242/api/', custom_http_headers: {
|
||
'Authorization': 'YOUR_API_KEY'
|
||
})
|
||
is_top3 = @unleash.is_enabled('top-3')
|
||
@posts = is_top3 ? Post.order(created_at: :desc).limit(3) : Post.all
|
||
end
|
||
|
||
```
|
||
|
||
## 6. Verify the toggle experience
|
||
|
||
Reload your browser and check that you see three blog posts displayed. Turn off the flag in your Unleash instance and reload the page. You should see all the blog posts again.
|
||
|
||
See additional use cases in our [Server-Side SDK with Ruby](https://docs.getunleash.io/reference/sdks/ruby) documentation.
|
||
|
||
> **Note:** An update to a feature flag may take 30 seconds to propagate.
|
||
|
||
## Conclusion
|
||
|
||
All done! Now you know how to add feature flags with Unleash in Rails. You’ve learned how to:
|
||
|
||
- Install Unleash
|
||
- Create and enable a feature flag
|
||
- Grab the value of a feature flag with the Ruby SDK, and use it in a Rails app
|
||
|
||
Thank you
|