Skip to content
Draft
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
26 commits
Select commit Hold shift + click to select a range
c915f71
feat: add keystoneauth_kubeservicetoken authentication plugin
skrobul Mar 26, 2026
8db97a5
feat: add oidc-rbac component for service account issuer discovery
skrobul May 12, 2026
9d92658
feat: install keystoneauth-kubeservicetoken in OpenStack containers
skrobul May 13, 2026
7db0eb0
drop! change to test OpenStack images
skrobul May 13, 2026
4c3b575
chore: update keystone-service-user secrets to OIDC
skrobul May 14, 2026
80faa9e
chore: generate provider metadata script
skrobul May 14, 2026
442ec58
chore: recreate keystne-keystone-admin from ES
skrobul May 14, 2026
bdef7a4
fix: try adding volume to init_container
skrobul May 14, 2026
0816bda
oidc: change approach from init container to static CM
skrobul May 15, 2026
3f684ca
keystone: add mod_oauth2 module
skrobul May 20, 2026
62bfae9
keystone: enable oauth2 module on build
skrobul May 20, 2026
daab144
keystone: try oauth2 with ld cache refresh
skrobul May 20, 2026
1483b75
keystone: switch to libapache2-mod-oauth2 provided by Ubuntu
skrobul May 20, 2026
fed08ac
keystone: create k8s service account group and roles
skrobul May 26, 2026
846007c
feat: create federation mapping for k8s
skrobul May 26, 2026
8d604db
keystone: create k8s identity providers and protocols
skrobul May 26, 2026
b565bf2
keystone: stop requiring keystone aud in mapping
skrobul May 26, 2026
34c2240
keystone: setup k8s-serviceaccounts in correct domain
skrobul May 26, 2026
a35534e
chore: upgrade openstack to 2026.1
skrobul Jun 3, 2026
5b7f5ae
include v3oidcaccessfiletoken in openstack-client container
skrobul Jun 8, 2026
f79311e
keystone: use stringData in generated secrets to fix base64 errors
skrobul Jun 8, 2026
7462772
keystone: add admin@Default access for k8s
skrobul Jun 8, 2026
020b088
fix: keystone-service-user reference to ID provider
skrobul Jun 15, 2026
3f602a8
fix: include keystoneauth-kubeservicetoken in ironic
skrobul Jun 15, 2026
0f1e6e8
fix: restore project_name and project_domain_name
skrobul Jun 15, 2026
3463a4c
drop! fix: set image for neutron_ironic_agent
skrobul Jun 17, 2026
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
21 changes: 2 additions & 19 deletions .github/workflows/containers-openstack.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,9 @@ jobs:
- cinder
- glance
- horizon
- ironic
- keystone
- neutron
- nova
- octavia
- openstack-client
Expand All @@ -47,24 +49,5 @@ jobs:
with:
container_name: ${{ matrix.project }}
dockerfile_path: containers/${{ matrix.project }}/Dockerfile
build_args: OPENSTACK_VERSION=2025.2
latest_name: "2025.2"

neutron:
uses: ./.github/workflows/build-container-reuse.yaml
secrets: inherit
with:
container_name: neutron
dockerfile_path: containers/neutron/Dockerfile
build_args: OPENSTACK_VERSION=2026.1
latest_name: "2026.1"

ironic:
uses: ./.github/workflows/build-container-reuse.yaml
secrets: inherit
with:
container_name: ironic
dockerfile_path: containers/ironic/Dockerfile
build_args: OPENSTACK_VERSION=2026.1
latest_name: "2026.1"
target: final
29 changes: 29 additions & 0 deletions ansible/roles/keystone_bootstrap/defaults/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -68,3 +68,32 @@ keystone_bootstrap_groups:
# role: member
# - project: shared-services
# role: reader

# domain in which k8s service account groups are created
keystone_bootstrap_k8s_group_domain: service

# k8s identity providers; override with your cluster issuers
keystone_k8s_identity:
providers: []

