Initial commit
This commit is contained in:
66
.gitea/workflows/docker-publish.yml
Normal file
66
.gitea/workflows/docker-publish.yml
Normal file
@@ -0,0 +1,66 @@
|
||||
name: Reusable Docker Publish
|
||||
|
||||
on:
|
||||
workflow_call:
|
||||
inputs:
|
||||
image_name:
|
||||
required: true
|
||||
type: string
|
||||
dockerfile_path:
|
||||
type: string
|
||||
default: "."
|
||||
secrets:
|
||||
REGISTRY_USERNAME: { required: true }
|
||||
REGISTRY_PASSWORD: { required: true }
|
||||
DOCKER_REGISTRY: { required: true }
|
||||
NTFY_TOPIC: { required: true }
|
||||
NTFY_TOKEN: { required: true }
|
||||
NTFY_SERVER: { required: true }
|
||||
|
||||
jobs:
|
||||
publish:
|
||||
runs-on: docker
|
||||
container:
|
||||
image: gitea.tech-buddy.at/bitbuddydev/gitea_runner_python314:dev-bda315b82bb23d83065b77d91fedf0e20d9accf1
|
||||
credentials:
|
||||
username: ${{ secrets.REGISTRY_USERNAME }}
|
||||
password: ${{ secrets.REGISTRY_PASSWORD }}
|
||||
|
||||
steps:
|
||||
- name: Checkout
|
||||
uses: actions/checkout@v4
|
||||
|
||||
- name: Extract Tags
|
||||
id: vars
|
||||
shell: bash
|
||||
run: |
|
||||
SHA_SHORT="$(git rev-parse --short HEAD)"
|
||||
FULL_IMAGE="${{ secrets.DOCKER_REGISTRY }}/${{ inputs.image_name }}"
|
||||
TAGS="-t ${FULL_IMAGE}:${SHA_SHORT}"
|
||||
|
||||
if echo "${{ gitea.ref }}" | grep -q '^refs/tags/v'; then
|
||||
VERSION="${{ gitea.ref_name }}"
|
||||
VERSION="${VERSION#v}"
|
||||
MAJOR="$(echo "$VERSION" | cut -d. -f1)"
|
||||
MINOR="$(echo "$VERSION" | cut -d. -f1,2)"
|
||||
TAGS="${TAGS} -t ${FULL_IMAGE}:latest -t ${FULL_IMAGE}:${VERSION} -t ${FULL_IMAGE}:${MINOR} -t ${FULL_IMAGE}:${MAJOR}"
|
||||
fi
|
||||
|
||||
echo "docker_tags=${TAGS}" >> "$GITEA_OUTPUT"
|
||||
echo "full_image=${FULL_IMAGE}" >> "$GITEA_OUTPUT"
|
||||
|
||||
- name: Docker Login
|
||||
run: |
|
||||
echo "${{ secrets.REGISTRY_PASSWORD }}" | docker login "${{ secrets.DOCKER_REGISTRY }}" -u "${{ secrets.REGISTRY_USERNAME }}" --password-stdin
|
||||
|
||||
- name: Build and Push
|
||||
run: |
|
||||
export DOCKER_BUILDKIT=1
|
||||
docker build ${{ steps.vars.outputs.docker_tags }} ${{ inputs.dockerfile_path }}
|
||||
|
||||
IMAGE="${{ steps.vars.outputs.full_image }}"
|
||||
for part in ${{ steps.vars.outputs.docker_tags }}; do
|
||||
if [[ "$part" == "${IMAGE}:"* ]]; then
|
||||
docker push "$part"
|
||||
fi
|
||||
done
|
||||
52
.gitea/workflows/notifications.yml
Normal file
52
.gitea/workflows/notifications.yml
Normal file
@@ -0,0 +1,52 @@
|
||||
name: Notification
|
||||
|
||||
on:
|
||||
workflow_call:
|
||||
inputs:
|
||||
job_status:
|
||||
required: true
|
||||
type: string
|
||||
job_name:
|
||||
required: true
|
||||
type: string
|
||||
secrets:
|
||||
NTFY_TOPIC: { required: true }
|
||||
NTFY_TOKEN: { required: true }
|
||||
NTFY_SERVER: { required: true }
|
||||
|
||||
jobs:
|
||||
notify:
|
||||
runs-on: docker
|
||||
steps:
|
||||
- name: Send Notification
|
||||
shell: bash
|
||||
run: |
|
||||
# Icon und Titel basierend auf Status
|
||||
if [ "${{ inputs.job_status }}" == "success" ]; then
|
||||
ICON="✅"
|
||||
TITLE="Fixed: ${{ inputs.job_name }} for ${{ gitea.repository }}"
|
||||
else
|
||||
ICON="❌"
|
||||
TITLE="Failed: ${{ inputs.job_name }} for ${{ gitea.repository }}"
|
||||
fi
|
||||
|
||||
COMMIT_SUBJECT="$(git log -1 --pretty=%s || echo 'Commit info unavailable')"
|
||||
RUN_URL="${{ gitea.server_url }}/${{ gitea.repository }}/actions/runs/${{ gitea.run_number }}"
|
||||
|
||||
cat <<EOF >/tmp/ntfy-payload.json
|
||||
{
|
||||
"topic": "${{ secrets.NTFY_TOPIC }}",
|
||||
"title": "${ICON} ${TITLE}",
|
||||
"message": "Ref: ${{ gitea.ref_name }}\nCommit: ${COMMIT_SUBJECT}\n\nRun URL: ${RUN_URL}",
|
||||
"click": "${RUN_URL}",
|
||||
"actions": [
|
||||
{ "action": "view", "label": "Open Run", "url": "${RUN_URL}" }
|
||||
]
|
||||
}
|
||||
EOF
|
||||
|
||||
curl -fsS \
|
||||
-H "Authorization: Bearer ${{ secrets.NTFY_TOKEN }}" \
|
||||
-H "Content-Type: application/json" \
|
||||
-d @/tmp/ntfy-payload.json \
|
||||
"${{ secrets.NTFY_SERVER }}"
|
||||
60
.gitea/workflows/python-checks.yml
Normal file
60
.gitea/workflows/python-checks.yml
Normal file
@@ -0,0 +1,60 @@
|
||||
name: Reusable Python Checks
|
||||
|
||||
on:
|
||||
workflow_call:
|
||||
inputs:
|
||||
python_version:
|
||||
type: string
|
||||
default: "3.14"
|
||||
test_command:
|
||||
type: string
|
||||
default: "coverage run -m pytest"
|
||||
|
||||
jobs:
|
||||
check:
|
||||
runs-on: docker
|
||||
container:
|
||||
image: gitea.tech-buddy.at/bitbuddydev/gitea_runner_python314:dev-bda315b82bb23d83065b77d91fedf0e20d9accf1
|
||||
credentials:
|
||||
username: ${{ secrets.REGISTRY_USERNAME }}
|
||||
password: ${{ secrets.REGISTRY_PASSWORD }}
|
||||
|
||||
steps:
|
||||
- name: Checkout
|
||||
uses: actions/checkout@v4
|
||||
|
||||
- name: Install Tools & Deps
|
||||
run: |
|
||||
python -m pip install --upgrade pip setuptools wheel
|
||||
pip install -e .[dev] || pip install -e .[test] || pip install -e .
|
||||
pip install ruff coverage pip-audit bandit
|
||||
|
||||
- name: Linting
|
||||
run: ruff check app tests
|
||||
|
||||
- name: Tests
|
||||
run: |
|
||||
${{ inputs.test_command }}
|
||||
coverage report --fail-under=60
|
||||
coverage xml
|
||||
coverage html
|
||||
|
||||
- name: Security Scan
|
||||
run: |
|
||||
pip freeze | grep -v "git+" > req.txt
|
||||
pip-audit -r req.txt
|
||||
bandit -r app/
|
||||
|
||||
- name: Upload Coverage
|
||||
if: always()
|
||||
uses: actions/upload-artifact@v3
|
||||
with:
|
||||
name: coverage-report
|
||||
path: |
|
||||
htmlcov/
|
||||
coverage.xml
|
||||
|
||||
- name: Notify on Failure
|
||||
if: failure()
|
||||
run: |
|
||||
# (Deine ntfy-Logik hier einfügen)
|
||||
Reference in New Issue
Block a user