mirror of
https://github.com/ansible/awx.git
synced 2026-02-16 18:50:04 -03:30
Additional API housekeeping, removing unused code Treat default branch as no branch provided
154 lines
5.1 KiB
YAML
154 lines
5.1 KiB
YAML
---
|
|
# The following variables will be set by the runner of this playbook:
|
|
# project_path: PROJECTS_DIR/_local_path_
|
|
# scm_type: git|hg|svn|insights
|
|
# scm_url: https://server/repo
|
|
# insights_url: Insights service URL (from configuration)
|
|
# scm_branch: branch/tag/revision (HEAD if unset)
|
|
# scm_clean: true/false
|
|
# scm_delete_on_update: true/false
|
|
# scm_full_checkout: true (if for a job template run), false (if retrieving revision)
|
|
# scm_username: username (only for svn/insights)
|
|
# scm_password: password (only for svn/insights)
|
|
# scm_accept_hostkey: true/false (only for git, set automatically)
|
|
# scm_refspec: a refspec to fetch in addition to obtaining version
|
|
# roles_enabled: Allow us to pull roles from a requirements.yml file
|
|
# roles_destination: Path to save roles from galaxy to
|
|
# awx_version: Current running version of the awx or tower as a string
|
|
# awx_license_type: "open" for AWX; else presume Tower
|
|
|
|
- hosts: all
|
|
gather_facts: false
|
|
tasks:
|
|
|
|
- name: delete project directory before update
|
|
file:
|
|
path: "{{project_path|quote}}"
|
|
state: absent
|
|
when: scm_delete_on_update|default('')
|
|
delegate_to: localhost
|
|
|
|
- block:
|
|
- name: update project using git
|
|
git:
|
|
dest: "{{project_path|quote}}"
|
|
repo: "{{scm_url}}"
|
|
version: "{{scm_branch|quote}}"
|
|
refspec: "{{scm_refspec|default(omit)}}"
|
|
force: "{{scm_clean}}"
|
|
accept_hostkey: "{{scm_accept_hostkey|default(omit)}}"
|
|
register: git_result
|
|
|
|
- name: Set the git repository version
|
|
set_fact:
|
|
scm_version: "{{ git_result['after'] }}"
|
|
when: "'after' in git_result"
|
|
when: scm_type == 'git'
|
|
delegate_to: localhost
|
|
|
|
- block:
|
|
- name: update project using hg
|
|
hg:
|
|
dest: "{{project_path|quote}}"
|
|
repo: "{{scm_url|quote}}"
|
|
revision: "{{scm_branch|quote}}"
|
|
force: "{{scm_clean}}"
|
|
register: hg_result
|
|
|
|
- name: Set the hg repository version
|
|
set_fact:
|
|
scm_version: "{{ hg_result['after'] }}"
|
|
when: "'after' in hg_result"
|
|
|
|
- name: parse hg version string properly
|
|
set_fact:
|
|
scm_version: "{{scm_version|regex_replace('^([A-Za-z0-9]+).*$', '\\1')}}"
|
|
when: scm_type == 'hg'
|
|
delegate_to: localhost
|
|
|
|
- block:
|
|
- name: update project using svn
|
|
subversion:
|
|
dest: "{{project_path|quote}}"
|
|
repo: "{{scm_url|quote}}"
|
|
revision: "{{scm_branch|quote}}"
|
|
force: "{{scm_clean}}"
|
|
username: "{{scm_username|default(omit)}}"
|
|
password: "{{scm_password|default(omit)}}"
|
|
register: svn_result
|
|
|
|
- name: Set the svn repository version
|
|
set_fact:
|
|
scm_version: "{{ svn_result['after'] }}"
|
|
when: "'after' in svn_result"
|
|
|
|
- name: parse subversion version string properly
|
|
set_fact:
|
|
scm_version: "{{scm_version|regex_replace('^.*Revision: ([0-9]+).*$', '\\1')}}"
|
|
when: scm_type == 'svn'
|
|
delegate_to: localhost
|
|
|
|
- block:
|
|
- name: Ensure the project directory is present
|
|
file:
|
|
dest: "{{project_path|quote}}"
|
|
state: directory
|
|
|
|
- name: Fetch Insights Playbook(s)
|
|
insights:
|
|
insights_url: "{{insights_url}}"
|
|
username: "{{scm_username}}"
|
|
password: "{{scm_password}}"
|
|
project_path: "{{project_path}}"
|
|
awx_license_type: "{{awx_license_type}}"
|
|
awx_version: "{{awx_version}}"
|
|
register: results
|
|
|
|
- name: Save Insights Version
|
|
set_fact:
|
|
scm_version: "{{results.version}}"
|
|
when: results is defined
|
|
when: scm_type == 'insights'
|
|
delegate_to: localhost
|
|
|
|
|
|
- name: Repository Version
|
|
debug: msg="Repository Version {{ scm_version }}"
|
|
when: scm_version is defined
|
|
|
|
- hosts: all
|
|
gather_facts: false
|
|
tasks:
|
|
|
|
- block:
|
|
- name: detect requirements.yml
|
|
stat: path={{project_path|quote}}/roles/requirements.yml
|
|
register: doesRequirementsExist
|
|
|
|
- name: fetch galaxy roles from requirements.yml
|
|
command: ansible-galaxy install -r requirements.yml -p {{roles_destination|quote}}
|
|
args:
|
|
chdir: "{{project_path|quote}}/roles"
|
|
register: galaxy_result
|
|
when: doesRequirementsExist.stat.exists
|
|
changed_when: "'was installed successfully' in galaxy_result.stdout"
|
|
|
|
when: roles_enabled|bool
|
|
delegate_to: localhost
|
|
|
|
- block:
|
|
- name: detect collections/requirements.yml
|
|
stat: path={{project_path|quote}}/collections/requirements.yml
|
|
register: doesCollectionRequirementsExist
|
|
|
|
- name: fetch galaxy collections from collections/requirements.yml
|
|
command: ansible-galaxy collection install -r requirements.yml -p {{collections_destination|quote}}
|
|
args:
|
|
chdir: "{{project_path|quote}}/collections"
|
|
register: galaxy_collection_result
|
|
when: doesCollectionRequirementsExist.stat.exists
|
|
changed_when: "'Installing ' in galaxy_collection_result.stdout"
|
|
|
|
when: collections_enabled|bool
|
|
delegate_to: localhost
|