blob: 851154b76abacae1c14a33ae7d84315035dbb6f2 [file] [log] [blame]
# Copyright (c) 2024 VEXXHOST, Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
- name: Build images
hosts: all
tasks:
- name: Create builder
ansible.builtin.shell: docker buildx create --name=atmosphere --driver=docker-container
- name: Log into registry
when: zuul.pipeline == 'post'
docker_login:
registry: registry.atmosphere.dev
username: "{{ registry_credentials.username }}"
password: "{{ registry_credentials.password }}"
- name: Build images
ansible.builtin.shell: |
docker buildx bake --builder=atmosphere --provenance --sbom=true {% if zuul.pipeline == 'post' %}--push{% endif %}
args:
chdir: "{{ zuul.project.src_dir }}"
environment:
PUSH_TO_CACHE: "{{ zuul.pipeline == 'post' }}"
- name: Get list of images built
ansible.builtin.shell: docker buildx bake --print
args:
chdir: "{{ zuul.project.src_dir }}"
register: images_built_json
- name: Set fact with list of images
set_fact:
images_built: "{{ images_built_json.stdout | from_json | json_query('target.*.tags[?@] | []') }}"
- name: Sign images
when: zuul.pipeline == 'post'
block:
- name: Download cosign binary
become: true
ansible.builtin.get_url:
url: https://github.com/sigstore/cosign/releases/latest/download/cosign-linux-amd64
dest: /usr/local/bin/cosign
mode: 0755
- name: Copy the cosign private key
copy:
content: "{{ cosign_key.private }}"
dest: cosign.key
- name: Sign images
ansible.builtin.shell: |
cosign sign -y --recursive --key cosign.key {{ item }}
loop: "{{ images_built }}"
- name: Delete the cosign private key
file:
path: cosign.key
state: absent
- name: Return Zuul artifacts for images
zuul_return:
data:
zuul:
artifacts:
- name: "{{ item }}"
url: "docker://{{ item }}"
metadata:
type: container_image
repository: "{{ item.split(':')[0] }}"
tag: "{{ item.split(':')[1] }}"
loop: "{{ images_built }}"