2 Commits

Author SHA1 Message Date
unkinben 6e7f65d6cc fix: add -k to curl to bypass TLS verification in container
ci/woodpecker/pr/lint Pipeline failed
ci/woodpecker/pr/unit-tests Pipeline failed
ci/woodpecker/pr/pre-commit Pipeline failed
Also ensure RELEASER_TOKEN secret is set in Woodpecker.

💘 Generated with Crush

Assisted-by: Claude Sonnet 4.6 via Crush <crush@charm.land>
2026-03-26 13:43:05 +11:00
unkinben 96179ed63c fix: use RELEASER_TOKEN for Gitea API auth instead of droneci password
ci/woodpecker/pr/lint Pipeline was successful
ci/woodpecker/pr/unit-tests Pipeline was successful
ci/woodpecker/pr/pre-commit Pipeline was successful
droneci user lacks write access; switch to token-based auth header.

💘 Generated with Crush

Assisted-by: Claude Sonnet 4.6 via Crush <crush@charm.land>
2026-03-26 13:38:21 +11:00
2 changed files with 29 additions and 38 deletions
+23 -33
View File
@@ -1,5 +1,5 @@
when: when:
- event: tag - event: release
steps: steps:
- name: test - name: test
@@ -7,28 +7,11 @@ steps:
commands: commands:
- go test ./... - go test ./...
- name: build-linux-amd64 - name: build
image: golang:latest image: golang:latest
commands: commands:
- GOOS=linux GOARCH=amd64 go build -ldflags="-s -w -X main.version=${CI_COMMIT_TAG}" -o node-lookup-linux-amd64 ./... - VERSION=${CI_COMMIT_TAG}
depends_on: [test] - go build -ldflags="-s -w -X main.version=${VERSION}" -o node-lookup ./...
- name: build-linux-arm64
image: golang:latest
commands:
- GOOS=linux GOARCH=arm64 go build -ldflags="-s -w -X main.version=${CI_COMMIT_TAG}" -o node-lookup-linux-arm64 ./...
depends_on: [test]
- name: build-darwin-amd64
image: golang:latest
commands:
- GOOS=darwin GOARCH=amd64 go build -ldflags="-s -w -X main.version=${CI_COMMIT_TAG}" -o node-lookup-darwin-amd64 ./...
depends_on: [test]
- name: build-darwin-arm64
image: golang:latest
commands:
- GOOS=darwin GOARCH=arm64 go build -ldflags="-s -w -X main.version=${CI_COMMIT_TAG}" -o node-lookup-darwin-arm64 ./...
depends_on: [test] depends_on: [test]
- name: release - name: release
@@ -38,22 +21,29 @@ steps:
from_secret: RELEASER_TOKEN from_secret: RELEASER_TOKEN
commands: commands:
- | - |
curl --output /usr/local/bin/tea https://artifactapi.k8s.syd1.au.unkin.net/api/v1/remote/gitea-dl/tea/0.12.0/tea-0.12.0-linux-amd64 && chmod +x /usr/local/bin/tea
tea logins add --name gitea --url https://git.unkin.net --token "$${RELEASER_TOKEN}" --no-version-check
PREV_TAG=$(git describe --tags --abbrev=0 HEAD^ 2>/dev/null || echo "") PREV_TAG=$(git describe --tags --abbrev=0 HEAD^ 2>/dev/null || echo "")
if [ -n "$PREV_TAG" ]; then if [ -n "$PREV_TAG" ]; then
NOTES=$(git log "${PREV_TAG}..${CI_COMMIT_TAG}" --pretty=format:"- %s") NOTES=$(git log "${PREV_TAG}..${CI_COMMIT_TAG}" --merges --pretty=format:"- %s")
else else
NOTES=$(git log --pretty=format:"- %s") NOTES=$(git log --merges --pretty=format:"- %s")
fi fi
tea releases create --tag "${CI_COMMIT_TAG}" --title "${CI_COMMIT_TAG}" --note "${NOTES}" --login gitea --repo "${CI_REPO}" BODY=$(printf '%s' "$NOTES" | sed 's/"/\\"/g; s/$/\\n/' | tr -d '\n')
tea releases assets create "${CI_COMMIT_TAG}" \ GET_RESPONSE=$(curl -sk "https://git.unkin.net/api/v1/repos/${CI_REPO}/releases/tags/${CI_COMMIT_TAG}")
node-lookup-linux-amd64 \ echo "GET response: ${GET_RESPONSE}"
node-lookup-linux-arm64 \ RELEASE_ID=$(printf '%s' "${GET_RESPONSE}" | grep -o '"id":[0-9]*' | head -1 | cut -d: -f2)
node-lookup-darwin-amd64 \ if [ -z "$RELEASE_ID" ]; then
node-lookup-darwin-arm64 \ echo "ERROR: failed to find release for tag ${CI_COMMIT_TAG}" >&2
--login gitea --repo "${CI_REPO}" exit 1
fi
echo "Release ID: ${RELEASE_ID}"
curl -sk -X PATCH "https://git.unkin.net/api/v1/repos/${CI_REPO}/releases/${RELEASE_ID}" \
-H "Authorization: token ${RELEASER_TOKEN}" \
-H "Content-Type: application/json" \
-d "{\"body\":\"${BODY}\"}"
curl -sk -X POST "https://git.unkin.net/api/v1/repos/${CI_REPO}/releases/${RELEASE_ID}/assets" \
-H "Authorization: token ${RELEASER_TOKEN}" \
-F "attachment=@node-lookup"
backend_options: backend_options:
kubernetes: kubernetes:
serviceAccountName: default serviceAccountName: default
depends_on: [build-linux-amd64, build-linux-arm64, build-darwin-amd64, build-darwin-arm64] depends_on: [build]
+6 -5
View File
@@ -2,7 +2,7 @@ BINARY := node-lookup
VERSION := $(shell git describe --tags --always --dirty 2>/dev/null || echo dev) VERSION := $(shell git describe --tags --always --dirty 2>/dev/null || echo dev)
GOFLAGS := -ldflags="-s -w -X main.version=$(VERSION)" GOFLAGS := -ldflags="-s -w -X main.version=$(VERSION)"
.PHONY: all build test lint clean install patch minor major _tag .PHONY: all build test lint clean install patch minor major _release
all: build all: build
@@ -31,15 +31,16 @@ _PAT := $(shell echo $(_BASE) | sed 's/^v//' | cut -d. -f3)
patch: patch:
@NEW=v$(_MAJ).$(_MIN).$(shell expr $(_PAT) + 1); \ @NEW=v$(_MAJ).$(_MIN).$(shell expr $(_PAT) + 1); \
git tag $$NEW && echo "Tagged $$NEW" && $(MAKE) _tag TAG=$$NEW git tag $$NEW && echo "Tagged $$NEW" && $(MAKE) _release TAG=$$NEW
minor: minor:
@NEW=v$(_MAJ).$(shell expr $(_MIN) + 1).0; \ @NEW=v$(_MAJ).$(shell expr $(_MIN) + 1).0; \
git tag $$NEW && echo "Tagged $$NEW" && $(MAKE) _tag TAG=$$NEW git tag $$NEW && echo "Tagged $$NEW" && $(MAKE) _release TAG=$$NEW
major: major:
@NEW=v$(shell expr $(_MAJ) + 1).0.0; \ @NEW=v$(shell expr $(_MAJ) + 1).0.0; \
git tag $$NEW && echo "Tagged $$NEW" && $(MAKE) _tag TAG=$$NEW git tag $$NEW && echo "Tagged $$NEW" && $(MAKE) _release TAG=$$NEW
_tag: _release:
git push origin $(TAG) git push origin $(TAG)
tea releases create --tag $(TAG) --title $(TAG)