-
Notifications
You must be signed in to change notification settings - Fork 19
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Describe advanced local feature flag configuration #326
base: main
Are you sure you want to change the base?
Changes from 2 commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change | ||||
---|---|---|---|---|---|---|
@@ -1,8 +1,3 @@ | ||||||
--- | ||||||
sidebar_custom_props: | ||||||
access: bitwarden | ||||||
--- | ||||||
|
||||||
# Feature Flags | ||||||
|
||||||
## Background | ||||||
|
@@ -97,6 +92,107 @@ configuration setting can be used to override it. The file must be present befor | |||||
solution, but once there you can change the file contents and see immediate results in running / | ||||||
debugging code. | ||||||
|
||||||
<details> | ||||||
<summary>Context-aware feature flag JSON</summary> | ||||||
<div> | ||||||
<div> | ||||||
The `flags.json` file can also define flags which respond to user context. Currently, only `UserId`and the `OrganizationId` of all organizations a user belongs to are included in our feature flagging context. The syntax for defining context-aware flags amounts to defining a `flag` object which specifies `variations` values and `rules` which are evaluated against the user context. A `fallthrough` object is also available to specify a default variation. Rules are represented by `segments`, which are defined in the same file. | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. ⛏️ This is also violating our line lengths since it's in custom HTML. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. ❌ We support an addition service account context as well that's omitted. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Good point, we actually have three |
||||||
|
||||||
A Feature flag may not appear in both the `flags` object and in the `flagValues` object. | ||||||
MGibson1 marked this conversation as resolved.
Show resolved
Hide resolved
|
||||||
|
||||||
Note that UserId is referred to as `key` in the `clauses` object while defining a segment. | ||||||
MGibson1 marked this conversation as resolved.
Show resolved
Hide resolved
|
||||||
</div> | ||||||
<br/> | ||||||
<details> | ||||||
<summary> | ||||||
JSON example | ||||||
</summary> | ||||||
<div> | ||||||
|
||||||
```json | ||||||
{ | ||||||
"flagValues": { | ||||||
"example-single-boolean-key": true, | ||||||
}, | ||||||
"flags": { | ||||||
"example-advanced-configuration": { | ||||||
"key": "example-advanced-configuration", | ||||||
"on": true, | ||||||
"variations": [ | ||||||
false, | ||||||
true | ||||||
], | ||||||
"fallthrough": { | ||||||
"variation": 0 | ||||||
}, | ||||||
"rules": [ | ||||||
{ | ||||||
"variation": 1, | ||||||
"clauses": [ | ||||||
{ | ||||||
"contextKind": "user", | ||||||
"attribute": "segmentMatch", | ||||||
"op": "segmentMatch", | ||||||
"values": [ | ||||||
"user-segment" | ||||||
] | ||||||
} | ||||||
] | ||||||
} | ||||||
], | ||||||
"version": 1 | ||||||
} | ||||||
}, | ||||||
"segments": { | ||||||
"user-segment": { | ||||||
"key": "user-segment", | ||||||
"rules": [ | ||||||
{ | ||||||
"clauses": [ | ||||||
{ | ||||||
"contextKind": "user", | ||||||
"attribute": "key", | ||||||
"op": "in", | ||||||
"values": [ | ||||||
"<<UserIdGuid>>", | ||||||
"<<UserIdGuid>>" | ||||||
... | ||||||
] | ||||||
} | ||||||
] | ||||||
} | ||||||
], | ||||||
"version": 1 | ||||||
}, | ||||||
"organization-segment": { | ||||||
"key": "organization-segment", | ||||||
"rules": [ | ||||||
{ | ||||||
"clauses": [ | ||||||
{ | ||||||
"contextKind": "user", | ||||||
"attribute": "organizations", | ||||||
"op": "in", | ||||||
"values": [ | ||||||
"<<OragnizationIdGuid>>", | ||||||
"<<OragnizationIdGuid>>" | ||||||
... | ||||||
] | ||||||
} | ||||||
] | ||||||
} | ||||||
] | ||||||
} | ||||||
} | ||||||
} | ||||||
``` | ||||||
|
||||||
</div> | ||||||
</details> | ||||||
|
||||||
</div> | ||||||
</details> | ||||||
|
||||||
### Local configuration: code modification | ||||||
|
||||||
In some situations there may be a need to change a feature flag value to be something other than its | ||||||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
❓ Why open this up to everyone? We do not want to encourage usage of this except internally.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The metric I use for internal vs external is whether or not special access is required. The feature flags is in the AGPL licensed section of the codebase and not blocked by any employee-specific secrets.
I don't see why we wouldn't want external contributors feature flagging their contributions, if it makes sense and they are able.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
They're not able, since we'd have to register flags in LD. If you think an engineer would connect with them to do that then alright, but it's a bit of a jump from today.
There's sometimes an eagerness to adopt features in the community and what's happened is users start trying to put these developer overrides in and have problems, therefore increasing support needs. I want the impetus to be on our internal engineering team to quickly remove these in a follow-up release instead.