description |
---|
flagd semver custom operation |
OpenFeature allows clients to pass contextual information which can then be used during a flag evaluation. For example, a client could pass the email address of the user.
In some scenarios, it is desirable to use that contextual information to segment the user population further and thus return dynamic values.
The sem_ver
evaluation checks if the given property matches a semantic versioning condition.
It returns 'true', if the value of the given property meets the condition, 'false' if not.
Note that the 'sem_ver' evaluation rule must contain exactly three items:
- Target property: this needs which both resolve to a semantic versioning string
- Operator: One of the following:
=
,!=
,>
,<
,>=
,<=
,~
(match minor version),^
(match major version) - Target value: this needs which both resolve to a semantic versioning string
The sem_ver
evaluation returns a boolean, indicating whether the condition has been met.
{
"if": [
{
"sem_ver": [{"var": "version"}, ">=", "1.0.0"]
},
"red", null
]
}
Flags defined as such:
{
"$schema": "https://flagd.dev/schema/v0/flags.json",
"flags": {
"headerColor": {
"variants": {
"red": "#FF0000",
"blue": "#0000FF",
"green": "#00FF00"
},
"defaultVariant": "blue",
"state": "ENABLED",
"targeting": {
"if": [
{
"sem_ver": [{"var": "version"}, ">=", "1.0.0"]
},
"red", "green"
]
}
}
}
}
will return variant red
, if the value of the version
is a semantic version that is greater than or equal to 1.0.0
.
Command:
curl -X POST "localhost:8013/flagd.evaluation.v1.Service/ResolveString" -d '{"flagKey":"headerColor","context":{"version": "1.0.1"}}' -H "Content-Type: application/json"
Result:
{"value":"#00FF00","reason":"TARGETING_MATCH","variant":"red"}
Command:
curl -X POST "localhost:8013/flagd.evaluation.v1.Service/ResolveString" -d '{"flagKey":"headerColor","context":{"version": "0.1.0"}}' -H "Content-Type: application/json"
Result:
{"value":"#0000FF","reason":"TARGETING_MATCH","variant":"green"}