Skip to main content

How to use feature flags in a FaaS application

· 6 min read
Chavez Harris

With the rise of cloud computing, Function as a Service (FaaS) services are becoming quite popular in the software industry. This is in part due to them not requiring the setup and implementation of a backend server to process and respond to data requests. This allows developers to focus on doing what they do best, writing better code.

By integrating such a service with feature flags, you can expand the way your functions work by toggling functionalities on or off and even rolling them back if anything goes wrong. Added to that, there is no limit on the number of feature flags you can implement, and they can be integrated into just about any language and framework out there.

using feature flags in a faas application cover

What are feature flags

Feature flags, or feature switches as they are sometimes called, are boolean values that can be used to turn on or off various features, components, or functionalities in your application. Typically, they are used in conditional "if" statements to control which features users will see.

Feature flagging can be used in many programming languages and the cloud is no exception. Let's dive in and explore how to use them in a FaaS application.

Before getting started let's take a look at the prerequisites to get up and running:

Prerequisites

Using feature flags in a FaaS app

Traditionally, a full-stack web application required two major components. Frontend - What the user sees and interacts with. Backend - a server that processes requests from the frontend.

With FaaS, a backend server is no longer required when building applications. Instead, you create functions that can be invoked from your frontend to perform single or multiple tasks. That's it!

Up and running with Google Cloud Functions

While there are many cloud service providers in the market today offering FaaS, Let's narrow our attention to a popular one from Google, Cloud Functions. I'll use it to build a simple weather app to return JSON data about the weather in a particular country, let’s say France for example. To get up and running with Google Cloud Functions, you'll need to do the following:

1. Sign up for a Free tier Google Cloud account

2. In the console, create a new project:

Creating a new project in Google

3. Create a new function with the following details:

Creating a cloud function

4. Select the runtime environment for executing the function. I'll be selecting node 16 in this case. This will result in two files being generated. An index.js file and a package.json file.

The newly created cloud function

Using a feature flag, I will control how the app responds. When the feature flag is on, it will return the weather information in France as JSON and when it's off the response will be "Sorry this service is unavailable. Try again later". To do this, I'll use ConfigCat's feature flag service.

Integrating with ConfigCat

1. To use ConfigCat, you'll need to sign up for a free account.

2. In the dashboard, create a feature flag with the following details.

Screenshot of creating a feature flag

3. Because my function will be executed in a node runtime environment, I will add ConfigCat's Node SDK as a dependency. With this SDK, the app will be able to access your ConfigCat dashboard and probe the feature flag status. While I'm here I'll also add the node-fetch package as a dependency that I'll use later on to make a fetch request.

{
"dependencies": {
"@google-cloud/functions-framework": "^3.0.0",
"configcat-node": "^8.0.1",
"node-fetch": "^2.6.7"
}
}

4. Include the SDK client in the index.js file:

const configcat = require("configcat-node");

5. Create the client using your SDK key. As a general rule, this key should be kept private and away from your codebase.

let configCatClient = configcat.createClient("YOUR_SDK_KEY")

6. In the entry point function, I'll use the client above to call the probe the status of the feature flag:

const isWeatherInfoFeatureFlagEnabled = await configCatClient.getValueAsync("weatherinfo",  false);

7. I'll use it in an if statement. If the value returned is true, the function will return the weather info for France fetched from the Open Weather API.

if (isWeatherInfoFeatureFlagEnabled) {
const myData = await fetch('http://api.openweathermap.org/data/2.5/weather?q=france&appid=YOUR-OPENWEATHER-API-KEY');
const myDataAsJson = await myData.json()
res.send(myDataAsJson);
} else {
// This response is returned when the feature flag is switched off
res.send("Sorry, this service is unavailable. Try again later.");
}

You can find the complete code for the index.js file here.

8. Deploy the function:

Save and deploy the function

By visiting the deployed app in your browser you should get the following response:

Response from FaaS application

Test drive

1. Head over to the ConfigCat dashboard and turn off the feature flag.

Screenshot of turning the feature flag off

2. Refresh the page, and you should now see the custom error string we set earlier.

Custom error message displayed - feature flag turned off

3. That's it!

If you need to target a specific user group based on demographics and personal characteristics, you can do this right on your ConfigCat dashboard by creating a user segment. As a result, when the feature flag is enabled, only users belonging to that segment will be able to see it. For example, you could release a feature only to London users.

Conclusion

We've discussed how to integrate feature flags into FaaS applications without any difficulties. By combining your cloud functions with feature flags, you can extend your cloud functions' capabilities, and Google is not the only one supported. Because feature flags are platform-agnostic you can use them in many languages and frameworks.

The dashboard of ConfigCat is really simple to use. Apart from adding feature flags, having the ability to set up user segmentation for targeting feature releases to specific user groups is helpful when doing A/B testing. With an account, you get a generous free tier for low-volume use cases which is ideal for getting started with feature flags.

Stay connected

For more awesome posts and other announcements, follow ConfigCat on Twitter, Facebook, LinkedIn, and GitHub. The most lovable feature flag service, ever.