Compare commits

..

26 commits

Author SHA1 Message Date
KV-Tube Deployer
eb011f720b ci: trigger docker build
Some checks failed
Build & Push Docker Image / build (push) Failing after 39s
2026-03-28 16:13:58 +07:00
KV-Tube Deployer
5d2e28dd99 merge: combine forgejo into main docker-compose 2026-03-28 15:54:13 +07:00
KV-Tube Deployer
1bdbffbc99 fix: update runner token 2026-03-28 15:46:58 +07:00
KV-Tube Deployer
e44d1b8b5a fix: use latest runner version 2026-03-28 15:39:18 +07:00
KV-Tube Deployer
ccee56aff2 remove: all GitHub related files 2026-03-28 15:38:29 +07:00
KV-Tube Deployer
3b2078b203 fix: new runner token 2026-03-28 15:14:34 +07:00
KV-Tube Deployer
601fce07f8 fix: test new token 2026-03-28 15:07:50 +07:00
KV-Tube Deployer
61a627483d fix: new runner token 2026-03-28 14:53:23 +07:00
KV-Tube Deployer
971d3e4b8f fix: new runner token 2026-03-28 14:51:33 +07:00
KV-Tube Deployer
6e766a28ae fix: match runner labels with workflow 2026-03-28 14:48:30 +07:00
KV-Tube Deployer
cfcf0a2800 ci: trigger workflow 2026-03-28 14:46:11 +07:00
KV-Tube Deployer
729bfbe49e fix: use docker:host label 2026-03-28 14:44:50 +07:00
KV-Tube Deployer
871d506f83 fix: simplify workflow for Forgejo 2026-03-28 14:42:55 +07:00
KV-Tube Deployer
6a70fc8438 fix: use forgejo 9 to match database version 2026-03-28 14:36:20 +07:00
KV-Tube Deployer
cbb487d307 ci: trigger workflow test 2026-03-28 11:26:45 +07:00
KV-Tube Deployer
ab37e8408a fix: match workflow runs-on with runner labels 2026-03-28 11:24:10 +07:00
KV-Tube Deployer
494b672aba ci: test forgejo workflow 2026-03-28 11:22:55 +07:00
KV-Tube Deployer
f289ff86b0 fix: update runner token 2026-03-28 11:21:49 +07:00
KV-Tube Deployer
f14f0ac299 fix: add runner registration 2026-03-28 11:19:12 +07:00
KV-Tube Deployer
cd8a69f1ad fix: correct runner command 2026-03-28 11:18:00 +07:00
KV-Tube Deployer
db7619b975 fix: use shell entrypoint for runner 2026-03-28 11:17:09 +07:00
KV-Tube Deployer
dce0f4c5f6 fix: use command for runner 2026-03-28 11:16:23 +07:00
KV-Tube Deployer
9b23ba183b fix: setup forgejo with manual runner registration 2026-03-28 11:14:16 +07:00
KV-Tube Deployer
77418ef60b fix: use forgejo 7 2026-03-28 11:10:21 +07:00
KV-Tube Deployer
24f6d524e2 fix: enable actions via environment variable 2026-03-28 11:08:53 +07:00
KV-Tube Deployer
1c867043fc fix: use external Forgejo instance for CI 2026-03-28 11:05:35 +07:00
5 changed files with 36 additions and 239 deletions

View file

@ -1 +1,4 @@
test
test
ci test Sat Mar 28 11:26:45 +07 2026
test Sat Mar 28 14:46:11 +07 2026

View file

