self-hosting/roles/forgejo/tasks/binary.yml

49 lines
1.7 KiB
YAML

---
- name: Find latest available version
ansible.builtin.uri:
url: https://codeberg.org/forgejo/forgejo/releases/latest
register: latest_http_content
- name: Set latest available version
ansible.builtin.set_fact:
forgejo_latest_version: "{{ latest_http_content.url | split('/') | last | replace('v', '') }}"
- name: Define forgejo architecture
ansible.builtin.set_fact:
forgejo_architecture: "{{ (ansible_architecture == 'x86_64') | ternary('amd64', 'arm-6') }}"
- name: Find currently installed version
ansible.builtin.shell:
cmd: "(forgejo --version 2>/dev/null || echo 'forgejo version 0.0.0') | awk '{print $3}'"
register: forgejo_installed_version
changed_when: false
- name: Get latest forgejo binary
become: true
ansible.builtin.get_url:
url: "https://codeberg.org/forgejo/forgejo/releases/download/v{{ forgejo_latest_version }}/forgejo-{{ forgejo_latest_version }}-linux-{{ forgejo_architecture }}"
dest: "{{ forgejo_run_dir }}/forgejo-{{ forgejo_latest_version }}-linux-{{ forgejo_architecture }}"
owner: git
group: git
mode: 0644
when: forgejo_installed_version.stdout is version(forgejo_latest_version, '<')
notify:
- Receive forgejo pgp key
- Download forgejo asc file
- Verify forgejo binary with gpg
- name: Make sure downloaded binary has been verified
ansible.builtin.meta: flush_handlers
- name: Copy binary to global location
become: true
ansible.builtin.copy:
src: "{{ forgejo_run_dir }}/forgejo-{{ forgejo_latest_version }}-linux-{{ forgejo_architecture }}"
dest: /usr/local/bin/forgejo
remote_src: true
owner: root
group: root
mode: 0755
when: forgejo_installed_version.stdout is version(forgejo_latest_version, '<')
notify: Restart forgejo service