Compare commits
4 Commits
transcaffe
...
877c5a137a
Author | SHA1 | Date | |
---|---|---|---|
877c5a137a
|
|||
11d4b397ef
|
|||
76e89db5c6
|
|||
4bddc95161
|
@ -3,8 +3,8 @@ set -euo pipefail
|
||||
|
||||
LEGO_BINARY=$(/usr/bin/env which lego)
|
||||
|
||||
if [[ -n "$LEGO_HTTP_FALLBACK_PORT" ]]; then
|
||||
if ! nc_binary="$(type -p \"nc\")" || [[ -z $nc_binary ]]; then
|
||||
if [[ -n "${LEGO_HTTP_FALLBACK_PORT:-}" ]]; then
|
||||
if ! nc_binary="$(type -p 'nc')" || [[ -z $nc_binary ]]; then
|
||||
echo "nc not found (in PATH), exiting"
|
||||
exit 1
|
||||
fi
|
||||
@ -14,7 +14,7 @@ if [[ -n "$LEGO_HTTP_FALLBACK_PORT" ]]; then
|
||||
fi
|
||||
fi
|
||||
|
||||
if [[ -n "$LEGO_PRE_RENEWAL_HOOK" ]]; then
|
||||
if [[ -n "${LEGO_PRE_RENEWAL_HOOK:-}" ]]; then
|
||||
$LEGO_PRE_RENEWAL_HOOK
|
||||
fi
|
||||
|
||||
@ -30,6 +30,6 @@ fi
|
||||
find "$LEGO_CERT_STORE_PATH/certificates" -type f | xargs -I{} -n 1 chmod "$LEGO_CERT_MODE" "{}"
|
||||
find "$LEGO_CERT_STORE_PATH/certificates" -type f | xargs -I{} -n 1 chown "${LEGO_CERT_USER}:${LEGO_CERT_GROUP}" "{}"
|
||||
|
||||
if [[ -n "$LEGO_POST_RENEWAL_HOOK" ]]; then
|
||||
if [[ -n "${LEGO_POST_RENEWAL_HOOK:-}" ]]; then
|
||||
$LEGO_POST_RENEWAL_HOOK
|
||||
fi
|
||||
|
@ -1,17 +1,7 @@
|
||||
---
|
||||
|
||||
minio_user: ~
|
||||
minio_data_path: /opt/minio
|
||||
|
||||
minio_create_user: false
|
||||
minio_manage_host_filesystem: false
|
||||
|
||||
minio_root_username: root
|
||||
minio_root_password: ~
|
||||
|
||||
minio_container_name: minio
|
||||
minio_container_image_name: docker.io/minio/minio
|
||||
minio_container_image_tag: latest
|
||||
minio_container_image_name: "docker.io/minio/minio"
|
||||
minio_container_image_tag: "RELEASE.2025-04-03T14-56-28Z"
|
||||
minio_container_image: "{{ minio_container_image_name }}:{{ minio_container_image_tag }}"
|
||||
minio_container_networks: []
|
||||
minio_container_ports: []
|
||||
@ -34,6 +24,8 @@ minio_container_command:
|
||||
- ":{{ minio_container_listen_port_console }}"
|
||||
minio_container_restart_policy: "unless-stopped"
|
||||
minio_container_image_force_source: "{{ (minio_container_image_tag == 'latest')|bool }}"
|
||||
minio_container_state: >-2
|
||||
{{ (minio_state == 'present') | ternary('started', 'absent') }}
|
||||
|
||||
minio_container_listen_port_api: 9000
|
||||
minio_container_listen_port_console: 8900
|
12
roles/minio/defaults/main/main.yml
Normal file
12
roles/minio/defaults/main/main.yml
Normal file
@ -0,0 +1,12 @@
|
||||
---
|
||||
minio_user: ~
|
||||
minio_data_path: /opt/minio
|
||||
|
||||
minio_create_user: false
|
||||
minio_manage_host_filesystem: false
|
||||
|
||||
minio_root_username: root
|
||||
minio_root_password: ~
|
||||
|
||||
minio_state: present
|
||||
minio_deployment_method: docker
|
29
roles/minio/tasks/deploy-docker.yml
Normal file
29
roles/minio/tasks/deploy-docker.yml
Normal file
@ -0,0 +1,29 @@
|
||||
---
|
||||
- name: Ensure filesystem mounts ({{ minio_data_path }}) for container volumes are present
|
||||
ansible.builtin.file:
|
||||
path: "{{ minio_data_path }}"
|
||||
state: directory
|
||||
user: "{{ minio_user|default(omit, True) }}"
|
||||
group: "{{ minio_user|default(omit, True) }}"
|
||||
when: minio_manage_host_filesystem
|
||||
|
||||
- name: Ensure container image '{{ minio_container_image }}' is {{ minio_state }}
|
||||
community.docker.docker_image:
|
||||
name: "{{ minio_container_image }}"
|
||||
state: "{{ minio_state }}"
|
||||
source: pull
|
||||
force_source: "{{ minio_container_image_force_source }}"
|
||||
|
||||
- name: Ensure container '{{ minio_container_name }}' is {{ minio_container_state }}
|
||||
community.docker.docker_container:
|
||||
name: "{{ minio_container_name }}"
|
||||
image: "{{ minio_container_image }}"
|
||||
volumes: "{{ minio_container_volumes }}"
|
||||
env: "{{ minio_container_env }}"
|
||||
labels: "{{ minio_container_labels }}"
|
||||
networks: "{{ minio_container_networks }}"
|
||||
ports: "{{ minio_container_ports }}"
|
||||
user: "{{ minio_user|default(omit, True) }}"
|
||||
command: "{{ minio_container_command }}"
|
||||
restart_policy: "{{ minio_container_restart_policy }}"
|
||||
state: "{{ minio_container_state }}"
|
@ -1,37 +1,25 @@
|
||||
---
|
||||
- name: Ensure 'minio_state' is valid
|
||||
ansible.builtin.fail:
|
||||
msg: >-
|
||||
Unsupported state '{{ minio_state }}'!
|
||||
Supported states are {{ minio_states | join(', ') }}.
|
||||
when: minio_state not in minio_states
|
||||
|
||||
- name: Ensure minio run user is present
|
||||
user:
|
||||
- name: Ensure 'minio_deployment_method' is valid
|
||||
ansible.builtin.fail:
|
||||
msg: >-
|
||||
Unsupported state '{{ minio_deployment_method }}'!
|
||||
Supported states are {{ minio_deployment_methods | join(', ') }}.
|
||||
when: minio_deployment_method not in minio_deployment_methods
|
||||
|
||||
- name: Ensure minio run user is {{ minio_state }}
|
||||
ansible.builtin.user:
|
||||
name: "{{ minio_user }}"
|
||||
state: present
|
||||
system: yes
|
||||
state: "{{ minio_state }}"
|
||||
system: true
|
||||
when: minio_create_user
|
||||
|
||||
- name: Ensure filesystem mounts ({{ minio_data_path }}) for container volumes are present
|
||||
file:
|
||||
path: "{{ minio_data_path }}"
|
||||
state: directory
|
||||
user: "{{ minio_user|default(omit, True) }}"
|
||||
group: "{{ minio_user|default(omit, True) }}"
|
||||
when: minio_manage_host_filesystem
|
||||
|
||||
- name: Ensure container image for minio is present
|
||||
community.docker.docker_image:
|
||||
name: "{{ minio_container_image }}"
|
||||
state: present
|
||||
source: pull
|
||||
force_source: "{{ minio_container_image_force_source }}"
|
||||
|
||||
- name: Ensure container {{ minio_container_name }} is running
|
||||
docker_container:
|
||||
name: "{{ minio_container_name }}"
|
||||
image: "{{ minio_container_image }}"
|
||||
volumes: "{{ minio_container_volumes }}"
|
||||
env: "{{ minio_container_env }}"
|
||||
labels: "{{ minio_container_labels }}"
|
||||
networks: "{{ minio_container_networks }}"
|
||||
ports: "{{ minio_container_ports }}"
|
||||
user: "{{ minio_user|default(omit, True) }}"
|
||||
command: "{{ minio_container_command }}"
|
||||
restart_policy: "{{ minio_container_restart_policy }}"
|
||||
state: started
|
||||
- name: Deploy minio using {{ minio_deployment_method }}
|
||||
ansible.builtin.include_tasks:
|
||||
file: "deploy-{{ minio_deployment_method }}.yml"
|
||||
|
@ -1,5 +1,9 @@
|
||||
---
|
||||
|
||||
minio_states:
|
||||
- present
|
||||
- absent
|
||||
minio_deployment_methods:
|
||||
- docker
|
||||
minio_container_volumes: "{{ minio_container_base_volumes + minio_container_extra_volumes }}"
|
||||
|
||||
minio_container_env: "{{ minio_container_base_env | combine(minio_container_extra_env) }}"
|
||||
|
@ -6,9 +6,9 @@ if [[ -n ${RESTIC_PRE_BACKUP_HOOK-} ]]; then
|
||||
/bin/bash -c "$RESTIC_PRE_BACKUP_HOOK"
|
||||
fi
|
||||
|
||||
echo "List existing snapshots or initialize repository"
|
||||
restic snapshots || restic init
|
||||
sleep 2;
|
||||
echo "List existing snapshots or attempt to initialize/unlock repository"
|
||||
restic snapshots || restic init || restic unlock
|
||||
sleep 1;
|
||||
|
||||
echo "Attempting to remove lock if present"
|
||||
restic unlock
|
||||
|
Reference in New Issue
Block a user