This repository has been archived by the owner on Dec 18, 2024. It is now read-only.
Use entries iterator that handles permissions correctly #471
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
# /******************************************************************************** | |
# * Copyright (c) 2022,2023 Contributors to the Eclipse Foundation | |
# * | |
# * See the NOTICE file(s) distributed with this work for additional | |
# * information regarding copyright ownership. | |
# * | |
# * This program and the accompanying materials are made available under the | |
# * terms of the Apache License 2.0 which is available at | |
# * http://www.apache.org/licenses/LICENSE-2.0 | |
# * | |
# * SPDX-License-Identifier: Apache-2.0 | |
# ********************************************************************************/ | |
name: kuksa_databroker-cli_build | |
on: | |
push: | |
branches: [ master ] | |
pull_request: | |
paths: | |
- ".github/workflows/kuksa_databroker-cli_build.yml" | |
- "kuksa_databroker/**" | |
- "proto/**" | |
- "Cargo.*" | |
- "Cross.toml" | |
workflow_call: | |
workflow_dispatch: | |
concurrency: | |
group: ${{ github.ref }}-${{ github.workflow }} | |
cancel-in-progress: true | |
jobs: | |
lint: | |
name: Lint | |
runs-on: ubuntu-latest | |
steps: | |
- name: Installing JVM | |
run: sudo apt update && sudo apt-get install -y default-jre | |
- uses: actions/checkout@v3 | |
- name: cargo fmt | |
working-directory: ${{github.workspace}} | |
run: cargo fmt -- --check | |
- name: cargo clippy | |
working-directory: ${{github.workspace}} | |
run: cargo clippy --all-targets -- -W warnings -D warnings | |
- name: "Createbom: License check and Dash output generation" | |
working-directory: ${{github.workspace}}/kuksa_databroker/createbom | |
run: | | |
cargo install cargo-license | |
python3 createbom.py --dash ${{github.workspace}}/dash-databroker-cli-deps ../databroker-cli | |
- name: Dash license check | |
uses: ./.github/actions/check-dash | |
with: | |
dashinput: ${{github.workspace}}/dash-databroker-cli-deps | |
checkrights: | |
uses: ./.github/workflows/check_push_rights.yml | |
secrets: inherit | |
# Run on selfhosted, because our runner has native ARM build in a remote | |
# builder (no need for qemu) | |
build-container: | |
runs-on: [ self-hosted ] | |
needs: checkrights | |
steps: | |
- uses: actions/checkout@v3 | |
with: | |
submodules: recursive | |
- name: Docker meta | |
id: meta | |
uses: docker/metadata-action@v4 | |
with: | |
# list of Docker images to use as base name for tags | |
images: | | |
ghcr.io/eclipse/kuksa.val/databroker-cli | |
# generate Docker tags based on the following events/attributes | |
tags: | | |
type=ref,event=branch | |
type=ref,event=pr | |
type=semver,pattern={{version}} | |
type=semver,pattern={{major}}.{{minor}} | |
type=semver,pattern={{major}} | |
# only needed for runners without buildx setup, will be slow | |
#- name: Set up QEMU | |
# uses: docker/setup-qemu-action@v2 | |
# - name: Set up Docker Buildx | |
# id: buildx | |
# uses: docker/setup-buildx-action@v2 | |
- name: Log in to the Container registry | |
if: needs.checkrights.outputs.have_secrets == 'true' | |
uses: docker/login-action@v2 | |
with: | |
registry: ghcr.io | |
username: ${{ github.repository_owner }} | |
password: ${{ secrets.GITHUB_TOKEN }} | |
- name: Build kuksa.val databroker CLI container and push to ghcr.io (and ttl.sh) | |
id: ghcr-build | |
if: ${{ needs.checkrights.outputs.have_secrets == 'true' && github.event_name != 'pull_request' }} | |
uses: docker/build-push-action@v4 | |
with: | |
platforms: | | |
linux/amd64 | |
linux/arm64 | |
file: ./kuksa_databroker/Dockerfile-cli | |
context: . | |
push: true | |
tags: | | |
${{ steps.meta.outputs.tags }} | |
ttl.sh/kuksa.val/kuksa-databroker-cli-${{github.sha}} | |
labels: ${{ steps.meta.outputs.labels }} | |
- name: Build ephemereal kuksa.val databroker container and push to ttl.sh | |
if: ${{ needs.checkrights.outputs.have_secrets == 'false' || github.event_name == 'pull_request' }} | |
id: tmp-build | |
uses: docker/build-push-action@v4 | |
with: | |
platforms: | | |
linux/amd64 | |
linux/arm64 | |
file: ./kuksa_databroker/Dockerfile-cli | |
context: . | |
push: true | |
tags: "ttl.sh/kuksa.val/kuksa-databroker-cli-${{github.sha}}" | |
labels: ${{ steps.meta.outputs.labels }} | |
- name: Posting message | |
uses: ./.github/actions/post-container-location | |
with: | |
image: ttl.sh/kuksa.val/kuksa-databroker-cli-${{github.sha}} | |
- name: Extracting ARM64 binaries | |
uses: ./.github/actions/copy-from-oci | |
with: | |
platform: linux/arm64 | |
id: databroker-cli-arm64 | |
image: ttl.sh/kuksa.val/kuksa-databroker-cli-${{github.sha}} | |
src: /app/ | |
export: true | |
transform: s/app/databroker-cli/ | |
- name: Extracting AMD64 binaries | |
uses: ./.github/actions/copy-from-oci | |
with: | |
platform: linux/amd64 | |
id: databroker-cli-amd64 | |
image: ttl.sh/kuksa.val/kuksa-databroker-cli-${{github.sha}} | |
src: /app/ | |
export: true | |
transform: s/app/databroker-cli/ |