|
1 | 1 | --- |
2 | | -- name: Patch leaf control plane with barbican-keystone-listener transport URL |
| 2 | +# Configure the leaf barbican-keystone-listener to use the Skupper |
| 3 | +# application network for cross-region RabbitMQ access. |
| 4 | +# |
| 5 | +# In the leaf region: |
| 6 | +# - Read the RabbitMQ credentials from the dedicated user credentials secret |
| 7 | +# created by the RabbitMQ operator when the TransportURL CR is reconciled. |
| 8 | +# - Patch barbicanKeystoneListener to connect to the central RabbitMQ via the |
| 9 | +# Skupper Listener endpoint using those credentials and its own pool_name. |
| 10 | +# |
| 11 | +# Variables: |
| 12 | +# cifmw_skupper_central_namespace (default: openstack) |
| 13 | +# cifmw_skupper_leaf_namespace (default: openstack2) |
| 14 | +# cifmw_skupper_listener_host (default: rabbitmq-regionone) |
| 15 | +# Must match the host set in skupper-listener.yaml. |
| 16 | +# cifmw_skupper_rabbitmq_port (default: 5671) |
| 17 | +# cifmw_skupper_transport_url_name (default: barbican-keystone-listener-regiontwo) |
| 18 | +# Name of the TransportURL CR created in prepare-leaf.yaml. The operator |
| 19 | +# creates a user credentials secret named: |
| 20 | +# rabbitmq-user-<name>-<username>-user |
| 21 | +# cifmw_skupper_transport_url_username (default: barbican-keystone-listener-regiontwo) |
| 22 | +# Must match the username field set on the TransportURL CR in prepare-leaf.yaml. |
| 23 | +- name: Configure barbican-keystone-listener to use Skupper for cross-region RabbitMQ |
3 | 24 | hosts: localhost |
4 | 25 | gather_facts: false |
5 | 26 | vars: |
6 | | - central_namespace: openstack |
7 | | - leaf_namespace: openstack2 |
8 | | - leaf_transport_url_name: rabbitmq-transport-url-barbican-keystone-listener-regiontwo |
| 27 | + cifmw_skupper_central_namespace: openstack |
| 28 | + cifmw_skupper_leaf_namespace: openstack2 |
| 29 | + cifmw_skupper_listener_host: rabbitmq-regionone |
| 30 | + cifmw_skupper_rabbitmq_port: 5671 |
| 31 | + cifmw_skupper_transport_url_name: barbican-keystone-listener-regiontwo |
| 32 | + cifmw_skupper_transport_url_username: barbican-keystone-listener-regiontwo |
9 | 33 | tasks: |
10 | | - - name: Get transport URL secret from central namespace |
| 34 | + - name: Get RabbitMQ user credentials secret for leaf listener |
| 35 | + # The RabbitMQ operator creates a secret named |
| 36 | + # rabbitmq-user-<transport-url-name>-<username>-user that contains |
| 37 | + # the username and password fields for the dedicated RabbitMQ user. |
11 | 38 | kubernetes.core.k8s_info: |
12 | 39 | api_version: v1 |
13 | 40 | kind: Secret |
14 | | - namespace: "{{ central_namespace }}" |
15 | | - name: "{{ leaf_transport_url_name }}" |
16 | | - register: _transport_secret |
| 41 | + namespace: "{{ cifmw_skupper_central_namespace }}" |
| 42 | + name: "rabbitmq-user-{{ cifmw_skupper_transport_url_name }}-{{ cifmw_skupper_transport_url_username }}-user" |
| 43 | + register: _rabbitmq_user_secret |
17 | 44 |
|
18 | | - - name: Patch OpenStackControlPlane in leaf region with notifications transport_url |
| 45 | + - name: Patch leaf barbicanKeystoneListener to use Skupper RabbitMQ endpoint |
19 | 46 | vars: |
20 | | - _transport_url: "{{ _transport_secret.resources[0].data['transport_url'] | b64decode }}" |
| 47 | + _username: "{{ _rabbitmq_user_secret.resources[0].data['username'] | b64decode }}" |
| 48 | + _password: "{{ _rabbitmq_user_secret.resources[0].data['password'] | b64decode }}" |
21 | 49 | kubernetes.core.k8s: |
22 | 50 | state: patched |
23 | 51 | api_version: core.openstack.org/v1beta1 |
24 | 52 | kind: OpenStackControlPlane |
25 | 53 | name: controlplane |
26 | | - namespace: "{{ leaf_namespace }}" |
| 54 | + namespace: "{{ cifmw_skupper_leaf_namespace }}" |
27 | 55 | definition: |
28 | 56 | spec: |
29 | 57 | barbican: |
30 | 58 | template: |
31 | 59 | barbicanKeystoneListener: |
32 | 60 | customServiceConfig: | |
33 | 61 | [DEFAULT] |
34 | | - transport_url = {{ _transport_url }} |
| 62 | + transport_url = rabbit://{{ _username }}:{{ _password }}@{{ cifmw_skupper_listener_host }}:{{ cifmw_skupper_rabbitmq_port }}/?ssl=1 |
35 | 63 | [keystone_notifications] |
36 | | - pool_name = barbican-listener-regionTwo |
| 64 | + pool_name = barbican-listener-regiontwo |
0 commit comments