Refactor gitea app: deploy with ansible
This commit is contained in:
parent
f4b5fcb0f1
commit
9a3e646d8a
@ -1,8 +1,9 @@
|
|||||||
services:
|
services:
|
||||||
|
|
||||||
server:
|
server:
|
||||||
image: gitea/gitea:1.23.1
|
image: gitea/gitea:1.22.6
|
||||||
restart: unless-stopped
|
restart: unless-stopped
|
||||||
|
container_name: gitea_web_app
|
||||||
environment:
|
environment:
|
||||||
- "USER_UID=${USER_UID}"
|
- "USER_UID=${USER_UID}"
|
||||||
- "USER_GID=${USER_GID}"
|
- "USER_GID=${USER_GID}"
|
@ -8,25 +8,6 @@
|
|||||||
tasks:
|
tasks:
|
||||||
# Applications
|
# Applications
|
||||||
|
|
||||||
- ansible.builtin.import_role:
|
|
||||||
name: docker-app
|
|
||||||
vars:
|
|
||||||
username: gitea
|
|
||||||
extra_groups:
|
|
||||||
- docker
|
|
||||||
ssh_keys:
|
|
||||||
- '{{ lookup("file", "files/av_id_rsa.pub") }}'
|
|
||||||
env:
|
|
||||||
PROJECT_NAME: gitea
|
|
||||||
DOCKER_PREFIX: gitea
|
|
||||||
IMAGE_PREFIX: gitea
|
|
||||||
CONTAINER_PREFIX: gitea
|
|
||||||
WEB_SERVER_PORT: "127.0.0.1:{{ gitea_port }}"
|
|
||||||
USER_UID: "{{ uc_result.uid }}"
|
|
||||||
USER_GID: "{{ uc_result.group }}"
|
|
||||||
tags:
|
|
||||||
- apps
|
|
||||||
|
|
||||||
- ansible.builtin.import_role:
|
- ansible.builtin.import_role:
|
||||||
name: docker-app
|
name: docker-app
|
||||||
vars:
|
vars:
|
||||||
|
55
playbook-gitea.yml
Normal file
55
playbook-gitea.yml
Normal file
@ -0,0 +1,55 @@
|
|||||||
|
---
|
||||||
|
- name: "Configure gitea application"
|
||||||
|
hosts: all
|
||||||
|
|
||||||
|
vars_files:
|
||||||
|
- vars/ports.yml
|
||||||
|
- vars/vars.yml
|
||||||
|
|
||||||
|
vars:
|
||||||
|
app_name: "gitea"
|
||||||
|
app_user: "{{ app_name }}"
|
||||||
|
base_dir: "/home/{{ app_name }}"
|
||||||
|
|
||||||
|
tasks:
|
||||||
|
- name: "Create user and environment"
|
||||||
|
ansible.builtin.import_role:
|
||||||
|
name: owner
|
||||||
|
vars:
|
||||||
|
owner_name: "{{ app_user }}"
|
||||||
|
owner_extra_groups:
|
||||||
|
- "docker"
|
||||||
|
owner_ssh_keys:
|
||||||
|
- "{{ lookup('file', 'files/av_id_rsa.pub') }}"
|
||||||
|
owner_env:
|
||||||
|
PROJECT_NAME: "{{ app_name }}"
|
||||||
|
DOCKER_PREFIX: "{{ app_name }}"
|
||||||
|
IMAGE_PREFIX: "{{ app_name }}"
|
||||||
|
CONTAINER_PREFIX: "{{ app_name }}"
|
||||||
|
WEB_SERVER_PORT: "127.0.0.1:{{ gitea_port }}"
|
||||||
|
USER_UID: "{{ user_create_result.uid }}"
|
||||||
|
USER_GID: "{{ user_create_result.group }}"
|
||||||
|
|
||||||
|
- name: "Create internal application directories"
|
||||||
|
ansible.builtin.file:
|
||||||
|
path: "{{ item }}"
|
||||||
|
state: "directory"
|
||||||
|
owner: "{{ app_user }}"
|
||||||
|
group: "{{ app_user }}"
|
||||||
|
mode: "0775"
|
||||||
|
loop:
|
||||||
|
- "{{ (base_dir, 'data') | path_join }}"
|
||||||
|
|
||||||
|
- name: "Copy docker compose file"
|
||||||
|
ansible.builtin.template:
|
||||||
|
src: "./files/{{ app_name }}/docker-compose.yml.j2"
|
||||||
|
dest: "{{ base_dir }}/docker-compose.yml"
|
||||||
|
owner: "{{ app_user }}"
|
||||||
|
group: "{{ app_user }}"
|
||||||
|
mode: "0644"
|
||||||
|
|
||||||
|
- name: "Run application with docker compose"
|
||||||
|
community.docker.docker_compose_v2:
|
||||||
|
project_src: "{{ base_dir }}"
|
||||||
|
state: "present"
|
||||||
|
remove_orphans: true
|
@ -1,5 +1,6 @@
|
|||||||
---
|
---
|
||||||
owner_name: ''
|
owner_name: ""
|
||||||
owner_group: '{{ owner_name }}'
|
owner_group: "{{ owner_name }}"
|
||||||
|
owner_extra_groups: []
|
||||||
owner_ssh_keys: []
|
owner_ssh_keys: []
|
||||||
owner_env: {}
|
owner_env: {}
|
||||||
|
@ -1,60 +1,52 @@
|
|||||||
---
|
---
|
||||||
- name: 'Check app requirements for user "{{ owner_name }}".'
|
- name: 'Check app requirements for user "{{ owner_name }}".'
|
||||||
fail:
|
ansible.builtin.fail:
|
||||||
msg: You must set owner name.
|
msg: You must set owner name.
|
||||||
when: not owner_name
|
when: not owner_name
|
||||||
|
|
||||||
- name: 'Create group "{{ owner_group }}".'
|
- name: 'Create group "{{ owner_group }}".'
|
||||||
group:
|
ansible.builtin.group:
|
||||||
name: '{{ owner_group }}'
|
name: "{{ owner_group }}"
|
||||||
state: present
|
state: present
|
||||||
|
|
||||||
- name: 'Create user "{{ owner_name }}".'
|
- name: 'Create user "{{ owner_name }}".'
|
||||||
user:
|
ansible.builtin.user:
|
||||||
name: '{{ owner_name }}'
|
name: "{{ owner_name }}"
|
||||||
group: '{{ owner_group }}'
|
group: "{{ owner_group }}"
|
||||||
groups: '{{ owner_extra_groups }}'
|
groups: "{{ owner_extra_groups }}"
|
||||||
shell: /bin/bash
|
shell: /bin/bash
|
||||||
register: uc_result
|
register: user_create_result
|
||||||
|
|
||||||
- name: 'Set up user ssh keys for user "{{ owner_name }}".'
|
- name: 'Set up user ssh keys for user "{{ owner_name }}".'
|
||||||
authorized_key:
|
ansible.posix.authorized_key:
|
||||||
user: '{{ owner_name }}'
|
user: "{{ owner_name }}"
|
||||||
key: '{{ item }}'
|
key: "{{ item }}"
|
||||||
state: present
|
state: present
|
||||||
with_items: '{{ owner_ssh_keys }}'
|
with_items: "{{ owner_ssh_keys }}"
|
||||||
when: owner_ssh_keys | length > 0
|
when: owner_ssh_keys | length > 0
|
||||||
|
|
||||||
- name: 'Prepare env variables.'
|
- name: "Prepare env variables."
|
||||||
set_fact:
|
ansible.builtin.set_fact:
|
||||||
env_dict: '{{ owner_env | combine({
|
env_dict: '{{ owner_env | combine({ "CURRENT_UID": user_create_result.uid | default(owner_name), "CURRENT_GID": user_create_result.group | default(owner_group)
|
||||||
"CURRENT_UID": uc_result.uid | default(owner_name),
|
}) }}'
|
||||||
"CURRENT_GID": uc_result.group | default(owner_group) }) }}'
|
|
||||||
tags:
|
|
||||||
- env
|
|
||||||
|
|
||||||
- name: 'Set up environment variables for user "{{ owner_name }}".'
|
- name: 'Set up environment variables for user "{{ owner_name }}".'
|
||||||
template:
|
ansible.builtin.template:
|
||||||
src: env.j2
|
src: env.j2
|
||||||
dest: '/home/{{ owner_name }}/.env'
|
dest: "/home/{{ owner_name }}/.env"
|
||||||
owner: '{{ owner_name }}'
|
owner: "{{ owner_name }}"
|
||||||
group: '{{ owner_group }}'
|
group: "{{ owner_group }}"
|
||||||
tags:
|
mode: "0640"
|
||||||
- env
|
|
||||||
|
|
||||||
- name: 'Remove absent environment variables for user "{{ owner_name }}" from bashrc.'
|
- name: 'Remove from bashrc absent environment variables for user "{{ owner_name }}".'
|
||||||
lineinfile:
|
ansible.builtin.lineinfile:
|
||||||
path: '/home/{{ owner_name }}/.bashrc'
|
path: "/home/{{ owner_name }}/.bashrc"
|
||||||
regexp: '^export {{ item.key }}='
|
regexp: "^export {{ item.key }}="
|
||||||
state: absent
|
state: absent
|
||||||
with_dict: '{{ env_dict }}'
|
with_dict: "{{ env_dict }}"
|
||||||
tags:
|
|
||||||
- env
|
|
||||||
|
|
||||||
- name: 'Include environment variables for user "{{ owner_name }}" in bashrc.'
|
- name: 'Include in bashrc environment variables for user "{{ owner_name }}".'
|
||||||
lineinfile:
|
ansible.builtin.lineinfile:
|
||||||
path: '/home/{{ owner_name }}/.bashrc'
|
path: "/home/{{ owner_name }}/.bashrc"
|
||||||
regexp: '^export \$\(grep -v'
|
regexp: "^export \\$\\(grep -v"
|
||||||
line: 'export $(grep -v "^#" "$HOME"/.env | xargs)'
|
line: 'export $(grep -v "^#" "$HOME"/.env | xargs)'
|
||||||
tags:
|
|
||||||
- env
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user