70 lines
1.8 KiB
YAML
Executable File
70 lines
1.8 KiB
YAML
Executable File
#################################################
|
|
# DO Community Playbooks: Docker
|
|
#################################################
|
|
---
|
|
- hosts: all
|
|
become: true
|
|
vars_files:
|
|
- vars/default.yml
|
|
|
|
tasks:
|
|
- name: Add the user 'git' with a specific uid and a primary group of 'admin'
|
|
user:
|
|
name: "{{ user }}"
|
|
comment: Git user
|
|
create_home: no
|
|
|
|
- name: Pull Gitea image
|
|
docker_image:
|
|
name: "{{ container_image }}"
|
|
source: pull
|
|
|
|
- getent:
|
|
database: passwd
|
|
key: "{{ user }}"
|
|
split: ":"
|
|
|
|
- name: Create gitea container
|
|
docker_container:
|
|
name: "{{ container_name }}"
|
|
image: "{{ container_image }}"
|
|
state: started
|
|
env:
|
|
USER_UID: "{{ getent_passwd[user][1] }}"
|
|
USER_GID: "{{ getent_passwd[user][2] }}"
|
|
published_ports:
|
|
- "3000:3000"
|
|
- "127.0.0.1:2222:22"
|
|
volumes:
|
|
- /var/lib/gitea:/data
|
|
- /etc/timezone:/etc/timezone:ro
|
|
- /etc/localtime:/etc/localtime:ro
|
|
|
|
- name: Check if Nginx conf file for gitea exists or not
|
|
stat: path="/etc/nginx/sites-available/{{ http_conf }}"
|
|
register: status
|
|
|
|
- name: No need to reload Nginx
|
|
debug: msg= {{ "No need to reload Nginx as sites-available entries have already been created" }}
|
|
|
|
- name: Sets Nginx conf file for gitea
|
|
when: status.stat.exists == false
|
|
template:
|
|
src: "files/nginx.conf.j2"
|
|
dest: "/etc/nginx/sites-available/{{ http_conf }}"
|
|
|
|
- name: Enables new site
|
|
when: status.stat.exists == false
|
|
file:
|
|
src: "/etc/nginx/sites-available/{{ http_conf }}"
|
|
dest: "/etc/nginx/sites-enabled/{{ http_conf }}"
|
|
state: link
|
|
notify: Reload Nginx
|
|
|
|
handlers:
|
|
- name: Reload Nginx
|
|
service:
|
|
name: nginx
|
|
state: reloaded
|
|
|