# k8s service account groups and their project role assignments
# Each group can have project_roles with an optional domain to scope the project lookup
keystone_bootstrap_k8s_groups:
- name: k8s-serviceaccounts
desc: 'Kubernetes Service Accounts'
project_roles:
- project: service
domain: service
role: admin
- project: service
domain: service
role: service
- project: baremetal
domain: infra
role: admin
- project: baremetal
domain: infra
role: service
- project: admin
domain: Default
role: admin
54 changes: 54 additions & 0 deletions ansible/roles/keystone_bootstrap/tasks/k8s.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,54 @@
---
# Copyright (c) 2026 Rackspace Technology, Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.

- name: Create k8s mapping
openstack.cloud.federation_mapping:
name: k8s-mapping
rules:
- local:
- user:
name: '{0}'
group:
domain:
name: service
name: k8s-serviceaccounts
remote:
- type: HTTP_OIDC_SUB

- name: Create k8s identity providers
openstack.cloud.federation_idp:
name: "{{ item.name }}"
is_enabled: true
remote_ids:
- "{{ item.issuer }}"
loop: "{{ keystone_k8s_identity.providers }}"

- name: Create k8s openid protocols
openstack.cloud.keystone_federation_protocol:
name: openid
idp: "{{ item.name }}"
mapping: k8s-mapping
loop: "{{ keystone_k8s_identity.providers }}"

- name: Get k8s group domain info
openstack.cloud.identity_domain_info:
name: "{{ keystone_bootstrap_k8s_group_domain }}"
register: _k8s_group_domain

- name: Create k8s service account group mappings
ansible.builtin.include_tasks: k8s_group.yml
loop: "{{ keystone_bootstrap_k8s_groups }}"
loop_control:
loop_var: group_item
34 changes: 34 additions & 0 deletions ansible/roles/keystone_bootstrap/tasks/k8s_group.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
---
# Copyright (c) 2026 Rackspace Technology, Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.

- name: Create k8s group
openstack.cloud.identity_group:
name: "{{ group_item.name }}"
domain_id: "{{ _k8s_group_domain.domains[0].id }}"
description: "{{ group_item.desc }}"
state: present
register: _k8s_group

- name: Assign role to k8s group for project
openstack.cloud.role_assignment:
group: "{{ _k8s_group.group.id }}"
project: "{{ role_item.project }}"
project_domain: "{{ role_item.domain | default(omit) }}"
role: "{{ role_item.role }}"
state: present
loop: "{{ group_item.project_roles | default([]) }}"
loop_control:
loop_var: role_item
when: dont_set_roles is not defined
3 changes: 3 additions & 0 deletions ansible/roles/keystone_bootstrap/tasks/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -10,5 +10,8 @@
- name: Define SSO
ansible.builtin.include_tasks: sso.yml

- name: Define k8s service account groups
ansible.builtin.include_tasks: k8s.yml

- name: Define misc keystone
ansible.builtin.include_tasks: misc.yml
30 changes: 30 additions & 0 deletions charts/argocd-understack/templates/application-oidc-rbac.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
{{- if or (eq (include "understack.isEnabled" (list $.Values.global "oidc_rbac")) "true") (eq (include "understack.isEnabled" (list $.Values.site "oidc_rbac")) "true") }}
---
apiVersion: argoproj.io/v1alpha1
kind: Application
metadata:
name: {{ printf "%s-%s" $.Release.Name "oidc-rbac" }}
finalizers:
- resources-finalizer.argocd.argoproj.io
annotations:
argocd.argoproj.io/compare-options: ServerSideDiff=true,IncludeMutationWebhook=true
{{- include "understack.appLabelsBlock" $ | nindent 2 }}
spec:
destination:
namespace: kube-system
server: {{ $.Values.cluster_server }}
project: understack-infra
sources:
- path: components/oidc-rbac
ref: understack
repoURL: {{ include "understack.understack_url" $ }}
targetRevision: {{ include "understack.understack_ref" $ }}
syncPolicy:
automated:
prune: true
selfHeal: true
syncOptions:
- ServerSideApply=true
- RespectIgnoreDifferences=true
- ApplyOutOfSyncOnly=true
{{- end }}
30 changes: 21 additions & 9 deletions charts/argocd-understack/values.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -166,6 +166,12 @@ global:
# @default -- false
enabled: false

