summaryrefslogtreecommitdiff
path: root/roles/raspios/image/tasks/fetch.yml
diff options
context:
space:
mode:
authorChristian Pointner <equinox@spreadspace.org>2022-09-04 18:25:12 +0200
committerChristian Pointner <equinox@spreadspace.org>2022-09-04 18:25:20 +0200
commit822b5e0e2eff46fbd007024ad1323abe27c2ff70 (patch)
tree3dfb358e3bbfe59815c881989f3e06be20108a9a /roles/raspios/image/tasks/fetch.yml
parentubuntu/installer: improved handling of latest image (diff)
raspios: major refactoring for image fetching, TODO: customization
Diffstat (limited to 'roles/raspios/image/tasks/fetch.yml')
-rw-r--r--roles/raspios/image/tasks/fetch.yml38
1 files changed, 23 insertions, 15 deletions
diff --git a/roles/raspios/image/tasks/fetch.yml b/roles/raspios/image/tasks/fetch.yml
index c95f1dea..5060bdfe 100644
--- a/roles/raspios/image/tasks/fetch.yml
+++ b/roles/raspios/image/tasks/fetch.yml
@@ -4,33 +4,41 @@
dest: "{{ raspios_download_dir }}"
state: directory
+- name: fetch imageutility os list from download server
+ check_mode: no
+ uri:
+ url: "{{ raspios_download_url }}/os_list_imagingutility_v3.json"
+ body_format: json
+ register: raspios_os_list_imagingutility
+
+- set_fact:
+ raspios_download_url_image: "{{ raspios_os_list_imagingutility.json.os_list | raspios_extract_latest_image_download_url(raspios_download_base_url) }}"
+
- name: download the raspios image
block:
- - name: download sha256sum
- get_url:
- url: "{{ raspios_download_base_url }}/{{ raspios_download_image_base_name }}.zip.sha256"
- dest: "{{ raspios_download_dir }}/{{ raspios_download_image_base_name }}.zip.sha256"
-
- - name: download signature
+ - name: download sha256sum and signature
+ loop:
+ - sha256
+ - sig
get_url:
- url: "{{ raspios_download_base_url }}/{{ raspios_download_image_base_name }}.zip.sig"
- dest: "{{ raspios_download_dir }}/{{ raspios_download_image_base_name }}.zip.sig"
+ url: "{{ raspios_download_url_image }}.{{ item }}"
+ dest: "{{ raspios_download_dir }}/{{ raspios_download_image_base_name }}.{{ item }}"
- name: extract SHA256 hash of the image archive
- command: grep '{{ raspios_download_image_base_name }}.zip' "{{ raspios_download_dir }}/{{ raspios_download_image_base_name }}.zip.sha256"
+ command: grep '{{ raspios_download_image_base_name }}' "{{ raspios_download_dir }}/{{ raspios_download_image_base_name }}.sha256"
changed_when: False
register: sha256
- name: download image
get_url:
- url: "{{ raspios_download_base_url }}/{{ raspios_download_image_base_name }}.zip"
- dest: "{{ raspios_download_dir }}/{{ raspios_download_image_base_name }}.zip"
+ url: "{{ raspios_download_url_image }}"
+ dest: "{{ raspios_download_dir }}/{{ raspios_download_image_base_name }}"
checksum: sha256:{{ sha256.stdout.split(' ') | first }}
- name: check OpenPGP signature
command: >-
gpgv --keyring "{{ global_files_dir }}/common/keyrings/raspios.gpg"
- "{{ raspios_download_dir }}/{{ raspios_download_image_base_name }}.zip.sig" "{{ raspios_download_dir }}/{{ raspios_download_image_base_name }}.zip"
+ "{{ raspios_download_dir }}/{{ raspios_download_image_base_name }}.sig" "{{ raspios_download_dir }}/{{ raspios_download_image_base_name }}"
changed_when: False
register: raspios_image_gpg_result
@@ -40,9 +48,9 @@
rescue:
- name: delete downloaded artifacts
loop:
- - "{{ raspios_download_dir }}/{{ raspios_download_image_base_name }}.zip.sha256"
- - "{{ raspios_download_dir }}/{{ raspios_download_image_base_name }}.zip.sig"
- - "{{ raspios_download_dir }}/{{ raspios_download_image_base_name }}.zip"
+ - "{{ raspios_download_dir }}/{{ raspios_download_image_base_name }}-sha256"
+ - "{{ raspios_download_dir }}/{{ raspios_download_image_base_name }}.sig"
+ - "{{ raspios_download_dir }}/{{ raspios_download_image_base_name }}"
file:
path: "{{ item }}"
state: absent