chore(ci): remove Gitea workflow and docs

This commit is contained in:
Logic
2026-03-23 10:55:31 +08:00
parent 087a093051
commit 06c516aa1c
2 changed files with 0 additions and 127 deletions

View File

@@ -1,93 +0,0 @@
name: docker-cicd
on:
push:
branches:
- main
- master
jobs:
build-and-push:
runs-on: linux_amd64
env:
GITEA_SERVER_URL: ${{ gitea.server_url }}
GITEA_REPOSITORY: ${{ gitea.repository }}
GITEA_REF_NAME: ${{ gitea.ref_name }}
GITEA_SHA: ${{ gitea.sha }}
DEFAULT_BRANCH: ${{ vars.DEFAULT_BRANCH }}
IMAGE_NAME_OVERRIDE: ${{ vars.IMAGE_NAME }}
PACKAGE_USER: ${{ vars.PACKAGE_USER }}
DOCKER_TOKEN: ${{ secrets.DOCKER_TOKEN }}
steps:
- name: Validate required tools and secrets
run: |
set -eu
command -v git >/dev/null 2>&1 || { echo "git 未安装"; exit 1; }
command -v docker >/dev/null 2>&1 || { echo "docker 未安装"; exit 1; }
command -v curl >/dev/null 2>&1 || { echo "curl 未安装"; exit 1; }
[ -n "${DOCKER_TOKEN}" ] || { echo "缺少 secrets.DOCKER_TOKEN"; exit 1; }
- name: Clone current repository
run: |
set -eu
SERVER_HOST="$(printf '%s' "${GITEA_SERVER_URL}" | sed -E 's#^[a-zA-Z]+://##; s#/.*$##')"
OWNER="${GITEA_REPOSITORY%%/*}"
LOGIN_USER="${PACKAGE_USER:-$OWNER}"
WORKDIR="/tmp/${GITEA_REPOSITORY##*/}-${GITEA_SHA}"
rm -rf "${WORKDIR}"
git clone --depth=1 "https://${LOGIN_USER}:${DOCKER_TOKEN}@${SERVER_HOST}/${GITEA_REPOSITORY}.git" "${WORKDIR}"
cd "${WORKDIR}"
git fetch --depth=1 origin "${GITEA_SHA}" || true
git checkout "${GITEA_SHA}" || true
echo "WORKDIR=${WORKDIR}" >> "${GITHUB_ENV}"
echo "SERVER_HOST=${SERVER_HOST}" >> "${GITHUB_ENV}"
echo "LOGIN_USER=${LOGIN_USER}" >> "${GITHUB_ENV}"
- name: Build and push Docker image
run: |
set -eu
cd "${WORKDIR}"
OWNER="${GITEA_REPOSITORY%%/*}"
OWNER_IMAGE="$(printf '%s' "${OWNER}" | tr '[:upper:]' '[:lower:]')"
REPO_NAME="${GITEA_REPOSITORY##*/}"
IMAGE_NAME="$(printf '%s' "${IMAGE_NAME_OVERRIDE:-$REPO_NAME}" | tr '[:upper:]' '[:lower:]')"
IMAGE_REF="${SERVER_HOST}/${OWNER_IMAGE}/${IMAGE_NAME}"
SHORT_SHA="$(printf '%s' "${GITEA_SHA}" | cut -c1-12)"
REF_SLUG="$(printf '%s' "${GITEA_REF_NAME}" | tr '/:@ ' '----')"
DEFAULT_BRANCH_NAME="${DEFAULT_BRANCH:-main}"
echo "${DOCKER_TOKEN}" | docker login "${SERVER_HOST}" --username "${LOGIN_USER}" --password-stdin
docker build -t "${IMAGE_REF}:sha-${SHORT_SHA}" .
docker tag "${IMAGE_REF}:sha-${SHORT_SHA}" "${IMAGE_REF}:branch-${REF_SLUG}"
docker push "${IMAGE_REF}:sha-${SHORT_SHA}"
docker push "${IMAGE_REF}:branch-${REF_SLUG}"
if [ "${GITEA_REF_NAME}" = "${DEFAULT_BRANCH_NAME}" ]; then
docker tag "${IMAGE_REF}:sha-${SHORT_SHA}" "${IMAGE_REF}:latest"
docker push "${IMAGE_REF}:latest"
fi
echo "OWNER=${OWNER}" >> "${GITHUB_ENV}"
echo "REPO_NAME=${REPO_NAME}" >> "${GITHUB_ENV}"
echo "IMAGE_NAME=${IMAGE_NAME}" >> "${GITHUB_ENV}"
echo "IMAGE_REF=${IMAGE_REF}" >> "${GITHUB_ENV}"
- name: Link package to current repository
run: |
set -eu
API_URL="${GITEA_SERVER_URL%/}/api/v1/packages/${OWNER}/container/${IMAGE_NAME}/-/link/${REPO_NAME}"
HTTP_CODE="$(curl -sS -o /tmp/package-link.out -w '%{http_code}' \
-X POST \
-H "Authorization: token ${DOCKER_TOKEN}" \
"${API_URL}")"
if [ "${HTTP_CODE}" = "201" ] || [ "${HTTP_CODE}" = "204" ] || [ "${HTTP_CODE}" = "409" ]; then
echo "package link result: ${HTTP_CODE}"
cat /tmp/package-link.out || true
exit 0
fi
echo "package link failed: ${HTTP_CODE}"
cat /tmp/package-link.out || true
exit 1

View File

@@ -41,37 +41,3 @@ Notes:
- The script looks for JS dependencies relative to itself under ./js/
- It reproduces the mini-program's getCommand(qr) wrapping and uses the bundled QR JS renderer
- Default timezone for QR payload generation is Asia/Shanghai; you can override it with MINIAPP_QR_TIMEZONE
Gitea CI/CD template:
1) Add `.gitea/workflows/docker-cicd.yaml` to your repository.
2) Repository Actions must be enabled:
- Repository Settings -> Enable Repository Actions
3) Your runner should have a label like:
linux_amd64
4) The runner host needs these commands installed:
- git
- docker
- curl
5) Required repository variables/secrets:
Variables:
- PACKAGE_USER -> optional; defaults to current repo owner. If your repo is under an organization, or the token belongs to another user/bot, set this explicitly to the token owner username.
- DEFAULT_BRANCH -> optional, defaults to main
- IMAGE_NAME -> optional, defaults to current repo name
Secret:
- DOCKER_TOKEN -> personal access token with at least repository read + package read/write permissions
6) What the workflow does:
- clones the current repo from Gitea
- builds the Docker image
- pushes it to the current Gitea instance package registry
- links the pushed container package back to the current repository
7) Registry image naming:
{gitea-domain}/{owner}/{image}
Example:
gitea.example.com/myteam/miniapp_qr_portable_bundle:latest