@ -3,70 +3,24 @@ name: Build & Push Docker Image
on:
push:
branches: [main, master]
tags: ['v*']
workflow_dispatch:
inputs:
api_url:
description: 'API URL for frontend build'
required: false
default: 'http://ut.khoavo.myds.me:8981/api'
type: string
jobs:
build:
runs-on: docker:host
runs-on: ubuntu-latest
steps:
- name: Tools check
run: |
echo "Docker: $(docker --version)"
echo "Git: $(git --version)"
- name: Checkout
run: |
cd /tmp
rm -rf kv-tube
git clone https://vndangkhoa:Thieugia19@git.khoavo.myds.me/vndangkhoa/kv-tube.git
git clone https://vndangkhoa:b14bc4938aeb5f4014fa15186985a0a625f7e9b4@nas:3050/vndangkhoa/kv-tube.git
cd kv-tube
git checkout ${GITEA_SHA:-main}
echo "Checked out: $(git rev-parse --short HEAD)"
- name: Login to registry
run: echo "Thieugia19" | docker login git.khoavo.myds.me -u vndangkhoa --password-stdin
- name: Build and push
run: |
cd /tmp/kv-tube
SHA_SHORT=$(git rev-parse --short HEAD)
IMAGE="git.khoavo.myds.me/vndangkhoa/kv-tube"
TAGS="${IMAGE}:${SHA_SHORT}"
if [ "${GITEA_REF}" = "refs/heads/main" ] || [ "${GITEA_REF}" = "refs/heads/master" ]; then
TAGS="${TAGS},${IMAGE}:main"
fi
if echo "${GITEA_REF}" | grep -q "refs/tags/v"; then
VERSION=${GITEA_REF#refs/tags/v}
TAGS="${TAGS},${IMAGE}:${VERSION},${IMAGE}:latest"
fi
echo "Building tags: ${TAGS}"
TAG_ARGS=""
IFS=',' read -ra TAG_ARRAY <<< "${TAGS}"
for tag in "${TAG_ARRAY[@]}"; do
TAG_ARGS="${TAG_ARGS} -t ${tag}"
done
docker build \
${TAG_ARGS} \
--build-arg NEXT_PUBLIC_API_URL=${{ gitea.event.inputs.api_url || 'http://ut.khoavo.myds.me:8981/api' }} \
.
for tag in "${TAG_ARRAY[@]}"; do
echo "Pushing ${tag}..."
docker push "${tag}"
done
- name: Verify
run: docker images | grep kv-tube
- name: Cleanup
if: always()
run: rm -rf /tmp/kv-tube
docker build -t ${IMAGE}:${SHA_SHORT} .
docker push ${IMAGE}:${SHA_SHORT}

View file

@ -1,114 +0,0 @@
name: CI
on:
push:
branches: [main, master]
pull_request:
branches: [main, master]
workflow_dispatch:
inputs:
api_url:
description: 'API URL'
required: false
default: 'http://ut.khoavo.myds.me:8981/api'
type: string
jobs:
lint:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: '3.11'
- name: Install dependencies
run: |
python -m pip install --upgrade pip
pip install ruff mypy bandit types-requests
pip install -r requirements.txt
- name: Run Ruff
run: ruff check . --output-format=github
- name: Run MyPy
run: mypy app/ config.py --ignore-missing-imports
continue-on-error: true
- name: Run Bandit
run: bandit -r app/ -x app/routes/api --skip B101,B311
continue-on-error: true
test:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: '3.11'
- name: Install dependencies
run: |
python -m pip install --upgrade pip
pip install -r requirements.txt
pip install pytest pytest-cov
- name: Run tests
run: pytest tests/ -v --tb=short
continue-on-error: true
build:
runs-on: ubuntu-latest
needs: [lint, test]
if: startsWith(github.ref, 'refs/tags/')
steps:
- uses: actions/checkout@v4
- name: Set up QEMU
uses: docker/setup-qemu-action@v3
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Log into Docker Hub
uses: docker/login-action@v3
with:
registry: docker.io
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}
- name: Log into Forgejo Registry
uses: docker/login-action@v3
with:
registry: git.khoavo.myds.me
username: ${{ secrets.FORGEJO_USERNAME }}
password: ${{ secrets.FORGEJO_PASSWORD }}
- name: Extract Docker metadata
id: meta
uses: docker/metadata-action@v5
with:
images: |
docker.io/${{ github.repository }}
git.khoavo.myds.me/${{ github.repository }}
tags: |
type=semver,pattern={{version}}
type=raw,value=latest,enable=${{ github.ref == 'refs/tags/v*' }}
- name: Build and push Docker image
uses: docker/build-push-action@v5
with:
context: .
push: true
tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}
platforms: linux/amd64
cache-from: type=gha
cache-to: type=gha,mode=max
build-args: |
NEXT_PUBLIC_API_URL=${{ github.event.inputs.api_url || 'http://ut.khoavo.myds.me:8981/api' }}

