Add volume role and support setting volume owner

Add volume role
container: Use volume role, including support for user and group
This commit is contained in:
uumas
2024-11-19 19:50:43 +02:00
parent 61aa99bcd1
commit 61a8e67205
10 changed files with 93 additions and 1 deletions

View File

@@ -53,6 +53,16 @@ argument_specs:
type: bool
required: false
default: false
user:
description: Volume owner uid. Only applicable if mount type is volume.
type: str
required: false
default: ""
group:
description: Volume owner gid. Only applicable if mount type is volume.
type: str
required: false
default: ""
container_publish_ports:
description: "A list of published ports in docker format (<host listen address>:<host port>:<container port>)"

View File

@@ -11,6 +11,17 @@
loop_control:
loop_var: network
- name: Create volumes for container {{ container_name }}
ansible.builtin.include_role:
name: volume
vars:
volume_name: "{{ volume.source }}"
volume_uid: "{{ volume.user | default('') }}"
volume_gid: "{{ volume.group | default('') }}"
loop: "{{ _container_volumes }}"
loop_control:
loop_var: volume
- name: Create secrets for container {{ container_name }}
containers.podman.podman_secret:
name: "{{ item.name }}"
@@ -24,7 +35,7 @@
name: "{{ container_name }}"
command: "{{ container_command or omit }}"
user: "{{ container_user or omit }}"
mount: "{{ container_mounts | map('items') | map('map', 'join', '=') | map('join', ',') }}"
mount: "{{ _container_mounts | map('items') | map('map', 'join', '=') | map('join', ',') }}"
network: "{{ container_networks | map('regex_replace', '$', '.network') }}"
publish: "{{ container_publish_ports }}"
secrets: "{{ container_secrets | map(attribute='name') }}"

View File

@@ -1,4 +1,25 @@
---
_container_volumes: "{{ container_mounts | selectattr('type', '==', 'volume') }}"
_container_mount_sources: "{{ container_mounts | map(attribute='source') }}"
_container_mount_destinations: "{{ container_mounts | map(attribute='destination') }}"
_container_volume_mount_sources: >-
{{
_container_volumes
| map(attribute='source')
| map('regex_replace', '$', '.volume')
| map('community.general.dict_kv', 'source')
}}
_container_mounts: >-
{{
container_mounts | selectattr('type', '!=', 'volume') +
container_mounts | selectattr('type', '==', 'volume')
| community.general.remove_keys(['user', 'group'])
| zip(_container_volume_mount_sources) | map('combine')
}}
_container_quadlet_unit_options: |
[Unit]
Description=Container {{ container_name }}

1
roles/volume/README.md Normal file
View File

@@ -0,0 +1 @@
Sets up podman volume with systemd unit (quadlet)

View File

@@ -0,0 +1,3 @@
---
volume_uid: ""
volume_gid: ""

View File

@@ -0,0 +1,19 @@
---
argument_specs:
main:
description: Sets up podman volume with systemd unit (quadlet)
options:
volume_name:
description: Name of the volume. Must be unique within a host.
type: str
required: true
volume_uid:
description: Volume uid (the volume owner)
type: str
required: false
default: ""
volume_gid:
description: Volume gid (the volume owner)
type: str
required: false
default: ""

View File

@@ -0,0 +1,3 @@
---
dependencies:
- role: podman

View File

@@ -0,0 +1,11 @@
---
- name: Validate inputs
ansible.builtin.import_tasks: validation.yaml
- name: Create container volume service {{ volume_name }}
containers.podman.podman_volume:
name: "{{ volume_name }}"
options: "{{ volume_options }}"
state: quadlet
quadlet_file_mode: "0644"
notify: Reload systemd daemon

View File

@@ -0,0 +1,7 @@
---
- name: Assert volume_uid and volume_gid are strings
ansible.builtin.assert:
that:
- volume_uid is string
- volume_gid is string
fail_msg: "volume_uid and volume_gid must be strings, not int."

View File

@@ -0,0 +1,6 @@
---
volume_mount_options_incl_empty:
- "{{ 'uid=' ~ volume_uid if volume_uid | length > 0 else '' }}"
- "{{ 'gid=' ~ volume_gid if volume_gid | length > 0 else '' }}"
volume_mount_options: "{{ volume_mount_options_incl_empty | select('!=', '') | list }}"
volume_options: "{{ ['o=' ~ volume_mount_options | join(',')] if volume_mount_options | length > 0 else [] }}"