openstack-ansible-os_keystone/tasks/keystone_install.yml
cloader89 8d046aa91c Update the keystone WSGI application locations
This change will update the file paths of the keystone WSGI
applications so that keystone will run properly and not just
produce errors in the logs. The virtualenvs were the primary reason
for this bug, and this solution allows for the deployment of
keystone without requiring virtualenvs provided that they override
keystone_bin.

Closes-bug: 1586161

Change-Id: Iedf4c2651d304d3034be64c781a6daf7ab0b400f
Signed-off-by: Kevin Carter <kevin.carter@rackspace.com>
2016-08-16 19:50:48 +00:00

159 lines
4.7 KiB
YAML

---
# Copyright 2014, 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_install_apt.yml
when:
- ansible_pkg_mgr == 'apt'
- name: Create WSGI symlinks
file:
src: "{{ item.src }}"
dest: "/var/www/cgi-bin/keystone/{{ item.dest }}"
state: link
force: yes
with_items:
- src: "{{ keystone_bin }}/keystone-wsgi-admin"
dest: admin
- src: "{{ keystone_bin }}/keystone-wsgi-public"
dest: main
- name: Create developer mode constraint file
copy:
dest: "/opt/developer-pip-constraints.txt"
content: |
{% for item in keystone_developer_constraints %}
{{ item }}
{% endfor %}
when:
- keystone_developer_mode | bool
- name: Clone requirements git repository
git:
repo: "{{ keystone_requirements_git_repo }}"
dest: "/opt/requirements"
clone: yes
update: yes
version: "{{ keystone_requirements_git_install_branch }}"
when:
- keystone_developer_mode | bool
- name: Add constraints to pip_install_options fact for developer mode
set_fact:
pip_install_options_fact: "{{ pip_install_options|default('') }} --constraint /opt/developer-pip-constraints.txt --constraint /opt/requirements/upper-constraints.txt"
when:
- keystone_developer_mode | bool
- name: Set pip_install_options_fact when not in developer mode
set_fact:
pip_install_options_fact: "{{ pip_install_options|default('') }}"
when:
- not keystone_developer_mode | bool
- name: Install required pip packages
pip:
name: "{{ keystone_requires_pip_packages | join(' ') }}"
state: latest
extra_args: "{{ pip_install_options_fact }}"
register: install_packages
until: install_packages|success
retries: 5
delay: 2
- name: Get local venv checksum
stat:
path: "/var/cache/{{ keystone_venv_download_url | basename }}"
get_md5: False
when:
- not keystone_developer_mode | bool
register: local_venv_stat
- name: Get remote venv checksum
uri:
url: "{{ keystone_venv_download_url | replace('tgz', 'checksum') }}"
return_content: True
when:
- not keystone_developer_mode | bool
register: remote_venv_checksum
# TODO: When project moves to ansible 2 we can pass this a sha256sum which will:
# a) allow us to remove force: yes
# b) allow the module to calculate the checksum of dest file which would
# result in file being downloaded only if provided and dest sha256sum
# checksums differ
- name: Attempt venv download
get_url:
url: "{{ keystone_venv_download_url }}"
dest: "/var/cache/{{ keystone_venv_download_url | basename }}"
force: yes
ignore_errors: true
register: get_venv
when:
- not keystone_developer_mode | bool
- (local_venv_stat.stat.exists == False or
{{ local_venv_stat.stat.checksum is defined and local_venv_stat.stat.checksum != remote_venv_checksum.content | trim }})
- name: Set keystone get_venv fact
set_fact:
keystone_get_venv: "{{ get_venv }}"
- name: Remove existing venv
file:
path: "{{ keystone_bin | dirname }}"
state: absent
when:
- keystone_get_venv | changed
- name: Create keystone venv dir
file:
path: "{{ keystone_bin | dirname }}"
state: directory
register: keystone_venv_dir
when:
- not keystone_developer_mode | bool
- name: Unarchive pre-built venv
unarchive:
src: "/var/cache/{{ keystone_venv_download_url | basename }}"
dest: "{{ keystone_bin | dirname }}"
copy: "no"
when:
- not keystone_developer_mode | bool
- keystone_get_venv | changed or keystone_venv_dir | changed
notify:
- Restart Apache
- name: Install pip packages
pip:
name: "{{ keystone_pip_packages | join(' ') }}"
state: latest
virtualenv: "{{ keystone_bin | dirname }}"
virtualenv_site_packages: "no"
extra_args: "{{ pip_install_options_fact }}"
register: install_packages
until: install_packages|success
retries: 5
delay: 2
when:
- keystone_get_venv | failed or keystone_developer_mode | bool
notify:
- Restart Apache
- name: Update virtualenv path
command: >
virtualenv-tools --update-path=auto {{ keystone_bin | dirname }}
when:
- not keystone_developer_mode | bool
- keystone_get_venv | success