name: sync-to-gitea on: push: branches: - main jobs: sync: runs-on: ubuntu-latest permissions: contents: write steps: - name: Checkout uses: actions/checkout@v4 with: fetch-depth: 0 - name: Sync to Gitea env: GITEA_TOKEN: ${{ secrets.GITEA_SECRET }} REPO: ${{ github.event.repository.name }} BRANCH: ${{ github.ref_name }} run: | set -euxo pipefail export GIT_TERMINAL_PROMPT=0 export GIT_TRACE=1 export GIT_CURL_VERBOSE=1 USER="Admin" TARGET="https://ci.nxtgauge.com/Admin/${REPO}.git" AUTH="$(printf '%s' "${USER}:${GITEA_TOKEN}" | base64 -w0)" test -n "${GITEA_TOKEN:-}" || (echo "GITEA_TOKEN empty" && exit 1) curl -fsS -H "Authorization: token ${GITEA_TOKEN}" https://ci.nxtgauge.com/api/v1/user >/dev/null curl -fsS -H "Authorization: Basic ${AUTH}" "${TARGET}/info/refs?service=git-receive-pack" >/dev/null git config user.name "github-actions[bot]" git config user.email "github-actions[bot]@users.noreply.github.com" git config --global http.version HTTP/1.1 git config --global http.postBuffer 524288000 git remote remove gitea 2>/dev/null || true git remote add gitea "${TARGET}" git -c http.extraheader="Authorization: Basic ${AUTH}" push gitea "HEAD:${BRANCH}" --force git -c http.extraheader="Authorization: Basic ${AUTH}" push gitea --tags --force