The open feature operator uses the open-feature-operator-controller-manager
service account, this service account contains the following RoleBindings
:
open-feature-operator-leader-election-role
(role name:leader-election-role
)open-feature-operator-manager-role
(role name:manager-role
)open-feature-operator-proxy-role
(role name:proxy-role
)open-feature-operator-flagd-kubernetes-sync
(role name:flagd-kubernetes-sync
)
The leader-election-role
provides the operator with the required permissions to perform leader election.
The definition of this role can be found here
API Group | Resource | Verbs |
---|---|---|
- | ConfigMap |
create, delete, get, list, patch, update, watch |
- | Event |
create, patch, |
coordination.k8s.io |
Lease |
create, delete, get, list, patch, update, watch |
The manager-role
applies the rules described below, its definition can be found here.
It provides the operator with sufficient permissions over the core.openfeature.dev
resources, and the required permissions for injecting the flagd
sidecar into appropriate pods.
The ConfigMap
permissions are needed to allow the mounting of FeatureFlag
resources for file syncs.
API Group | Resource | Verbs |
---|---|---|
- | ConfigMap |
create, delete, get, list, patch, update, watch |
- | Pod |
create, delete, get, list, patch, update, watch |
- | ServiceAccount |
get, list, watch |
- | Service (*) |
create, delete, get, list, patch, update, watch |
networking.k8s.io |
Ingress (*) |
create, delete, get, list, patch, update, watch |
core.openfeature.dev |
FeatureFlag |
create, delete, get, list, patch, update, watch |
core.openfeature.dev |
FeatureFlag Finalizers |
update |
core.openfeature.dev |
FeatureFlag Status |
get, patch, update |
core.openfeature.dev |
FeatureFlagSource |
create, delete, get, list, patch, update, watch |
core.openfeature.dev |
FeatureFlagSource Finalizers |
get, update |
core.openfeature.dev |
FeatureFlagSource Status |
get, patch, update |
core.openfeature.dev |
Flagd |
create, delete, get, list, patch, update, watch |
core.openfeature.dev |
Flagd Finalizers |
update |
core.openfeature.dev |
InProcessConfiguration |
create, delete, get, list, patch, update, watch |
rbac.authorization.k8s.io |
ClusterRoleBinding |
get, list, update, watch |
The proxy-role
definition can be found here
API Group | Resource | Verbs |
---|---|---|
authentication.k8s.io |
Token Review |
create |
authentication.k8s.io |
Subject Access Review |
create |
The flagd-kubernetes-sync
role providers the permission to get, watch and list all core.openfeature.dev
resources, permitting the kubernetes sync feature in injected flagd
containers.
Its definition can be found here.
During startup the operator will backfill permissions to the flagd-kubernetes-sync
cluster role binding from the current state of the cluster, adding all service accounts from pods with the core.openfeature.dev/enabled
annotation set to "true"
, preventing unexpected behavior during upgrades.
API Group | Resource | Verbs |
---|---|---|
core.openfeature.dev |
FeatureFlagSource |
get, watch, list |
core.openfeature.dev |
FeatureFlag |
get, watch, list |
When a Pod
has the core.openfeature.dev/enabled
annotation value set to "true"
, its Service Account
is added as a subject for this role's Role Binding
, granting it all required permissions for watching its associated FeatureFlags
. As a result flagd
can provide real time events describing flag definition changes.