# -- OIDC RBAC (ClusterRoleBindings for OIDC service account issuer discovery)
oidc_rbac:
# -- Enable/disable deploying OIDC RBAC
# @default -- false
enabled: false

# -- OpenEBS
openebs:
# -- Enable/disable deploying OpenEBS
Expand Down Expand Up @@ -338,7 +344,7 @@ site:
wave: 1
# -- Chart version for Keystone
# renovate: datasource=helm depName=keystone registryUrl=https://tarballs.opendev.org/openstack/openstack-helm
chartVersion: 2025.2.14+3bc47c1e9
chartVersion: 2026.1.4+872fd69e7

# -- Glance (Image Service)
glance:
Expand All @@ -350,7 +356,7 @@ site:
wave: 2
# -- Chart version for Glance
# renovate: datasource=helm depName=glance registryUrl=https://tarballs.opendev.org/openstack/openstack-helm
chartVersion: 2025.2.7+01c93d867
chartVersion: 2026.1.3+872fd69e7

# -- Cinder (Block Storage Service)
cinder:
Expand All @@ -362,7 +368,7 @@ site:
wave: 2
# -- Chart version for Cinder
# renovate: datasource=helm depName=cinder registryUrl=https://tarballs.opendev.org/openstack/openstack-helm
chartVersion: 2025.1.3+abd55b4a7
chartVersion: 2026.1.5+872fd69e7

# -- Ironic (Bare Metal Service)
ironic:
Expand All @@ -374,7 +380,7 @@ site:
wave: 2
# -- Chart version for Ironic
# renovate: datasource=helm depName=ironic registryUrl=https://tarballs.opendev.org/openstack/openstack-helm
chartVersion: 2025.2.23+ea0d1ecda
chartVersion: 2026.1.7+872fd69e7

# -- Neutron (Networking Service)
neutron:
Expand All @@ -398,7 +404,7 @@ site:
wave: 2
# -- Chart version for Placement
# renovate: datasource=helm depName=placement registryUrl=https://tarballs.opendev.org/openstack/openstack-helm
chartVersion: 2025.2.17+bb8dd0598
chartVersion: 2026.1.3+872fd69e7

# -- Nova (Compute Service)
nova:
Expand All @@ -410,7 +416,7 @@ site:
wave: 3
# -- Chart version for Nova
# renovate: datasource=helm depName=nova registryUrl=https://tarballs.opendev.org/openstack/openstack-helm
chartVersion: 2025.2.22+008600f9e
chartVersion: 2026.1.7+872fd69e7

# -- Octavia (Load Balancer Service)
octavia:
Expand All @@ -422,7 +428,7 @@ site:
wave: 3
# -- Chart version for Octavia
# renovate: datasource=helm depName=octavia registryUrl=https://tarballs.opendev.org/openstack/openstack-helm
chartVersion: 2025.2.8+01c93d867
chartVersion: 2026.1.4+872fd69e7

# -- Horizon (Dashboard)
horizon:
Expand All @@ -434,7 +440,7 @@ site:
wave: 4
# -- Chart version for Horizon
# renovate: datasource=helm depName=horizon registryUrl=https://tarballs.opendev.org/openstack/openstack-helm
chartVersion: 2025.2.4+01c93d867
chartVersion: 2026.1.2+872fd69e7

# -- Skyline (Dashboard)
skyline:
Expand All @@ -446,7 +452,7 @@ site:
wave: 4
# -- Chart version for Skyline
# renovate: datasource=helm depName=skyline registryUrl=https://tarballs.opendev.org/openstack/openstack-helm
chartVersion: 2025.2.5+01c93d867
chartVersion: 2026.1.2+872fd69e7

# -- Open vSwitch (Networking)
openvswitch:
Expand Down Expand Up @@ -505,6 +511,12 @@ site:
# @default -- false
enabled: false

# -- OIDC RBAC (ClusterRoleBindings for OIDC service account issuer discovery)
oidc_rbac:
# -- Enable/disable deploying OIDC RBAC
# @default -- false
enabled: false

# -- OpenEBS
openebs:
# -- Enable/disable deploying OpenEBS
Expand Down
Loading
Loading