Compare commits

...

7 Commits

Author SHA1 Message Date
t.behrendt 0199d06001 ci: fix deploy workflows (#51)
Reviewed-on: #51
Co-authored-by: Timo Behrendt <t.behrendt@t00n.de>
Co-committed-by: Timo Behrendt <t.behrendt@t00n.de>
2026-04-29 20:02:52 +02:00
t.behrendt 2866c3983b fix: deploy secret workflow step (#50)
Reviewed-on: #50
Co-authored-by: Timo Behrendt <t.behrendt@t00n.de>
Co-committed-by: Timo Behrendt <t.behrendt@t00n.de>
2026-04-29 20:01:28 +02:00
t.behrendt bb6706d1a0 refactor!: modernize shared cicd deploy and validate workflows (#49)
Release / Release (push) Successful in 11s
Reviewed-on: #49
Co-authored-by: Timo Behrendt <t.behrendt@t00n.de>
Co-committed-by: Timo Behrendt <t.behrendt@t00n.de>
2026-04-29 19:49:08 +02:00
renovate-bot dc62bc4e6a chore(deps): update azure/k8s-deploy action to v6 (#45)
Release / Release (push) Successful in 10s
This PR contains the following updates:

| Package | Type | Update | Change |
|---|---|---|---|
| [azure/k8s-deploy](https://github.com/azure/k8s-deploy) | action | major | `v5.1.0` → `v6.0.0` |

---

### Release Notes

<details>
<summary>azure/k8s-deploy (azure/k8s-deploy)</summary>

### [`v6.0.0`](https://github.com/Azure/k8s-deploy/releases/tag/v6.0.0)

[Compare Source](https://github.com/azure/k8s-deploy/compare/v5.1.0...v6.0.0)

##### Changed

- [#&#8203;504](https://github.com/azure/k8s-deploy/issues/504) [Update Node.js runtime from node20 to node24](https://github.com/Azure/k8s-deploy/pull/504)
- [#&#8203;500](https://github.com/azure/k8s-deploy/issues/500) [Update action version references in README to latest majors](https://github.com/Azure/k8s-deploy/pull/500)

##### Security

- [#&#8203;506](https://github.com/azure/k8s-deploy/issues/506) [Bump undici from 6.23.0 to 6.24.1](https://github.com/Azure/k8s-deploy/pull/506)
- [#&#8203;513](https://github.com/azure/k8s-deploy/issues/513) [Bump vite from 8.0.3 to 8.0.5](https://github.com/Azure/k8s-deploy/pull/513)
- [#&#8203;509](https://github.com/azure/k8s-deploy/issues/509) [Bump the actions group across 1 directory with 4 updates](https://github.com/Azure/k8s-deploy/pull/509)
- [#&#8203;510](https://github.com/azure/k8s-deploy/issues/510) [Bump the actions group across 1 directory with 2 updates](https://github.com/Azure/k8s-deploy/pull/510)
- [#&#8203;511](https://github.com/azure/k8s-deploy/issues/511) [Bump vitest from 4.1.1 to 4.1.2](https://github.com/Azure/k8s-deploy/pull/511)
- [#&#8203;514](https://github.com/azure/k8s-deploy/issues/514) [Bump the actions group with 2 updates](https://github.com/Azure/k8s-deploy/pull/514)
- [#&#8203;501](https://github.com/azure/k8s-deploy/issues/501) [Bump @&#8203;types/node from 25.3.3 to 25.4.0](https://github.com/Azure/k8s-deploy/pull/501)

</details>

---

### Configuration

📅 **Schedule**: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined).

🚦 **Automerge**: Disabled by config. Please merge this manually once you are satisfied.

♻ **Rebasing**: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.

🔕 **Ignore**: Close this PR and you won't be reminded about this update again.

---

 - [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check this box

---

This PR has been generated by [Renovate Bot](https://github.com/renovatebot/renovate).
<!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiI0My41LjQiLCJ1cGRhdGVkSW5WZXIiOiI0My41LjQiLCJ0YXJnZXRCcmFuY2giOiJtYWluIiwibGFiZWxzIjpbImFjdGlvbiIsImRlcHMiXX0=-->

Reviewed-on: https://gitea.t000-n.de/t.behrendt/k_deploy_workflows/pulls/45
Reviewed-by: t.behrendt <t.behrendt@noreply.localhost>
Co-authored-by: Renovate Bot <renovate@t00n.de>
Co-committed-by: Renovate Bot <renovate@t00n.de>
2026-04-28 17:11:14 +02:00
renovate-bot d7d914ca4a chore(deps): update https://gitea.t000-n.de/t.behrendt/actions action to v0.2.3 (#46)
This PR contains the following updates:

| Package | Type | Update | Change |
|---|---|---|---|
| [https://gitea.t000-n.de/t.behrendt/actions](https://gitea.t000-n.de/t.behrendt/actions) | action | patch | `0.2.2` → `0.2.3` |

---

### Release Notes

<details>
<summary>t.behrendt/actions (https://gitea.t000-n.de/t.behrendt/actions)</summary>

### [`v0.2.3`](https://gitea.t000-n.de/t.behrendt/actions/compare/0.2.2...0.2.3)

[Compare Source](https://gitea.t000-n.de/t.behrendt/actions/compare/0.2.2...0.2.3)

</details>

---

### Configuration

📅 **Schedule**: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined).

🚦 **Automerge**: Disabled by config. Please merge this manually once you are satisfied.

♻ **Rebasing**: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.

🔕 **Ignore**: Close this PR and you won't be reminded about this update again.

---

 - [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check this box

---

This PR has been generated by [Renovate Bot](https://github.com/renovatebot/renovate).
<!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiI0My41LjQiLCJ1cGRhdGVkSW5WZXIiOiI0My41LjQiLCJ0YXJnZXRCcmFuY2giOiJtYWluIiwibGFiZWxzIjpbImFjdGlvbiIsImRlcHMiXX0=-->

Reviewed-on: #46
Reviewed-by: t.behrendt <t.behrendt@noreply.localhost>
Co-authored-by: Renovate Bot <renovate@t00n.de>
Co-committed-by: Renovate Bot <renovate@t00n.de>
2026-04-28 17:11:03 +02:00
renovate-bot 5982457d82 chore(deps): update helmfile/helmfile-action action to v2.4.3 (#47)
Release / Release (push) Successful in 20s
This PR contains the following updates:

| Package | Type | Update | Change |
|---|---|---|---|
| [helmfile/helmfile-action](https://github.com/helmfile/helmfile-action) | action | patch | `v2.4.2` → `v2.4.3` |

---

### Release Notes

<details>
<summary>helmfile/helmfile-action (helmfile/helmfile-action)</summary>

### [`v2.4.3`](https://github.com/helmfile/helmfile-action/releases/tag/v2.4.3)

[Compare Source](https://github.com/helmfile/helmfile-action/compare/v2.4.2...v2.4.3)

##### What's Changed

- build(deps-dev): bump [@&#8203;typescript-eslint/parser](https://github.com/typescript-eslint/parser) from 8.58.0 to 8.58.1 by [@&#8203;dependabot](https://github.com/dependabot)\[bot] in [#&#8203;670](https://github.com/helmfile/helmfile-action/pull/670)
- build(deps-dev): bump eslint-plugin-jest from 29.15.1 to 29.15.2 by [@&#8203;dependabot](https://github.com/dependabot)\[bot] in [#&#8203;673](https://github.com/helmfile/helmfile-action/pull/673)
- build(deps-dev): bump prettier from 3.8.1 to 3.8.2 by [@&#8203;dependabot](https://github.com/dependabot)\[bot] in [#&#8203;672](https://github.com/helmfile/helmfile-action/pull/672)
- build(deps-dev): bump [@&#8203;typescript-eslint/eslint-plugin](https://github.com/typescript-eslint/eslint-plugin) from 8.58.0 to 8.58.1 by [@&#8203;dependabot](https://github.com/dependabot)\[bot] in [#&#8203;669](https://github.com/helmfile/helmfile-action/pull/669)
- build(deps-dev): bump [@&#8203;types/node](https://github.com/types/node) from 25.5.2 to 25.6.0 by [@&#8203;dependabot](https://github.com/dependabot)\[bot] in [#&#8203;671](https://github.com/helmfile/helmfile-action/pull/671)
- build(deps-dev): bump globals from 17.4.0 to 17.5.0 by [@&#8203;dependabot](https://github.com/dependabot)\[bot] in [#&#8203;674](https://github.com/helmfile/helmfile-action/pull/674)
- build(deps-dev): bump [@&#8203;typescript-eslint/eslint-plugin](https://github.com/typescript-eslint/eslint-plugin) from 8.58.1 to 8.58.2 by [@&#8203;dependabot](https://github.com/dependabot)\[bot] in [#&#8203;676](https://github.com/helmfile/helmfile-action/pull/676)
- build(deps-dev): bump typescript from 6.0.2 to 6.0.3 by [@&#8203;dependabot](https://github.com/dependabot)\[bot] in [#&#8203;679](https://github.com/helmfile/helmfile-action/pull/679)
- build(deps-dev): bump [@&#8203;swc/core](https://github.com/swc/core) from 1.15.24 to 1.15.30 by [@&#8203;dependabot](https://github.com/dependabot)\[bot] in [#&#8203;680](https://github.com/helmfile/helmfile-action/pull/680)
- build(deps-dev): bump prettier from 3.8.2 to 3.8.3 by [@&#8203;dependabot](https://github.com/dependabot)\[bot] in [#&#8203;677](https://github.com/helmfile/helmfile-action/pull/677)
- build(deps-dev): bump [@&#8203;typescript-eslint/parser](https://github.com/typescript-eslint/parser) from 8.58.1 to 8.58.2 by [@&#8203;dependabot](https://github.com/dependabot)\[bot] in [#&#8203;675](https://github.com/helmfile/helmfile-action/pull/675)

**Full Changelog**: <https://github.com/helmfile/helmfile-action/compare/v2.4.2...v2.4.3>

</details>

---

### Configuration

📅 **Schedule**: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined).

🚦 **Automerge**: Disabled by config. Please merge this manually once you are satisfied.

♻ **Rebasing**: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.

🔕 **Ignore**: Close this PR and you won't be reminded about this update again.

---

 - [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check this box

---

This PR has been generated by [Renovate Bot](https://github.com/renovatebot/renovate).
<!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiI0My41LjQiLCJ1cGRhdGVkSW5WZXIiOiI0My41LjQiLCJ0YXJnZXRCcmFuY2giOiJtYWluIiwibGFiZWxzIjpbImFjdGlvbiIsImRlcHMiXX0=-->

Reviewed-on: #47
Reviewed-by: t.behrendt <t.behrendt@noreply.localhost>
Co-authored-by: Renovate Bot <renovate@t00n.de>
Co-committed-by: Renovate Bot <renovate@t00n.de>
2026-04-28 17:09:07 +02:00
renovate-bot 2d3fc7613a chore(deps): update https://gitea.t000-n.de/t.behrendt/conventional-semantic-git-tag-increment action to v0.1.32 (#48)
This PR contains the following updates:

| Package | Type | Update | Change |
|---|---|---|---|
| [https://gitea.t000-n.de/t.behrendt/conventional-semantic-git-tag-increment](https://gitea.t000-n.de/t.behrendt/conventional-semantic-git-tag-increment) | action | patch | `0.1.31` → `0.1.32` |

---

### Release Notes

<details>
<summary>t.behrendt/conventional-semantic-git-tag-increment (https://gitea.t000-n.de/t.behrendt/conventional-semantic-git-tag-increment)</summary>

### [`v0.1.32`](https://gitea.t000-n.de/t.behrendt/conventional-semantic-git-tag-increment/compare/0.1.31...0.1.32)

[Compare Source](https://gitea.t000-n.de/t.behrendt/conventional-semantic-git-tag-increment/compare/0.1.31...0.1.32)

</details>

---

### Configuration

📅 **Schedule**: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined).

🚦 **Automerge**: Disabled by config. Please merge this manually once you are satisfied.

♻ **Rebasing**: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.

🔕 **Ignore**: Close this PR and you won't be reminded about this update again.

---

 - [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check this box

---

This PR has been generated by [Renovate Bot](https://github.com/renovatebot/renovate).
<!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiI0My41LjQiLCJ1cGRhdGVkSW5WZXIiOiI0My41LjQiLCJ0YXJnZXRCcmFuY2giOiJtYWluIiwibGFiZWxzIjpbImFjdGlvbiIsImRlcHMiXX0=-->

Reviewed-on: #48
Reviewed-by: t.behrendt <t.behrendt@noreply.localhost>
Co-authored-by: Renovate Bot <renovate@t00n.de>
Co-committed-by: Renovate Bot <renovate@t00n.de>
2026-04-28 17:04:11 +02:00
7 changed files with 100 additions and 247 deletions
@@ -1,19 +0,0 @@
name: Extract chart name from repo name
description: Extracts the chart name from the repo name, based on the convention of helm-<chart-name>
inputs:
repo:
description: The full repository name (e.g., "helm-my-chart")
required: true
outputs:
chart-name:
description: The extracted chart name
value: ${{ steps.extract.outputs.suffix }}
runs:
using: "composite"
steps:
- id: extract
shell: bash
run: |
full_repo="${{ inputs.repo }}"
suffix="${full_repo##*helm-}"
echo "suffix=$suffix" >> $GITHUB_OUTPUT
@@ -1,19 +0,0 @@
name: "Extract namespace from repo name"
description: "Extracts the namespace name from the repo name, based on the convention of k_<namespace-name>"
inputs:
repo:
description: 'The repo name, get it from "github.repository"'
required: true
outputs:
namespace:
description: "The namespace name"
value: ${{ steps.extract.outputs.suffix }}
runs:
using: "composite"
steps:
- id: extract
shell: bash
run: |
full_repo="${{ inputs.repo }}"
suffix="${full_repo##*k_}"
echo "suffix=$suffix" >> $GITHUB_OUTPUT
@@ -3,35 +3,30 @@ name: Deploy
on: on:
workflow_call: workflow_call:
inputs: inputs:
# Optional: Override the default k8s directory path
k8s_dir: k8s_dir:
description: "Path to Kubernetes manifests directory" description: "Override the default k8s directory path (k8s/)"
required: false required: false
default: "k8s/" default: "k8s/"
type: string type: string
# Optional: Override the default helmfile path
helmfile_path: helmfile_path:
description: "Path to helmfile.yaml" description: "Override the default helmfile path (hemfile.yaml)"
required: false required: false
default: "helmfile.yaml" default: "helmfile.yaml"
type: string type: string
# Optional: Skip Helm deployment even if helmfile exists
skip_helm_deployment: skip_helm_deployment:
description: "Skip Helm deployment even if helmfile.yaml exists" description: "Skip Helm deployment even if helmfile.yaml exists"
required: false required: false
default: false default: false
type: boolean type: boolean
# Optional: Custom secrets to create (JSON array of secret objects) skip_shared_secrets_deployment:
custom_secrets: description: "Skip shared secrets deployment (e.g. restic backup secret)"
description: "JSON array of secrets to create. Each secret should have: name, type, data"
required: false required: false
default: "[]" default: false
type: string type: boolean
# Optional: Branch to deploy from helmfile_env:
deploy_branch: description: "Optional JSON object string of environment variables for Helmfile"
description: "Branch to deploy from"
required: false required: false
default: "main" default: "{}"
type: string type: string
jobs: jobs:
@@ -63,15 +58,13 @@ jobs:
echo "No k8s directory found at ${{ inputs.k8s_dir }}" echo "No k8s directory found at ${{ inputs.k8s_dir }}"
fi fi
deploy-k8s: deploy-shared-secrets:
runs-on: ubuntu-latest runs-on: ubuntu-latest
needs: detect-service-type needs: detect-service-type
if: needs.detect-service-type.outputs.has_k8s == 'true' if: inputs.skip_shared_secrets_deployment != 'true'
steps: steps:
- uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
with: - uses: https://gitea.t000-n.de/t.behrendt/k_deploy_actions/.gitea/actions/extract-namespace-from-repo-name@0.0.1
ref: ${{ inputs.deploy_branch }}
- uses: ./.gitea/actions/extract-namespace-from-repo-name
id: namespace id: namespace
with: with:
repo: ${{ github.repository }} repo: ${{ github.repository }}
@@ -80,31 +73,37 @@ jobs:
with: with:
method: kubeconfig method: kubeconfig
kubeconfig: ${{ secrets.KUBECONFIG }} kubeconfig: ${{ secrets.KUBECONFIG }}
- name: Create custom secrets - name: Set restic backup secret
id: create-secrets uses: azure/k8s-create-secret@6e0ba8047235646753f2a3a3b359b4d0006ff218 # v5.0.1
run: | with:
# Parse custom secrets from input namespace: ${{ steps.namespace.outputs.namespace }}
SECRETS='${{ inputs.custom_secrets }}' secret-name: backupsidecar-secret
if [ "$SECRETS" != "[]" ]; then secret-type: generic
echo "Creating custom secrets..." data: |
echo "$SECRETS" | jq -c '.[]' | while read -r secret; do {
SECRET_NAME=$(echo "$secret" | jq -r '.name') "restic_password": "${{ secrets.RESTIC_PASSWORD }}",
SECRET_TYPE=$(echo "$secret" | jq -r '.type // "generic"') "restic_rest_username": "${{ secrets.RESTIC_REST_USERNAME }}",
SECRET_DATA=$(echo "$secret" | jq -r '.data') "restic_rest_password": "${{ secrets.RESTIC_REST_PASSWORD }}",
"gotify_token": "${{ secrets.GOTIFY_TOKEN }}"
}
echo "Creating secret: $SECRET_NAME (type: $SECRET_TYPE)" deploy-k8s:
runs-on: ubuntu-latest
# Create the secret using kubectl needs: detect-service-type
echo "$SECRET_DATA" | kubectl create secret $SECRET_TYPE $SECRET_NAME \ if: needs.detect-service-type.outputs.has_k8s == 'true'
--from-literal=secret.json="$SECRET_DATA" \ steps:
--namespace=${{ steps.namespace.outputs.namespace }} \ - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
--dry-run=client -o yaml | kubectl apply -f - - uses: https://gitea.t000-n.de/t.behrendt/k_deploy_actions/.gitea/actions/extract-namespace-from-repo-name@0.0.1
done id: namespace
else with:
echo "No custom secrets to create" repo: ${{ github.repository }}
fi - uses: azure/setup-kubectl@829323503d1be3d00ca8346e5391ca0b07a9ab0d # v5.1.0
- uses: azure/k8s-set-context@89b837d75b40a7bd2ddafde837473c212db8b313 # v5.0.0
with:
method: kubeconfig
kubeconfig: ${{ secrets.KUBECONFIG }}
- name: Deploy Kubernetes manifests - name: Deploy Kubernetes manifests
uses: azure/k8s-deploy@c8cfec839dc09896b3b8cc40cd13d04792680771 # v5.1.0 uses: azure/k8s-deploy@c7ebd0d5f39477a23f1b5dea0f52e6db04adf28e # v6.0.0
with: with:
action: deploy action: deploy
manifests: "${{ inputs.k8s_dir }}" manifests: "${{ inputs.k8s_dir }}"
@@ -120,9 +119,7 @@ jobs:
inputs.skip_helm_deployment != 'true' inputs.skip_helm_deployment != 'true'
steps: steps:
- uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
with: - uses: https://gitea.t000-n.de/t.behrendt/k_deploy_actions/.gitea/actions/extract-namespace-from-repo-name@0.0.1
ref: ${{ inputs.deploy_branch }}
- uses: ./.gitea/actions/extract-namespace-from-repo-name
id: namespace id: namespace
with: with:
repo: ${{ github.repository }} repo: ${{ github.repository }}
@@ -132,38 +129,16 @@ jobs:
with: with:
method: kubeconfig method: kubeconfig
kubeconfig: ${{ secrets.KUBECONFIG }} kubeconfig: ${{ secrets.KUBECONFIG }}
- name: Create custom secrets
id: create-secrets
run: |
# Parse custom secrets from input
SECRETS='${{ inputs.custom_secrets }}'
if [ "$SECRETS" != "[]" ]; then
echo "Creating custom secrets..."
echo "$SECRETS" | jq -c '.[]' | while read -r secret; do
SECRET_NAME=$(echo "$secret" | jq -r '.name')
SECRET_TYPE=$(echo "$secret" | jq -r '.type // "generic"')
SECRET_DATA=$(echo "$secret" | jq -r '.data')
echo "Creating secret: $SECRET_NAME (type: $SECRET_TYPE)"
# Create the secret using kubectl
echo "$SECRET_DATA" | kubectl create secret $SECRET_TYPE $SECRET_NAME \
--from-literal=secret.json="$SECRET_DATA" \
--namespace=${{ steps.namespace.outputs.namespace }} \
--dry-run=client -o yaml | kubectl apply -f -
done
else
echo "No custom secrets to create"
fi
- name: Deploy Helm - name: Deploy Helm
uses: helmfile/helmfile-action@8676eae58f17e6232c519147a0729f5f3d67a8a0 # v2.4.2 uses: helmfile/helmfile-action@02671705b1dda1dc4b0a4ddd4f9f1ea8f4568c6f # v2.4.3
with: with:
helmfile-args: apply helmfile-args: apply
env: ${{ fromJSON(inputs.helmfile_env) }}
# Summary job that always runs to show what was deployed # Summary job that always runs to show what was deployed
deployment-summary: deployment-summary:
runs-on: ubuntu-latest runs-on: ubuntu-latest
needs: [ detect-service-type, deploy-k8s, deploy-helm ] needs: [detect-service-type, deploy-k8s, deploy-helm]
if: always() if: always()
steps: steps:
- name: Deployment Summary - name: Deployment Summary
@@ -187,11 +162,3 @@ jobs:
echo "" >> $GITHUB_STEP_SUMMARY echo "" >> $GITHUB_STEP_SUMMARY
echo "**Service Type**: ${{ needs.detect-service-type.outputs.has_helmfile == 'true' && 'Helm + Kubernetes' || 'Kubernetes Only' }}" >> $GITHUB_STEP_SUMMARY echo "**Service Type**: ${{ needs.detect-service-type.outputs.has_helmfile == 'true' && 'Helm + Kubernetes' || 'Kubernetes Only' }}" >> $GITHUB_STEP_SUMMARY
# Show custom secrets info
SECRETS='${{ inputs.custom_secrets }}'
if [ "$SECRETS" != "[]" ]; then
echo "" >> $GITHUB_STEP_SUMMARY
echo "**Custom Secrets Created**: $(echo "$SECRETS" | jq length)" >> $GITHUB_STEP_SUMMARY
echo "$SECRETS" | jq -r '.[] | "- " + .name + " (" + (.type // "generic") + ")"' >> $GITHUB_STEP_SUMMARY
fi
+5 -4
View File
@@ -5,8 +5,9 @@ on:
branches: branches:
- main - main
paths: paths:
- ".gitea/workflows/cd.yaml" - ".gitea/workflows/deploy.yaml"
- ".gitea/workflows/ci.yaml" - ".gitea/workflows/validate.yaml"
workflow_dispatch:
jobs: jobs:
release: release:
@@ -18,10 +19,10 @@ jobs:
fetch-depth: 0 fetch-depth: 0
- name: Increment tag - name: Increment tag
id: tag id: tag
uses: https://gitea.t000-n.de/t.behrendt/conventional-semantic-git-tag-increment@74d41d9bd9c243f295b53762681c714f3d24fd4c # 0.1.31 uses: https://gitea.t000-n.de/t.behrendt/conventional-semantic-git-tag-increment@ef0c23189db33220a73022d8c29a27709d0df440 # 0.1.32
with: with:
token: ${{ secrets.GITEA_TOKEN }} token: ${{ secrets.GITEA_TOKEN }}
- name: Push tag - name: Push tag
uses: https://gitea.t000-n.de/t.behrendt/actions/release-git-tag@f386e2570df6a796ba0a69865c89ea0c1a7109ab # 0.2.2 uses: https://gitea.t000-n.de/t.behrendt/actions/release-git-tag@47a1c635cfc76cfb4eeee3db0d0b89bf19007c7a # 0.2.3
with: with:
tag: ${{ steps.tag.outputs.new-tag }} tag: ${{ steps.tag.outputs.new-tag }}
@@ -18,6 +18,11 @@ on:
required: false required: false
default: false default: false
type: boolean type: boolean
helmfile_env:
description: "Optional JSON object string of environment variables for Helmfile"
required: false
default: "{}"
type: string
jobs: jobs:
detect-service-type: detect-service-type:
@@ -54,7 +59,7 @@ jobs:
if: needs.detect-service-type.outputs.has_k8s == 'true' if: needs.detect-service-type.outputs.has_k8s == 'true'
steps: steps:
- uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
- uses: ./.gitea/actions/extract-namespace-from-repo-name - uses: https://gitea.t000-n.de/t.behrendt/k_deploy_actions/.gitea/actions/extract-namespace-from-repo-name@0.0.1
id: namespace id: namespace
with: with:
repo: ${{ github.repository }} repo: ${{ github.repository }}
@@ -79,7 +84,7 @@ jobs:
inputs.skip_helm_validation != 'true' inputs.skip_helm_validation != 'true'
steps: steps:
- uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 - uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2
- uses: ./.gitea/actions/extract-namespace-from-repo-name - uses: https://gitea.t000-n.de/t.behrendt/k_deploy_actions/.gitea/actions/extract-namespace-from-repo-name@0.0.1
id: namespace id: namespace
with: with:
repo: ${{ github.repository }} repo: ${{ github.repository }}
@@ -90,14 +95,15 @@ jobs:
method: kubeconfig method: kubeconfig
kubeconfig: ${{ secrets.KUBECONFIG }} kubeconfig: ${{ secrets.KUBECONFIG }}
- name: Validate Helm - name: Validate Helm
uses: helmfile/helmfile-action@8676eae58f17e6232c519147a0729f5f3d67a8a0 # v2.4.2 uses: helmfile/helmfile-action@02671705b1dda1dc4b0a4ddd4f9f1ea8f4568c6f # v2.4.3
with: with:
helmfile-args: diff helmfile-args: diff
env: ${{ fromJSON(inputs.helmfile_env) }}
# Summary job that always runs to show what was validated # Summary job that always runs to show what was validated
ci-summary: ci-summary:
runs-on: ubuntu-latest runs-on: ubuntu-latest
needs: [ detect-service-type, validate-k8s, validate-helm ] needs: [detect-service-type, validate-k8s, validate-helm]
if: always() if: always()
steps: steps:
- name: CI Summary - name: CI Summary
+38 -118
View File
@@ -1,79 +1,75 @@
> [!WARNING] # Reusable CI/CD Workflows for k\_ Services
> Repo is currently not in use and not tested.
> We are waiting for proper shared workflow UI support in gitea. Otherwise errors are hard to identify.
> Follow https://github.com/go-gitea/gitea/issues/24604
# Reusable CI Workflow for Kubernetes Services This repository contains reusable CI and CD workflows that automatically detect Kubernetes service type (Kubernetes-only vs Helm + Kubernetes) and execute the relevant steps.
This directory contains a reusable CI workflow that automatically detects and validates your Kubernetes services, whether they use Helm + Kubernetes or just Kubernetes manifests.
## Features ## Features
- **Automatic Detection**: Automatically detects if your service uses Helm (helmfile.yaml) or just Kubernetes manifests - **Reusable CI and CD**: Separate reusable workflows for validation and deployment
- **Conditional Validation**: Only runs Helm validation when helmfile.yaml exists - **Automatic Detection**: Detects whether `helmfile.yaml` exists and whether `k8s/` exists
- **Flexible Paths**: Configurable paths for k8s directory and helmfile - **Conditional Execution**: Runs Helm steps only when applicable
- **Comprehensive Validation**: Validates both Kubernetes manifests and Helm charts - **Flexible Inputs**: Supports custom `k8s_dir` and `helmfile_path`
- **CI Summary**: Provides a clear summary of what was validated
## Usage ## Usage
### Basic Usage (Recommended) ### Basic CI Usage
Simply call the workflow without any parameters - it will automatically detect your service type: Call the reusable CI workflow:
```yaml ```yaml
jobs: jobs:
ci: ci:
uses: ./.gitea/workflows/ci.yaml uses: https://gitea.t000-n.de/t.behrendt/k_deploy_workflows/.gitea/workflows/ci.yaml@main
secrets: inherit
``` ```
### Advanced Usage with Custom Paths ### Basic CD Usage
If your service uses non-standard directory names: Call the reusable CD workflow:
```yaml
jobs:
deploy:
uses: https://gitea.t000-n.de/t.behrendt/k_deploy_workflows/.gitea/workflows/cd.yaml@main
secrets: inherit
```
### Advanced Usage with Custom Paths and Flags
```yaml ```yaml
jobs: jobs:
ci: ci:
uses: ./.gitea/workflows/ci.yaml uses: https://gitea.t000-n.de/t.behrendt/k_deploy_workflows/.gitea/workflows/ci.yaml@main
with: with:
k8s_dir: "kubernetes/" k8s_dir: "kubernetes/"
helmfile_path: "helm/helmfile.yaml" helmfile_path: "helm/helmfile.yaml"
```
### Force Skip Helm Validation
If you want to skip Helm validation even when helmfile.yaml exists:
```yaml
jobs:
ci:
uses: ./.gitea/workflows/ci.yaml
with:
skip_helm_validation: true skip_helm_validation: true
secrets: inherit
``` ```
## Input Parameters ## Inputs
### CI (`.gitea/workflows/ci.yaml`)
| Parameter | Description | Default | Required | | Parameter | Description | Default | Required |
| ---------------------- | -------------------------------------------- | --------------- | -------- | | ---------------------- | -------------------------------------------- | --------------- | -------- |
| `k8s_dir` | Path to Kubernetes manifests directory | `k8s/` | No | | `k8s_dir` | Path to Kubernetes manifests directory | `k8s/` | No |
| `helmfile_path` | Path to helmfile.yaml | `helmfile.yaml` | No | | `helmfile_path` | Path to helmfile.yaml | `helmfile.yaml` | No |
| `skip_helm_validation` | Skip Helm validation even if helmfile exists | `false` | No | | `skip_helm_validation` | Skip Helm validation even if helmfile exists | `false` | No |
| `helmfile_env` | JSON object string passed as env to helmfile | `{}` | No |
### CD (`.gitea/workflows/cd.yaml`)
| Parameter | Description | Default | Required |
| -------------------------------- | -------------------------------------------- | --------------- | -------- |
| `k8s_dir` | Path to Kubernetes manifests directory | `k8s/` | No |
| `helmfile_path` | Path to helmfile.yaml | `helmfile.yaml` | No |
| `skip_helm_deployment` | Skip Helm deployment even if helmfile exists | `false` | No |
| `skip_shared_secrets_deployment` | Skip shared secrets deployment | `false` | No |
| `helmfile_env` | JSON object string passed as env to helmfile | `{}` | No |
## Directory Structure Requirements ## Directory Structure Requirements
### For Kubernetes-only services: ### Full example structure (Helm + Kubernetes):
```
your-service/
├── k8s/
│ ├── deployment.yaml
│ ├── service.yaml
│ └── ...
└── .gitea/workflows/your-workflow.yaml
```
### For Helm + Kubernetes services:
``` ```
your-service/ your-service/
@@ -84,79 +80,3 @@ your-service/
├── helmfile.yaml ├── helmfile.yaml
└── .gitea/workflows/your-workflow.yaml └── .gitea/workflows/your-workflow.yaml
``` ```
## What Gets Validated
### Always (if k8s/ directory exists):
- Kubernetes manifest validation using `kubectl --dry-run`
- Namespace extraction from repository name
- Basic Kubernetes syntax and schema validation
### Conditionally (if helmfile.yaml exists and Helm validation not skipped):
- Helm chart validation using `helmfile diff`
- Kubernetes manifests in Helm context
- Helm-specific configurations and values
## Example Workflows
See `example-usage.yaml` for complete examples of how to use this workflow in different scenarios.
## Available Actions
### Extract Chart Name from Repository Name
The `extract-chart-name-from-repo-name` action extracts the chart name from repository names following the `helm-<chart-name>` convention.
#### Usage
```yaml
- name: Extract chart name
uses: ./.gitea/actions/extract-chart-name-from-repo-name
with:
repo: ${{ github.repository_name }} # e.g., "helm-my-service"
```
#### Inputs
| Parameter | Description | Required |
| --------- | ------------------------------------------------ | -------- |
| `repo` | The full repository name (e.g., "helm-my-chart") | Yes |
#### Outputs
| Output | Description |
| ------------ | ---------------------------------------------------------------- |
| `chart-name` | The extracted chart name (e.g., "my-chart" from "helm-my-chart") |
#### Example
For a repository named `helm-user-service`, this action will extract `user-service` as the chart name.
## Dependencies
This workflow requires:
- `./.gitea/actions/extract-namespace-from-repo-name` action
- `./.gitea/actions/extract-chart-name-from-repo-name` action
- `KUBECONFIG` secret configured in your repository
- Access to your Kubernetes cluster
## Troubleshooting
### Helm validation skipped unexpectedly
- Check if `helmfile.yaml` exists in the expected location
- Verify the `skip_helm_validation` parameter is not set to `true`
- Ensure the file path is correct if using custom paths
### Kubernetes validation skipped
- Verify the `k8s/` directory (or custom path) exists
- Check the directory contains valid Kubernetes manifests
### Permission issues
- Ensure the `KUBECONFIG` secret is properly configured
- Verify the workflow has access to your Kubernetes cluster
+1 -4
View File
@@ -1,7 +1,4 @@
{ {
"$schema": "https://docs.renovatebot.com/renovate-schema.json", "$schema": "https://docs.renovatebot.com/renovate-schema.json",
"extends": [ "extends": ["local>t.behrendt/renovate-configs:action"]
"local>t.behrendt/renovate-configs:common",
"local>t.behrendt/renovate-configs:action"
]
} }