
Feature Flags with Optimizely
This example shows how to use Optimizely to conduct experiments using Edge Middleware.
Demo
https://feature-flag-optimizely.vercel.app
How to Use
You can choose from one of the following two methods to use this repository:
One-Click Deploy
Note: Before clicking Deploy, follow the section Set up Optimizely to create an account, set up feature flags and obtain the Optimizely SDK Key.
Clone and Deploy
Execute create-next-app with pnpm to bootstrap the example:
Note: Before running locally, follow the section Set up Optimizely to create an account, set up feature flags and obtain the Optimizely SDK Key.
Create a local environment file from example and add your Optimizely SDK Key.
Next, run Next.js in development mode:
Deploy it to the cloud with Vercel (Documentation).
Optimizely Full Stack Feature Flags and Experimentation
Optimizely Full Stack is a feature flagging and experimentation platform for websites, mobile apps, chatbots, APIs, smart devices, and anything else with a network connection.
You can deploy code behind feature flags, experiment with A/B tests, and roll out or roll back features immediately. All of this functionality is available with minimal performance impact through easy-to-use, open source SDKs.
You can use Optimizely feature flags at the edge with NextJS applications deployed on Vercel. This example uses Optimizely Javascript SDK inside a Edge Middleware as a starting point for you to implement experimentation and feature flagging for your experiences at the edge. For a guide to getting started with our platform more generally, this can be combined with the steps outlined in our Javascript Quickstart.
Identity Management
Out of the box, Optimizely's Full Stack SDKs require a user-provided identifier to be passed in at runtime to drive experiment and feature flag decisions. This example generates a unique id, stores it in a cookie and reuses it to make the decisions sticky. Another common approach would be to use an existing unique identifier available within your application.
Bucketing
For more information on how Optimizely Full Stack SDKs assign users to feature flags and experiments, see the documentation on how bucketing works.
Auto update with Optimizely Webhooks
This example fetches the latest datafile from the Optimizely CDN during every build. Deploy Hooks from Vercel can be used with Optimizely Webhooks to keep the application up to date with the latest changes in the Optimizely project.
Create a Deploy Hook in Vercel
- Navigate to Settings tab in your Vercel deployment.
- Look for the Deploy Hooks section and create a Hook.
- Generate a URL that can be used to trigger a rebuild of the deployment.
Create a Webhook in Optimizely
- Follow the instructions here to create a Webhook in your Optimizely project.
- Use the Deploy HookURL Generated from the previous section to create the Optimizely Webhook.
How it works
When a user makes a change to the Optimizely Project using the UI, the Webhook hits Vercel's Deploy Hook URL to trigger a new build on Vercel. Every new build fetches the latest version of the Optimizely datafile and uses it in the application.
Set up Optimizely
Get a free account
You need an account to follow this example. If you do not have an account, you can register for a free account. If you already have an account navigate to your Flags-enabled project.
Get your SDK Key
- Go to Settings > Primary Environment
- Copy and save the SDK Key for your primary environment. Note: Each environment has its own SDK key.
- Go back to the Vercel dashboard, click on your project and go to Settings > Environment Variables
- Create a new Environment Variable called OPTIMIZELY_SDK_KEY
- Paste your Optimizely SDK Key as its value and Save
Create the feature flag
A feature flag lets you control the users that are exposed to a new feature code in your app. For this example, imagine that you are rolling out a redesigned sorting feature for displaying products.
Create a flag in Optimizely named product_sort and give it a variable named sort_method:
- Go to Flags > Create Flag.
- Name the flag key product_sort and click Create Flag, which corresponds to the flag key in this example.
- Go to Default Variables and click New (+).
- Set the variable type to "String".
- Name the variable sort_method, which corresponds to the variable key in this example.
- Set the variable default value to alphabetical, which represents your old sorting method.
- Click Save at the lower right corner to save the variable.
- Go to Variations and click the default "on" variation. A variation is a wrapper for a collection of variable values.
- Set the sort_method variable value to popular_first, which represents your new sorting method.
- Click Save.
Create the flag delivery rule
Make a targeted delivery rule for the "on" variation for the product_sort flag. A targeted delivery lets you gradually release a feature flag to users, with the flexibility to roll it back if you encounter bugs.
- 
Verify that you are in your primary environment (since you are using the primary environment SDK key): 
- 
Click Add Rule and select Targeted Delivery. 
- 
Set the traffic slider to 50%. This delivers the flag to 50% of everyone who triggers the flag in this environment. You can roll out or roll back the product_sort flag to a percentage of traffic whenever you want. 
- 
select On from the Deliver dropdown, . 
- 
Click Save. 
- 
Enable the flag for your flag rule: 
