Flipping Feature Flags
Oftentimes, you need to toggle different feature flags (number of accounts, expiration time, admin access) in your application, per user (diagram below).
data:image/s3,"s3://crabby-images/4c89d/4c89d59aae341e3bf9ca1eee2358b6ccf7f9b580" alt="Messages Image(3194620760).png 3050"
In this tutorial we will run through a sample tutorial of how this system could work.
This quickstart requires you to sign up for DataSiv.
If you haven't already, please sign up here
Add the table, switch, datepicker, and slider components into the canvas.
Next, click the Add Data Query option and choose Rest Api
.
data:image/s3,"s3://crabby-images/3679d/3679df298e7a6fe4930854a1e3fa636d398f67a1" alt="4.png 2578"
DataSiv provides integrations and read/write capabilities across multiple sources
Although we use Google Sheets and a SQL database in this tutorial, you can swap these out with other supported integrations, such as a Rest Api Endpoint, GraphQL, Salesforce, Stripe, etc.
We will be using the following publicly available api to simulate users.
Set the url to https://jsonplaceholder.typicode.com/users
.
data:image/s3,"s3://crabby-images/fc0d6/fc0d6df473b03cdf448b32c87535559ef3776149" alt="7.png 2572"
Set Automatic Execution to On Document Load
so the Rest API query triggers on document loading.
data:image/s3,"s3://crabby-images/a70f4/a70f4fc64c3b6f43ca1b5ad36fdf74b691b215a8" alt="Messages Image(4240637757).png 2700"
Click on the table, select Edit Data and set the data source to queries.rest0.data
.
data:image/s3,"s3://crabby-images/e753f/e753f1d9723e71438783361a96554c061e8026d5" alt="3.png 1982"
Change the SelectRows property to single, as we will be selecting one user at a time.
Change the title of the text field to Update Feature Flags for User {{data.table0.selectedRow.0.id}}
.
data:image/s3,"s3://crabby-images/4c50d/4c50d757b22bfcd13ddde3e37d1dff6a39d9abc5" alt="Messages Image(1785816024).png 432"
What are {{}} good for?
All component properties are stored in a global key value store that other components in the app are able to access. You are able to reference other components using javascript dictionary terminology.
Based on Django's templated {{}} syntax, the special
{{}}
expression allows you to substitute in values from one set of objects in your application to another. For example, in the Text query above, we reference the selectedRow property of the table component with identifier table0. Since selectedRow references an array of json dictionaries (all of which contain anid
property), and we want to get the first selected row's user id, we referenceselectedRow.0.id
. As all data components are stored under the global data key, to reference this component, we would write{{data.table0.selectedRow.0.id}}
.
Next, create a new Rest API query with the following artificial parameters, which will reference the feature flags for the particular user.
data:image/s3,"s3://crabby-images/f2f06/f2f065023b313aa6d8f638f8a317ccc684bd3952" alt="10.png 2402"
Set the execution for this Rest API command to never.
data:image/s3,"s3://crabby-images/2a11e/2a11ed69c4a407bf3597e55c6da773b6db969b7a" alt="Messages Image(3908296001).png 2688"
On the button, choose to run queries.rest1
for the Code property. Now, on clicking this button, you will update the feature flags to be the ones that you specify in the user interface. Congratulations!
data:image/s3,"s3://crabby-images/f0c7d/f0c7de14b8f6a7e16ce9cd826a818946dc0da476" alt="Messages Image(359891439).png 428"
Triggering data queries
The button's code property allows you to specify and trigger data queries with the special
DataSiv.ExecuteQuery(...)
function.
Congratulations! Your application is done. Now, you can flip feature flags per user, and trigger a Rest API query with the feature flags.
To test out the application, click the button. In the App Objects tab in the right sidebar, under query rest0, you should be able to see a response under the data property from the api you triggered.
Updated almost 2 years ago