Merge "Add support for deploying Keystone with Fernet"
This commit is contained in:
commit
9a868c3753
@ -45,6 +45,10 @@ keystone_revocation_driver: keystone.contrib.revoke.backends.sql.Revoke
|
|||||||
keystone_revocation_cache_time: 3600
|
keystone_revocation_cache_time: 3600
|
||||||
keystone_revocation_expiration_buffer: 1800
|
keystone_revocation_expiration_buffer: 1800
|
||||||
|
|
||||||
|
## Fernet config vars
|
||||||
|
keystone_fernet_tokens_key_repository: "/etc/keystone/fernet-keys"
|
||||||
|
keystone_fernet_tokens_max_active_keys: 3
|
||||||
|
|
||||||
keystone_cache_expiration_time: 5400
|
keystone_cache_expiration_time: 5400
|
||||||
|
|
||||||
keystone_assignment_driver: keystone.assignment.backends.sql.Assignment
|
keystone_assignment_driver: keystone.assignment.backends.sql.Assignment
|
||||||
@ -161,6 +165,7 @@ keystone_apt_packages:
|
|||||||
- libldap2-dev
|
- libldap2-dev
|
||||||
- libsasl2-dev
|
- libsasl2-dev
|
||||||
- libxslt1.1
|
- libxslt1.1
|
||||||
|
- rsync
|
||||||
|
|
||||||
# Common pip packages
|
# Common pip packages
|
||||||
keystone_pip_packages:
|
keystone_pip_packages:
|
||||||
|
29
tasks/keystone_fernet.yml
Normal file
29
tasks/keystone_fernet.yml
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
---
|
||||||
|
# Copyright 2015, Rackspace US, 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.
|
||||||
|
|
||||||
|
- include: keystone_fernet_keys_create.yml
|
||||||
|
when: >
|
||||||
|
inventory_hostname == groups['keystone_all'][0]
|
||||||
|
|
||||||
|
- include: keystone_fernet_keys_fetch.yml
|
||||||
|
when: >
|
||||||
|
inventory_hostname == groups['keystone_all'][0]
|
||||||
|
|
||||||
|
- include: keystone_fernet_keys_distribute.yml
|
||||||
|
when: >
|
||||||
|
inventory_hostname != groups['keystone_all'][0] and
|
||||||
|
inventory_hostname in groups['keystone_all']
|
||||||
|
|
||||||
|
- include: keystone_fernet_cleanup.yml
|
24
tasks/keystone_fernet_cleanup.yml
Normal file
24
tasks/keystone_fernet_cleanup.yml
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
---
|
||||||
|
# Copyright 2015, Rackspace US, 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: Clean up the local key clone
|
||||||
|
local_action:
|
||||||
|
module: file
|
||||||
|
path="/tmp/{{ keystone_fernet_tokens_key_repository|basename }}"
|
||||||
|
state=absent
|
||||||
|
tags:
|
||||||
|
- keystone-cleanup
|
||||||
|
- keystone-setup
|
||||||
|
- keystone-fernet
|
38
tasks/keystone_fernet_keys_create.yml
Normal file
38
tasks/keystone_fernet_keys_create.yml
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
---
|
||||||
|
# Copyright 2015, Rackspace US, 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: Check if fernet keys already exist
|
||||||
|
stat:
|
||||||
|
path: "{{ keystone_fernet_tokens_key_repository }}/0"
|
||||||
|
register: _fernet_keys
|
||||||
|
tags:
|
||||||
|
- keystone-fernet
|
||||||
|
|
||||||
|
- name: Create fernet keys for Keystone
|
||||||
|
command: keystone-manage fernet_setup --keystone-user "{{ keystone_system_user_name }}" --keystone-group "{{ keystone_system_group_name }}"
|
||||||
|
sudo: yes
|
||||||
|
sudo_user: "{{ keystone_system_user_name }}"
|
||||||
|
when: not _fernet_keys.stat.exists
|
||||||
|
tags:
|
||||||
|
- keystone-setup
|
||||||
|
- keystone-fernet
|
||||||
|
|
||||||
|
- name: Rotate fernet keys for Keystone
|
||||||
|
command: keystone-manage fernet_rotate --keystone-user "{{ keystone_system_user_name }}" --keystone-group "{{ keystone_system_group_name }}"
|
||||||
|
sudo: yes
|
||||||
|
sudo_user: "{{ keystone_system_user_name }}"
|
||||||
|
when: _fernet_keys.stat.exists
|
||||||
|
tags:
|
||||||
|
- keystone-fernet
|
24
tasks/keystone_fernet_keys_distribute.yml
Normal file
24
tasks/keystone_fernet_keys_distribute.yml
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
---
|
||||||
|
# Copyright 2015, Rackspace US, 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: Distribute the fernet keys to the other keystone containers
|
||||||
|
synchronize:
|
||||||
|
src: "/tmp/{{ keystone_fernet_tokens_key_repository|basename }}"
|
||||||
|
dest: "{{ keystone_fernet_tokens_key_repository|dirname }}"
|
||||||
|
recursive: yes
|
||||||
|
delete: yes
|
||||||
|
tags:
|
||||||
|
- keystone-setup
|
||||||
|
- keystone-fernet
|
24
tasks/keystone_fernet_keys_fetch.yml
Normal file
24
tasks/keystone_fernet_keys_fetch.yml
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
---
|
||||||
|
# Copyright 2015, Rackspace US, 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: Fetch the fernet key repository
|
||||||
|
synchronize:
|
||||||
|
src: "{{ keystone_fernet_tokens_key_repository }}"
|
||||||
|
dest: /tmp/
|
||||||
|
recursive: yes
|
||||||
|
mode: pull
|
||||||
|
tags:
|
||||||
|
- keystone-setup
|
||||||
|
- keystone-fernet
|
@ -50,6 +50,21 @@
|
|||||||
tags:
|
tags:
|
||||||
- keystone-dirs
|
- keystone-dirs
|
||||||
|
|
||||||
|
- name: Create keystone fernet-keys dir
|
||||||
|
file:
|
||||||
|
path: "{{ item.path }}"
|
||||||
|
state: directory
|
||||||
|
owner: "{{ item.owner|default(keystone_system_user_name) }}"
|
||||||
|
group: "{{ item.group|default(keystone_system_group_name) }}"
|
||||||
|
mode: "{{ item.mode }}"
|
||||||
|
with_items:
|
||||||
|
- { path: "{{ keystone_fernet_tokens_key_repository }}", mode: '0750' }
|
||||||
|
when: >
|
||||||
|
'fernet' in keystone_token_provider
|
||||||
|
tags:
|
||||||
|
- keystone-dirs
|
||||||
|
- keystone-fernet
|
||||||
|
|
||||||
- name: Test for log directory or link
|
- name: Test for log directory or link
|
||||||
shell: |
|
shell: |
|
||||||
if [ -h "/var/log/keystone" ]; then
|
if [ -h "/var/log/keystone" ]; then
|
||||||
|
@ -15,6 +15,11 @@
|
|||||||
|
|
||||||
- include: keystone_pre_install.yml
|
- include: keystone_pre_install.yml
|
||||||
- include: keystone_install.yml
|
- include: keystone_install.yml
|
||||||
|
|
||||||
|
- include: keystone_fernet.yml
|
||||||
|
when: >
|
||||||
|
'fernet' in keystone_token_provider
|
||||||
|
|
||||||
- include: keystone_post_install.yml
|
- include: keystone_post_install.yml
|
||||||
|
|
||||||
- include: keystone_db_setup.yml
|
- include: keystone_db_setup.yml
|
||||||
|
@ -54,6 +54,11 @@ max_pool_size = {{ keystone_database_max_pool_size }}
|
|||||||
pool_timeout = {{ keystone_database_pool_timeout }}
|
pool_timeout = {{ keystone_database_pool_timeout }}
|
||||||
|
|
||||||
|
|
||||||
|
[fernet_keys]
|
||||||
|
key_repository = {{ keystone_fernet_tokens_key_repository }}
|
||||||
|
max_active_keys = {{ keystone_fernet_tokens_max_active_keys }}
|
||||||
|
|
||||||
|
|
||||||
[identity]
|
[identity]
|
||||||
driver = {{ keystone_identity_driver }}
|
driver = {{ keystone_identity_driver }}
|
||||||
{% if keystone_ldap is defined %}
|
{% if keystone_ldap is defined %}
|
||||||
|
Loading…
Reference in New Issue
Block a user