WIP: feat(jenkins): add role to deploy jenkins

This commit is contained in:
2025-02-04 17:27:12 +01:00
parent 4e31d575ab
commit 55f7ea3c40
11 changed files with 214 additions and 0 deletions

View File

@ -0,0 +1,21 @@
---
- name: Ensure 'jenkins_state' is valid
ansible.builtin.fail:
msg: >-2
Unsupported jenkins_state '{{ jenkins_state }}'.
Supported values are: {{ jenkins_states | join(', ') }}
when: jenkins_state not in jenkins_states
- name: Ensure 'jenkins_deployment_method' is valid
ansible.builtin.fail:
msg: >-2
Unsupported jenkins_deployment_method '{{ jenkins_deployment_method }}'.
Supported values are: {{ jenkins_deployment_methods | join(', ') }}
when: jenkins_deployment_method not in jenkins_deployment_methods
- name: Ensure 'jenkins_version_channel' is valid
ansible.builtin.fail:
msg: >-2
Unsupported jenkins_version_channel '{{ jenkins_version_channel }}'.
Supported values are: {{ jenkins_version_channels | join(', ') }}
when: jenkins_version_channel not in jenkins_version_channels

View File

@ -0,0 +1,40 @@
---
- name: Ensure jenkins container image '{{ jenkins_container_image }}' is {{ jenkins_state }}
community.docker.docker_image:
name: "{{ jenkins_container_image }}"
state: "{{ jenkins_state }}"
source: "{{ jenkins_container_image_source }}"
force_source: "{{ jenkins_container_image_force_source }}"
- name: Ensure jenkins configuration folder is created
ansible.builtin.file:
path: "{{ jenkins_etc_passwd_shim_path | dirname }}"
state: directory
mode: "0755"
owner: "root"
group: "root"
when: jenkins_state == 'present'
- name: Ensure jenkins fake '/etc/passwd' is created
ansible.builtin.template:
src: "docker-passwd.j2"
dest: "{{ jenkins_etc_passwd_shim_path }}"
mode: "0644"
owner: "root"
group: "root"
when: jenkins_state == 'present'
notify:
- jenkins_restart
- name: Ensure jenkins container '{{ jenkins_container_name }}' is {{ jenkins_container_state }}
community.docker.docker_container:
name: "{{ jenkins_container_name }}"
image: "{{ jenkins_container_image }}"
env: "{{ jenkins_container_env | default(omit, true) }}"
user: "{{ jenkins_container_user | default(omit, true) }}"
ports: "{{ jenkins_container_ports | default(omit, true) }}"
labels: "{{ jenkins_container_labels | default(omit, true) }}"
networks: "{{ jenkins_container_networks | default(omit, true) }}"
volumes: "{{ jenkins_container_all_volumes }}"
restart_policy: "{{ jenkins_container_restart_policy }}"
state: "{{ jenkins_container_state }}"

View File

@ -0,0 +1,26 @@
---
- name: Ensure role arguments are valid
ansible.builtin.include_tasks:
file: "check.yml"
- name: Ensure jenkins user '{{ jenkins_user }}' is {{ jenkins_state }}
ansible.builtin.user:
name: "{{ jenkins_user }}"
state: "{{ jenkins_state }}"
system: "{{ jenkins_user_is_system }}"
create_home: "{{ jenkins_user_create_home }}"
register: jenkins_user_info
- name: Ensure jenkins home '{{ jenkins_home_path }}' is {{ jenkins_state }}
ansible.builtin.file:
path: "{{ jenkins_home_path }}"
state: "{{ (jenkins_state == 'present') | ternary('directory', 'absent') }}"
mode: "{{ jenkins_home_path_mode | default('0750', true) }}"
owner: "{{ jenkins_user_uid | default(jenkins_user, true) }}"
group: "{{ jenkins_user_gid | default(jenkins_user, true) }}"
notify:
- jenkins_restart
- name: Ensure jenkins is deployed using {{ jenkins_deployment_method }}
ansible.builtin.include_tasks:
file: "deploy-{{ jenkins_deployment_method }}.yml"