main.yml 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. ---
  2. - name: Install podman
  3. ansible.builtin.package:
  4. name: podman
  5. state: present
  6. - name: Create container group
  7. ansible.builtin.group:
  8. name: "{{ container_group }}"
  9. gid: "{{ container_gid }}"
  10. - name: Create container user
  11. ansible.builtin.user:
  12. name: "{{ container_user }}"
  13. uid: "{{ container_uid }}"
  14. group: "{{ container_group }}"
  15. - name: Generate list of persistent container directories
  16. ansible.builtin.set_fact:
  17. persistent_container_dirs: "{{ containers | map(attribute='volumes') | flatten | map('regex_replace', ':.*' ) | list }}"
  18. - name: Create persistent container directories
  19. ansible.builtin.file:
  20. path: "{{ item }}"
  21. state: directory
  22. owner: "{{ container_user | default('root') }}"
  23. group: "{{ container_group | default('root') }}"
  24. mode: '0770'
  25. with_items:
  26. - "{{ persistent_container_dirs }}"
  27. loop_control:
  28. label: "{{ item }}"
  29. - name: Create quadlet .container files
  30. containers.podman.podman_container:
  31. name: "{{ item.name }}"
  32. state: quadlet
  33. image: "{{ item.image }}"
  34. generate_systemd:
  35. names: True
  36. after: "{{ item.after | default(omit) }}"
  37. restart_sec: "{{ item.restart_sec | default(omit) }}"
  38. requires: "{{ item.requires | default(omit) }}"
  39. restart_policy: "{{ item.restart_policy | default(omit) }}"
  40. privileged: "{{ item.privileged | default(omit) }}"
  41. network: "{{ item.networks | default(omit) }}"
  42. env: "{{ item.environment | default(omit) }}"
  43. cap_add: "{{ item.cap_add | default(omit) }}"
  44. volumes: "{{ item.volumes | default(omit) }}"
  45. device: "{{ item.devices | default(omit) }}"
  46. ports: "{{ item.ports | default(omit) }}"
  47. quadlet_options:
  48. - "AutoUpdate=registry"
  49. - "Pull=newer"
  50. - |
  51. [Install]
  52. WantedBy=default.target
  53. {{ item.quadlet_options | default('') }}
  54. with_items:
  55. - "{{ containers }}"
  56. when:
  57. - containers is defined
  58. loop_control:
  59. label: "{{ item.name }}"
  60. notify:
  61. - Daemon Reload
  62. - name: Flush handlers
  63. meta: flush_handlers