Rehaul Gitea role for compose and PostgreSQL
This commit is contained in:
parent
dc520a09e9
commit
be6e1596c5
@ -17,7 +17,7 @@ proxy:
|
|||||||
- domain: "{{ bitwarden_domain }}"
|
- domain: "{{ bitwarden_domain }}"
|
||||||
proxy_pass: "http://127.0.0.1:8080"
|
proxy_pass: "http://127.0.0.1:8080"
|
||||||
- domain: "{{ gitea_domain }}"
|
- domain: "{{ gitea_domain }}"
|
||||||
proxy_pass: "http://127.0.0.1:3080"
|
proxy_pass: "http://127.0.0.1:3000"
|
||||||
|
|
||||||
# docker
|
# docker
|
||||||
docker_users:
|
docker_users:
|
||||||
@ -34,8 +34,4 @@ bitwarden_install_key: 1yB3Z2gRI0KnnH90C6p
|
|||||||
# gitea
|
# gitea
|
||||||
gitea_domain: "git.{{ base_domain }}"
|
gitea_domain: "git.{{ base_domain }}"
|
||||||
gitea_version: 1
|
gitea_version: 1
|
||||||
gitea_dbversion: latest
|
|
||||||
gitea_dbpass: password
|
gitea_dbpass: password
|
||||||
gitea_ports:
|
|
||||||
- "222:22"
|
|
||||||
- "3080:3000"
|
|
||||||
|
@ -1,11 +1,16 @@
|
|||||||
# container settings
|
# container settings
|
||||||
gitea_name: gitea
|
gitea_name: gitea
|
||||||
gitea_dbname: "{{ gitea_name }}-db"
|
gitea_sshport: "127.0.0.1:222"
|
||||||
gitea_ports: "222:22"
|
gitea_webport: "127.0.0.1:3000"
|
||||||
|
gitea_volume: "{{ gitea_name }}"
|
||||||
|
gitea_rooturl: "http://{{ gitea_domain }}"
|
||||||
|
gitea_signup: true
|
||||||
|
|
||||||
# database settings
|
# database settings
|
||||||
gitea_dbuser: "{{ gitea_dbname }}"
|
gitea_dbtype: postgres
|
||||||
|
gitea_dbhost: host.docker.internal
|
||||||
|
gitea_dbname: "{{ gitea_name }}"
|
||||||
|
gitea_dbuser: "{{ gitea_name }}"
|
||||||
|
|
||||||
# host
|
# host
|
||||||
gitea_root: "/opt/{{ gitea_name }}/data"
|
gitea_root: "{{ docker_root }}/{{ gitea_name }}"
|
||||||
gitea_dbroot: "/opt/{{ gitea_name }}/database"
|
|
||||||
|
@ -1,85 +1,34 @@
|
|||||||
- name: Create Gitea Network
|
- name: Create Gitea directory
|
||||||
docker_network:
|
file:
|
||||||
name: "{{ gitea_name }}"
|
path: "{{ gitea_root }}"
|
||||||
|
state: directory
|
||||||
|
|
||||||
- name: Start Gitea's database container
|
- name: Create Gitea database
|
||||||
docker_container:
|
postgresql_db:
|
||||||
name: "{{ gitea_dbname }}"
|
name: "{{ gitea_dbname }}"
|
||||||
image: mariadb:{{ gitea_dbversion }}
|
become: true
|
||||||
state: started
|
become_user: postgres
|
||||||
restart_policy: always
|
|
||||||
volumes: "{{ gitea_dbroot }}:/var/lib/mysql"
|
|
||||||
container_default_behavior: "no_defaults"
|
|
||||||
networks_cli_compatible: true
|
|
||||||
networks:
|
|
||||||
- name: "{{ gitea_name }}"
|
|
||||||
env:
|
|
||||||
MYSQL_RANDOM_ROOT_PASSWORD: "true"
|
|
||||||
MYSQL_DATABASE: "{{ gitea_dbname }}"
|
|
||||||
MYSQL_USER: "{{ gitea_dbuser }}"
|
|
||||||
MYSQL_PASSWORD: "{{ gitea_dbpass }}"
|
|
||||||
|
|
||||||
- name: Start Gitea container (traefik routing)
|
- name: Create Gitea database user
|
||||||
docker_container:
|
postgresql_user:
|
||||||
name: "{{ gitea_name }}"
|
db: "{{ gitea_dbname }}"
|
||||||
image: gitea/gitea:{{ gitea_version }}
|
name: "{{ gitea_dbuser }}"
|
||||||
state: started
|
password: "{{ gitea_dbpass }}"
|
||||||
restart_policy: always
|
become: true
|
||||||
container_default_behavior: "no_defaults"
|
become_user: postgres
|
||||||
networks_cli_compatible: true
|
|
||||||
ports: "{{ gitea_ports }}"
|
|
||||||
networks:
|
|
||||||
- name: "{{ gitea_name }}"
|
|
||||||
- name: traefik
|
|
||||||
volumes:
|
|
||||||
- "{{ gitea_root }}:/data"
|
|
||||||
- /etc/timezone:/etc/timezone:ro
|
|
||||||
- /etc/localtime:/etc/localtime:ro
|
|
||||||
env:
|
|
||||||
USER_UID: "1000"
|
|
||||||
USER_GID: "1000"
|
|
||||||
DB_TYPE: mysql
|
|
||||||
DB_HOST: "{{ gitea_dbname }}"
|
|
||||||
DB_NAME: "{{ gitea_dbname }}"
|
|
||||||
DB_USER: "{{ gitea_dbuser }}"
|
|
||||||
DB_PASSWD: "{{ gitea_dbpass }}"
|
|
||||||
ROOT_URL: "https://{{ gitea_domain }}/"
|
|
||||||
SSH_DOMAIN: "{{ gitea_domain }}"
|
|
||||||
DOMAIN: "{{ gitea_domain }}"
|
|
||||||
labels:
|
|
||||||
traefik.http.routers.gitea.rule: "Host(`{{ gitea_domain }}`)"
|
|
||||||
traefik.http.routers.gitea.entrypoints: websecure
|
|
||||||
traefik.http.routers.gitea.tls.certresolver: letsencrypt
|
|
||||||
traefik.http.routers.gitea.middlewares: "securehttps@file"
|
|
||||||
traefik.http.services.gitea.loadbalancer.server.port: "3000"
|
|
||||||
traefik.docker.network: traefik
|
|
||||||
traefik.enable: "true"
|
|
||||||
when: traefik_version is defined
|
|
||||||
|
|
||||||
- name: Start Gitea container
|
- name: Install Gitea's docker-compose file
|
||||||
docker_container:
|
template:
|
||||||
name: "{{ gitea_name }}"
|
src: docker-compose.yml.j2
|
||||||
image: gitea/gitea:{{ gitea_version }}
|
dest: "{{ gitea_root }}/docker-compose.yml"
|
||||||
|
|
||||||
|
- name: Install Gitea's docker-compose variables
|
||||||
|
template:
|
||||||
|
src: compose-env.j2
|
||||||
|
dest: "{{ gitea_root }}/.env"
|
||||||
|
|
||||||
|
- name: Start and enable Gitea service
|
||||||
|
service:
|
||||||
|
name: "{{ docker_compose_service }}@{{ gitea_name }}"
|
||||||
state: started
|
state: started
|
||||||
restart_policy: always
|
enabled: true
|
||||||
container_default_behavior: "no_defaults"
|
|
||||||
networks_cli_compatible: true
|
|
||||||
ports: "{{ gitea_ports }}"
|
|
||||||
networks:
|
|
||||||
- name: "{{ gitea_name }}"
|
|
||||||
volumes:
|
|
||||||
- "{{ gitea_root }}:/data"
|
|
||||||
- /etc/timezone:/etc/timezone:ro
|
|
||||||
- /etc/localtime:/etc/localtime:ro
|
|
||||||
env:
|
|
||||||
USER_UID: "1000"
|
|
||||||
USER_GID: "1000"
|
|
||||||
DB_TYPE: mysql
|
|
||||||
DB_HOST: "{{ gitea_dbname }}"
|
|
||||||
DB_NAME: "{{ gitea_dbname }}"
|
|
||||||
DB_USER: "{{ gitea_dbuser }}"
|
|
||||||
DB_PASSWD: "{{ gitea_dbpass }}"
|
|
||||||
ROOT_URL: "https://{{ gitea_domain }}/"
|
|
||||||
SSH_DOMAIN: "{{ gitea_domain }}"
|
|
||||||
DOMAIN: "{{ gitea_domain }}"
|
|
||||||
when: traefik_version is not defined
|
|
||||||
|
17
roles/gitea/templates/compose-env.j2
Normal file
17
roles/gitea/templates/compose-env.j2
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
# {{ ansible_managed }}
|
||||||
|
gitea_version={{ gitea_version }}
|
||||||
|
gitea_name={{ gitea_name }}
|
||||||
|
gitea_domain={{ gitea_domain }}
|
||||||
|
gitea_rooturl={{ gitea_rooturl }}
|
||||||
|
gitea_webport={{ gitea_webport }}
|
||||||
|
gitea_sshport={{ gitea_sshport }}
|
||||||
|
gitea_dbtype={{ gitea_dbtype }}
|
||||||
|
gitea_dbhost={{ gitea_dbhost }}
|
||||||
|
gitea_dbname={{ gitea_dbname }}
|
||||||
|
gitea_dbuser={{ gitea_dbuser }}
|
||||||
|
gitea_dbpass={{ gitea_dbpass }}
|
||||||
|
{% if not gitea_signup %}
|
||||||
|
gitea_disable_registration=true
|
||||||
|
{% else %}
|
||||||
|
gitea_disable_registration=false
|
||||||
|
{% endif %}
|
30
roles/gitea/templates/docker-compose.yml.j2
Normal file
30
roles/gitea/templates/docker-compose.yml.j2
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
version: '3.7'
|
||||||
|
|
||||||
|
services:
|
||||||
|
gitea:
|
||||||
|
image: "gitea/gitea:${gitea_version}"
|
||||||
|
container_name: "${gitea_name}"
|
||||||
|
ports:
|
||||||
|
- "${gitea_sshport}:22"
|
||||||
|
- "${gitea_webport}:3000"
|
||||||
|
extra_hosts:
|
||||||
|
- "host.docker.internal:host-gateway"
|
||||||
|
environment:
|
||||||
|
- USER_UID=1000
|
||||||
|
- USER_GID=1000
|
||||||
|
- GITEA__server__ROOT_URL=${gitea_rooturl}
|
||||||
|
- GITEA__server__DOMAIN=${gitea_domain}
|
||||||
|
- GITEA__server__SSH_DOMAIN=${gitea_domain}
|
||||||
|
- GITEA__database__DB_TYPE=${gitea_dbtype}
|
||||||
|
- GITEA__database__HOST=${gitea_dbhost}
|
||||||
|
- GITEA__database__NAME=${gitea_dbname}
|
||||||
|
- GITEA__database__USER=${gitea_dbuser}
|
||||||
|
- GITEA__database__PASSWD=${gitea_dbpass}
|
||||||
|
- GITEA__service__DISABLE_REGISTRATION=${gitea_disable_registration}
|
||||||
|
volumes:
|
||||||
|
- {{ gitea_volume }}:/data
|
||||||
|
- /etc/timezone:/etc/timezone:ro
|
||||||
|
- /etc/localtime:/etc/localtime:ro
|
||||||
|
|
||||||
|
volumes:
|
||||||
|
{{ gitea_volume }}:
|
Loading…
Reference in New Issue
Block a user