1
0

Refactor gitea app: deploy with ansible

This commit is contained in:
Anton Vakhrushev 2025-05-03 14:44:23 +03:00
parent f4b5fcb0f1
commit 9a3e646d8a
Signed by: av
GPG Key ID: F5BF52FC352E255A
7 changed files with 90 additions and 60 deletions

View File

@ -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}"

View File

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

View File

@ -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: {}

View File

@ -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