feat(jenkins_inbound_agent): add ansible role for deployment with docker

This commit is contained in:
2025-02-05 13:48:09 +01:00
parent 94f15cc402
commit 98b0567c51
10 changed files with 265 additions and 0 deletions

View 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

View 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"

View 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"