From 1bdadee9e8d56e3c37102d96cf585ca8958a454e Mon Sep 17 00:00:00 2001 From: Christian Pointner Date: Sun, 26 May 2024 21:44:21 +0200 Subject: apt-cacher-ng: initial working role --- roles/apt-cacher-ng/defaults/main.yml | 18 +++++++++++ roles/apt-cacher-ng/handlers/main.yml | 5 +++ roles/apt-cacher-ng/tasks/main.yml | 58 +++++++++++++++++++++++++++++++++++ 3 files changed, 81 insertions(+) create mode 100644 roles/apt-cacher-ng/handlers/main.yml (limited to 'roles') diff --git a/roles/apt-cacher-ng/defaults/main.yml b/roles/apt-cacher-ng/defaults/main.yml index abdf06ee..eb50d456 100644 --- a/roles/apt-cacher-ng/defaults/main.yml +++ b/roles/apt-cacher-ng/defaults/main.yml @@ -1,3 +1,21 @@ --- # apt_cacher_ng_storage: # type: ... + +# apt_cacher_ng_remaps: +# debrep: +# path: /debian +# backends: +# - http://deb.debian.org/debian +# debsec: +# path: /debian-security +# backends: +# - http://security.debian.org +# uburep: +# path: /ubuntu +# backends: +# - http://archive.ubuntu.com/ubuntu + +# apt_cacher_ng_admin_auth: +# username: admin +# password: secret diff --git a/roles/apt-cacher-ng/handlers/main.yml b/roles/apt-cacher-ng/handlers/main.yml new file mode 100644 index 00000000..80718ec2 --- /dev/null +++ b/roles/apt-cacher-ng/handlers/main.yml @@ -0,0 +1,5 @@ +--- +- name: restart apt-cacher-ng + service: + name: apt-cacher-ng + state: restarted diff --git a/roles/apt-cacher-ng/tasks/main.yml b/roles/apt-cacher-ng/tasks/main.yml index bfe05383..eb1620cc 100644 --- a/roles/apt-cacher-ng/tasks/main.yml +++ b/roles/apt-cacher-ng/tasks/main.yml @@ -24,3 +24,61 @@ apt: name: apt-cacher-ng state: present + +- name: fetch current remaps + slurp: + src: /etc/apt-cacher-ng/acng.conf + register: apt_cacher_ng_config_data + +- name: fetch current backend files + find: + paths: /etc/apt-cacher-ng + patterns: 'backends_*' + recurse: no + file_type: any + register: apt_cacher_ng_backends_files + +- name: remove superflous remaps + loop: "{{ (apt_cacher_ng_config_data.content | b64decode).splitlines() | select('match', '^Remap-') | map('regex_replace', '^Remap-([^:]*):.*$', '\\1') }}" + lineinfile: + path: /etc/apt-cacher-ng/acng.conf + regexp: '^Remap-{{ item }}:.*' + state: absent + notify: restart apt-cacher-ng + +- name: remove superflous backend files + loop: "{{ apt_cacher_ng_backends_files.files | map(attribute='path') | map('basename') | map('regex_replace', '^backends_(.*)$', '\\1') | difference(apt_cacher_ng_remaps | list) }}" + file: + path: "/etc/apt-cacher-ng/backends_{{ item }}" + state: absent + +- name: add ansible config + copy: + content: | + # ansible managed + ForceManaged: 1 + + {% for name, config in apt_cacher_ng_remaps.items() %} + Remap-{{ name }}: {{ config.path }} ; file:backends_{{ name }} + {% endfor %} + dest: /etc/apt-cacher-ng/zzz_ansible.conf + notify: restart apt-cacher-ng + +- name: create backend files + loop: "{{ apt_cacher_ng_remaps | dict2items }}" + loop_control: + label: "{{ item.key }}" + copy: + content: | + {% for backend in item.value.backends %} + {{ backend }} + {% endfor %} + dest: "/etc/apt-cacher-ng/backends_{{ item.key }}" + notify: restart apt-cacher-ng + +- name: configure admin auth + lineinfile: + path: /etc/apt-cacher-ng/security.conf + regexp: '#\s*AdminAuth:' + line: "AdminAuth: {{ apt_cacher_ng_admin_auth.username }}:{{ apt_cacher_ng_admin_auth.password }}" + notify: restart apt-cacher-ng -- cgit v1.2.3