Compare commits
7 Commits
20fb6572bc
...
main
| Author | SHA1 | Date | |
|---|---|---|---|
| 45d0ffe3bb | |||
| 6efe762f49 | |||
| fb54e86d3d | |||
| 269094be05 | |||
| 10b20bc6e7 | |||
| 143110847e | |||
| 531c82f4c1 |
@@ -1,85 +0,0 @@
|
||||
name: Docker Build & Push to GitHub Container Registry (Use git tags with format vX.Y.Z as release version)
|
||||
|
||||
on:
|
||||
workflow_call:
|
||||
inputs:
|
||||
image_name:
|
||||
type: string
|
||||
required: true
|
||||
description: >
|
||||
Docker image name without registry and owner.
|
||||
Example: observability/alloy
|
||||
|
||||
build_context:
|
||||
type: string
|
||||
required: false
|
||||
default: .
|
||||
description: >
|
||||
Path to the Docker build context.
|
||||
Example: . or ./services/api
|
||||
|
||||
file_path:
|
||||
type: string
|
||||
required: false
|
||||
default: ./Dockerfile
|
||||
description: >
|
||||
Path to the Dockerfile relative to the repository root.
|
||||
Example: ./Dockerfile or ./services/api/Dockerfile
|
||||
|
||||
platforms:
|
||||
type: string
|
||||
required: false
|
||||
default: linux/amd64,linux/arm64
|
||||
description: >
|
||||
Comma-separated list of target platforms to build.
|
||||
Example: linux/amd64,linux/arm64
|
||||
|
||||
jobs:
|
||||
build-and-push:
|
||||
runs-on: ubuntu-latest
|
||||
permissions:
|
||||
contents: read
|
||||
packages: write
|
||||
|
||||
steps:
|
||||
- name: Checkout
|
||||
uses: actions/checkout@v4
|
||||
|
||||
# - name: Set up QEMU (for cross-arch builds)
|
||||
# uses: docker/setup-qemu-action@v3
|
||||
# with:
|
||||
# platforms: arm64
|
||||
|
||||
- name: Set up Docker Buildx
|
||||
uses: docker/setup-buildx-action@v3
|
||||
|
||||
- name: Ensure lowercase username because some registries do not allow uppercase letters
|
||||
id: lowercase
|
||||
run: echo "username=$(echo ${{ github.repository_owner }} | tr '[:upper:]' '[:lower:]')" >> $GITHUB_OUTPUT
|
||||
|
||||
- name: Docker meta
|
||||
id: meta
|
||||
uses: docker/metadata-action@v5
|
||||
with:
|
||||
images: ghcr.io/${{ steps.lowercase.outputs.username }}/${{ inputs.image_name }}
|
||||
tags: |
|
||||
type=match,pattern=.*(v\d+\.\d+\.\d+),group=1
|
||||
type=match,pattern=.*(v\d+\.\d+)\.\d+,group=1
|
||||
type=match,pattern=.*(v\d+)\.\d+\.\d+,group=1
|
||||
|
||||
# - name: Login to GitHub Container Registry
|
||||
# uses: docker/login-action@v3
|
||||
# with:
|
||||
# registry: ghcr.io
|
||||
# username: ${{ github.repository_owner }}
|
||||
# password: ${{ secrets.GITHUB_TOKEN }}
|
||||
|
||||
# - name: Build and push
|
||||
# uses: docker/build-push-action@v6
|
||||
# with:
|
||||
# context: ${{ inputs.build_context }}
|
||||
# file: ${{ inputs.file_path }}
|
||||
# platforms: ${{ inputs.platforms }}
|
||||
# push: true
|
||||
# tags: ${{ steps.meta.outputs.tags }}
|
||||
# labels: ${{ steps.meta.outputs.labels }}
|
||||
@@ -1,17 +0,0 @@
|
||||
name: Build and Push Alloy
|
||||
|
||||
on:
|
||||
push:
|
||||
tags:
|
||||
- "alloy-v*.*.*"
|
||||
|
||||
jobs:
|
||||
build-and-push:
|
||||
uses: ./.github/workflows/action-build-and-push.yaml
|
||||
permissions:
|
||||
contents: read
|
||||
packages: write
|
||||
with:
|
||||
image_name: observability/alloy
|
||||
build_context: ./observability/alloy
|
||||
file_path: ./observability/alloy/Dockerfile
|
||||
@@ -1,17 +0,0 @@
|
||||
name: Build and Push Grafana Observability
|
||||
|
||||
on:
|
||||
push:
|
||||
tags:
|
||||
- "grafana-v*.*.*"
|
||||
|
||||
jobs:
|
||||
build-and-push:
|
||||
uses: ./.github/workflows/action-build-and-push.yaml
|
||||
permissions:
|
||||
contents: read
|
||||
packages: write
|
||||
with:
|
||||
image_name: observability/grafana
|
||||
build_context: ./observability/grafana
|
||||
file_path: ./observability/grafana/Dockerfile
|
||||
@@ -1,17 +0,0 @@
|
||||
name: Build and Push Loki Database
|
||||
|
||||
on:
|
||||
push:
|
||||
tags:
|
||||
- "loki-v*.*.*"
|
||||
|
||||
jobs:
|
||||
build-and-push:
|
||||
uses: ./.github/workflows/action-build-and-push.yaml
|
||||
permissions:
|
||||
contents: read
|
||||
packages: write
|
||||
with:
|
||||
image_name: observability/loki
|
||||
build_context: ./observability/loki
|
||||
file_path: ./observability/loki/Dockerfile
|
||||
@@ -1,17 +0,0 @@
|
||||
name: Build and Push Prometheus Observability
|
||||
|
||||
on:
|
||||
push:
|
||||
tags:
|
||||
- "prometheus-v*.*.*"
|
||||
|
||||
jobs:
|
||||
build-and-push:
|
||||
uses: ./.github/workflows/action-build-and-push.yaml
|
||||
permissions:
|
||||
contents: read
|
||||
packages: write
|
||||
with:
|
||||
image_name: observability/prometheus
|
||||
build_context: ./observability/prometheus
|
||||
file_path: ./observability/prometheus/Dockerfile
|
||||
@@ -1,20 +0,0 @@
|
||||
name: Gitea Actions Demo
|
||||
run-name: ${{ gitea.actor }} is testing out Gitea Actions 🚀
|
||||
on: [push]
|
||||
|
||||
jobs:
|
||||
Explore-Gitea-Actions:
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- run: echo "🎉 The job was automatically triggered by a ${{ gitea.event_name }} event."
|
||||
- run: echo "🐧 This job is now running on a ${{ runner.os }} server hosted by Gitea!"
|
||||
- run: echo "🔎 The name of your branch is ${{ gitea.ref }} and your repository is ${{ gitea.repository }}."
|
||||
- name: Check out repository code
|
||||
uses: actions/checkout@v4
|
||||
- run: echo "💡 The ${{ gitea.repository }} repository has been cloned to the runner."
|
||||
- run: echo "🖥️ The workflow is now ready to test your code on the runner."
|
||||
- name: List files in the repository
|
||||
run: |
|
||||
ls ${{ gitea.workspace }}
|
||||
- run: echo "🍏 This job's status is ${{ job.status }}."
|
||||
- run: echo "✅ The workflow has completed successfully!"
|
||||
40
.github/workflows/action-build-and-push.yaml
vendored
40
.github/workflows/action-build-and-push.yaml
vendored
@@ -34,6 +34,30 @@ on:
|
||||
Comma-separated list of target platforms to build.
|
||||
Example: linux/amd64,linux/arm64
|
||||
|
||||
registry:
|
||||
type: string
|
||||
required: false
|
||||
default: ghcr.io
|
||||
description: >
|
||||
Container registry to push the image to.
|
||||
Example: ghcr.io or docker.io
|
||||
|
||||
registry_username:
|
||||
type: string
|
||||
required: false
|
||||
default: ${{ github.repository_owner }}
|
||||
description: >
|
||||
Username for the container registry.
|
||||
Example: myusername
|
||||
|
||||
registry_password:
|
||||
type: string
|
||||
required: false
|
||||
default: ${{ secrets.GITHUB_TOKEN }}
|
||||
description: >
|
||||
Password or token for the container registry.
|
||||
Example: secrets.GITHUB_TOKEN
|
||||
|
||||
jobs:
|
||||
build-and-push:
|
||||
runs-on: ubuntu-latest
|
||||
@@ -61,18 +85,18 @@ jobs:
|
||||
id: meta
|
||||
uses: docker/metadata-action@v5
|
||||
with:
|
||||
images: ghcr.io/${{ steps.lowercase.outputs.username }}/${{ inputs.image_name }}
|
||||
images: ${{ inputs.registry }}/${{ steps.lowercase.outputs.username }}/${{ inputs.image_name }}
|
||||
tags: |
|
||||
type=match,pattern=.*(v\d+\.\d+\.\d+),group=1
|
||||
type=match,pattern=.*(v\d+\.\d+)\.\d+,group=1
|
||||
type=match,pattern=.*(v\d+)\.\d+\.\d+,group=1
|
||||
|
||||
- name: Login to GitHub Container Registry
|
||||
uses: docker/login-action@v3
|
||||
with:
|
||||
registry: ghcr.io
|
||||
username: ${{ github.repository_owner }}
|
||||
password: ${{ secrets.GITHUB_TOKEN }}
|
||||
# - name: Login to GitHub Container Registry
|
||||
# uses: docker/login-action@v3
|
||||
# with:
|
||||
# registry: ${{ inputs.registry }}
|
||||
# username: ${{ inputs.registry_username }}
|
||||
# password: ${{ inputs.registry_password }}
|
||||
|
||||
- name: Build and push
|
||||
uses: docker/build-push-action@v6
|
||||
@@ -80,6 +104,6 @@ jobs:
|
||||
context: ${{ inputs.build_context }}
|
||||
file: ${{ inputs.file_path }}
|
||||
platforms: ${{ inputs.platforms }}
|
||||
push: true
|
||||
push: false
|
||||
tags: ${{ steps.meta.outputs.tags }}
|
||||
labels: ${{ steps.meta.outputs.labels }}
|
||||
|
||||
@@ -15,3 +15,7 @@ jobs:
|
||||
image_name: observability/loki
|
||||
build_context: ./observability/loki
|
||||
file_path: ./observability/loki/Dockerfile
|
||||
|
||||
registry: gitea.obnitram.cloud
|
||||
registry_username: ${{ github.repository_owner }}
|
||||
registry_password: ${{ secrets.GITEA_TOKEN }}
|
||||
Reference in New Issue
Block a user