feat(jenkins_inbound_agent): add ansible role for deployment with docker
This commit is contained in:
38
roles/jenkins_inbound_agent/tasks/check.yml
Normal file
38
roles/jenkins_inbound_agent/tasks/check.yml
Normal file
@ -0,0 +1,38 @@
|
||||
---
|
||||
- name: Ensure 'jenkins_agent_state' is valid
|
||||
ansible.builtin.fail:
|
||||
msg: >-2
|
||||
Unsupported jenkins_agent_state '{{ jenkins_agent_state }}'.
|
||||
Supported values are: {{ jenkins_agent_states | join(', ') }}
|
||||
when: jenkins_agent_state not in jenkins_agent_states
|
||||
|
||||
- name: Ensure 'jenkins_agent_deployment_method' is valid
|
||||
ansible.builtin.fail:
|
||||
msg: >-2
|
||||
Unsupported jenkins_agent_deployment_method '{{ jenkins_agent_deployment_method }}'.
|
||||
Supported values are: {{ jenkins_agent_deployment_methods | join(', ') }}
|
||||
when: jenkins_agent_deployment_method not in jenkins_agent_deployment_methods
|
||||
|
||||
- name: Ensure Jenkins agent JDK version is valid if specified
|
||||
ansible.builtin.fail:
|
||||
msg: >-2
|
||||
Unsupported jenkins_agent_container_image_jdk_version
|
||||
'{{ jenkins_agent_container_image_jdk_version }}' specified!
|
||||
Supported JDK versions are:
|
||||
{{ jenkins_agent_container_image_jdk_versions | join(', ') }}
|
||||
when:
|
||||
- jenkins_agent_container_image_jdk_version is string
|
||||
- jenkins_agent_container_image_jdk_version | length > 0
|
||||
- jenkins_agent_container_image_jdk_version not in jenkins_agent_container_image_jdk_versions
|
||||
|
||||
- name: Ensure Jenkins agent distribution is valid if specified
|
||||
ansible.builtin.fail:
|
||||
msg: >-2
|
||||
Unsupported jenkins_agent_container_image_distribution
|
||||
'{{ jenkins_agent_container_image_distribution }}' specified!
|
||||
Supported JDK versions are:
|
||||
{{ jenkins_agent_container_image_distibrutions | join(', ') }}
|
||||
when:
|
||||
- jenkins_agent_container_image_distribution is string
|
||||
- jenkins_agent_container_image_distribution | length > 0
|
||||
- jenkins_agent_container_image_distribution not in jenkins_agent_container_image_distributions
|
58
roles/jenkins_inbound_agent/tasks/deploy-docker.yml
Normal file
58
roles/jenkins_inbound_agent/tasks/deploy-docker.yml
Normal file
@ -0,0 +1,58 @@
|
||||
---
|
||||
- name: Ensure container image '{{ jenkins_agent_container_image }}' is {{ jenkins_agent_state }}
|
||||
community.docker.docker_image:
|
||||
name: "{{ jenkins_agent_container_image }}"
|
||||
state: "{{ jenkins_agent_state }}"
|
||||
source: "{{ jenkins_agent_container_image_source }}"
|
||||
force_source: "{{ jenkins_agent_container_image_force_source }}"
|
||||
|
||||
- name: Ensure jenkins configuration directory exists
|
||||
ansible.builtin.file:
|
||||
path: "{{ jenkins_agent_secret_file | dirname }}"
|
||||
state: directory
|
||||
mode: "0755"
|
||||
recurse: true
|
||||
when: jenkins_agent_state == 'present'
|
||||
|
||||
- name: Ensure jenkins agent secret is persisted
|
||||
ansible.builtin.copy:
|
||||
dest: "{{ jenkins_agent_secret_file }}"
|
||||
content: "{{ jenkins_agent_secret }}"
|
||||
mode: "0400"
|
||||
owner: "{{ jenkins_agent_user_uid | default(jenkins_agent_user) }}"
|
||||
group: "{{ jenkins_agent_user_gid | default(jenkins_agent_user) }}"
|
||||
when: jenkins_agent_state == 'present'
|
||||
notify:
|
||||
- jenkins_agent_restart
|
||||
|
||||
- name: Ensure jenkins agent fake '/etc/passwd' is templated
|
||||
ansible.builtin.template:
|
||||
src: "docker-passwd.j2"
|
||||
dest: "{{ jenkins_agent_passwd_shim_file }}"
|
||||
mode: "0644"
|
||||
owner: "root"
|
||||
group: "root"
|
||||
|
||||
- name: Ensure jenkins configuration is removed
|
||||
ansible.builtin.file:
|
||||
path: "{{ jenkins_agent_secret_file | dirname }}"
|
||||
state: absent
|
||||
recurse: true
|
||||
when: jenkins_agent_state == 'absent'
|
||||
|
||||
- name: Ensure jenkins-agent container '{{ jenkins_agent_container_name }}' is {{ jenkins_agent_container_state }}
|
||||
community.docker.docker_container:
|
||||
name: "{{ jenkins_agent_container_name }}"
|
||||
image: "{{ jenkins_agent_container_image }}"
|
||||
env: "{{ jenkins_agent_container_all_env | default(omit, true) }}"
|
||||
init: "{{ jenkins_agent_container_init | default(true, true) }}"
|
||||
user: "{{ jenkins_agent_container_user | default(omit, true) }}"
|
||||
ports: "{{ jenkins_agent_container_ports | default(omit, true) }}"
|
||||
labels: "{{ jenkins_agent_container_labels | default(omit, true) }}"
|
||||
volumes: "{{ jenkins_agent_container_all_volumes }}"
|
||||
networks: "{{ jenkins_agent_container_networks | default(omit, true) }}"
|
||||
etc_hosts: "{{ jenkins_agent_container_etc_hosts | default(omit, true) }}"
|
||||
restart_policy: "{{ jenkins_agent_container_restart_policy }}"
|
||||
state: "{{ jenkins_agent_container_state }}"
|
||||
comparisons:
|
||||
"env": "strict"
|
16
roles/jenkins_inbound_agent/tasks/main.yml
Normal file
16
roles/jenkins_inbound_agent/tasks/main.yml
Normal file
@ -0,0 +1,16 @@
|
||||
---
|
||||
- name: Ensure required variables are populated (correctly)
|
||||
ansible.builtin.include_tasks:
|
||||
file: "check.yml"
|
||||
|
||||
- name: Ensure jenkins-agent user '{{ jenkins_agent_user }}' is {{ jenkins_agent_state }}
|
||||
ansible.builtin.user:
|
||||
name: "{{ jenkins_agent_user }}"
|
||||
state: "{{ jenkins_agent_state }}"
|
||||
system: "{{ jenkins_agent_user_is_system }}"
|
||||
create_home: "{{ jenkins_agent_user_create_home }}"
|
||||
register: jenkins_agent_user_info
|
||||
|
||||
- name: Ensure jenkins-agent '{{ jenkins_agent_name }}' is deployed using {{ jenkins_agent_deployment_method }}
|
||||
ansible.builtin.include_tasks:
|
||||
file: "deploy-{{ jenkins_agent_deployment_method }}.yml"
|
Reference in New Issue
Block a user