View file

@ -1,56 +0,0 @@
name: Docker Build & Push
on:
push:
tags:
- 'v*'
workflow_dispatch:
inputs:
api_url:
description: 'API URL'
required: false
default: 'http://ut.khoavo.myds.me:8981/api'
type: string
jobs:
build:
runs-on: ubuntu-latest
permissions:
contents: read
packages: write
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Log into Forgejo Registry
uses: docker/login-action@v3
with:
registry: git.khoavo.myds.me
username: ${{ secrets.FORGEJO_USERNAME }}
password: ${{ secrets.FORGEJO_PASSWORD }}
- name: Extract metadata
id: meta
uses: docker/metadata-action@v5
with:
images: git.khoavo.myds.me/vndangkhoa/kv-tube
tags: |
type=semver,pattern={{version}}
type=raw,value=latest,enable=${{ github.ref == 'refs/tags/v*' }}
- name: Build and push
uses: docker/build-push-action@v5
with:
context: .
push: true
tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}
platforms: linux/amd64
cache-from: type=gha
cache-to: type=gha,mode=max
build-args: |
NEXT_PUBLIC_API_URL=${{ github.event.inputs.api_url || 'http://ut.khoavo.myds.me:8981/api' }}

View file

@ -1,42 +1,52 @@
services:
server:
image: codeberg.org/forgejo/forgejo:9
forgejo:
image: codeberg.org/forgejo/forgejo:7.0.16
container_name: forgejo
environment:
- USER_UID=1026
- USER_GID=100
- GITEA__database__DB_TYPE=sqlite3
- TZ=Asia/Ho_Chi_Minh
- GITEA__actions__ENABLED=true
- INSTALL_LOCK=true
- FORGEJO__server__ROOT_URL=http://nas:3050/
restart: always
networks:
- forgejo_custom_net
volumes:
- ./data:/data
- ./forgejo-data:/data
ports:
- "3050:3000"
- "2222:22"
networks:
- kv-tube_default
runner:
image: code.forgejo.org/forgejo/runner:6.0.1
forgejo-runner:
image: code.forgejo.org/forgejo/runner:latest
container_name: forgejo_runner
restart: always
user: "0:0"
privileged: true
depends_on:
- server
networks:
- forgejo_custom_net
- forgejo
volumes:
- /var/run/docker.sock:/var/run/docker.sock
- ./runner-data:/data
entrypoint: >
sh -c "if [ ! -f /data/.runner ]; then forgejo-runner register --no-interactive --instance http://server:3000 --token xP3IdP05YPJJZ504z7UzK90njFFzQnX4d77cJiCN --name synology-runner --labels ubuntu-latest:docker://node:20-bookworm,ubuntu-22.04:docker://node:20-bookworm,docker:host; fi; forgejo-runner daemon"
- ./forgejo-runner-data:/data
entrypoint:
- sh
- -c
- |
if [ ! -f /data/.runner ]; then
forgejo-runner register --no-interactive \
--instance http://forgejo:3000 \
--token d5XKhmpu4lTR7P516juCjEes6QsI4qFvVean3zqT \
--name synology-runner \
--labels ubuntu-latest,ubuntu-22.04,docker:host
fi
forgejo-runner daemon
environment:
- TZ=Asia/Ho_Chi_Minh
networks:
- kv-tube_default
networks:
forgejo_custom_net:
driver: bridge
ipam:
config:
- subnet: 172.38.0.0/24
kv-tube_default:
external: true