3 Commits

Author SHA1 Message Date
eliaskohout 388e24a8df ci: cross-compile binaries in workflow instead of downloading from APK registry
Build and Publish Arch Package / build-arch (amd64, x86_64) (push) Successful in 58s
Build and Publish Arch Package / build-arch (arm64, aarch64) (push) Failing after 1m2s
Build and Publish Docker Image / build-apk (amd64, x86_64) (push) Successful in 52s
Build and Publish Docker Image / build-apk (arm64, aarch64) (push) Failing after 47s
Build and Publish Docker Image / build-and-push-docker (push) Successful in 10m50s
2026-04-14 11:24:37 +02:00
eliaskohout b5ef107f9c ci: use pre-built APK in Docker image instead of compiling from source
Build and Publish Arch Package / build-arch (amd64, x86_64) (push) Has been cancelled
Build and Publish Arch Package / build-arch (arm64, aarch64) (push) Has been cancelled
Build and Publish Docker Image / build-apk (amd64, x86_64) (push) Successful in 46s
Build and Publish Docker Image / build-apk (arm64, aarch64) (push) Successful in 51s
Build and Publish Docker Image / build-and-push-docker (push) Failing after 11m58s
2026-04-14 00:59:31 +02:00
eliaskohout 21a01e9412 fix: include client_secret in device authorization request
Build and Publish APK Package / build-apk (arm64, aarch64) (push) Failing after 46s
Build and Publish Arch Package / build-arch (arm64, aarch64) (push) Successful in 1m2s
Build and Publish APK Package / build-apk (amd64, x86_64) (push) Waiting to run
Build and Push Docker Container / build-and-push (push) Has been cancelled
Build and Publish Arch Package / build-arch (amd64, x86_64) (push) Has been cancelled
2026-04-14 00:48:16 +02:00
4 changed files with 87 additions and 90 deletions
-68
View File
@@ -1,68 +0,0 @@
name: Build and Publish APK Package
on:
push:
tags:
- 'v*'
jobs:
build-apk:
runs-on:
- ubuntu-24.04
container:
image: alpine:latest
strategy:
matrix:
include:
- goarch: amd64
pkgarch: x86_64
- goarch: arm64
pkgarch: aarch64
steps:
- name: Install build dependencies
run: |
apk update
apk add --no-cache git nodejs go abuild curl sudo build-base
- name: Checkout repository
uses: actions/checkout@v4
- name: Create build user
run: |
adduser -D -G abuild build
echo "build ALL=(ALL) NOPASSWD:ALL" >> /etc/sudoers
chown -R build:abuild .
- name: Configure git safe directory
run: git config --global --add safe.directory "$PWD"
- name: Setup abuild for package signing
run: |
su build -c "abuild-keygen -a -n"
cp /home/build/.abuild/*.pub /etc/apk/keys/
- name: Prepare source
run: |
pkgver=$(echo "${{ github.ref_name }}" | sed 's/^v//')
pkgname="axolotl"
sed -i "s/pkgver=.*/pkgver=$pkgver/" packaging/alpine/APKBUILD
sed -i "s/^arch=.*/arch=\"${{ matrix.pkgarch }}\"/" packaging/alpine/APKBUILD
git archive --format=tar.gz --prefix="$pkgname-$pkgver/" -o "packaging/alpine/$pkgname-$pkgver.tar.gz" HEAD
sed -i "s|source=.*|source=\"\$pkgname-\$pkgver.tar.gz\"|" packaging/alpine/APKBUILD
chown -R build:abuild .
- name: Generate checksums
run: su build -c "cd $PWD/packaging/alpine && abuild checksum"
- name: Build package
run: su build -c "cd $PWD/packaging/alpine && GOARCH=${{ matrix.goarch }} CARCH=${{ matrix.pkgarch }} abuild -r"
- name: Publish to Gitea Registry
run: |
apk_file=$(find ~build/packages -name "*.apk" -type f | head -1)
curl --fail-with-body \
--user "${{ github.repository_owner }}:${{ secrets.ACCESS_TOKEN }}" \
--upload-file "$apk_file" \
"${{ github.server_url }}/api/packages/${{ github.repository_owner }}/alpine/edge/main"
+80 -3
View File
@@ -1,15 +1,91 @@
name: Build and Push Docker Container
name: Build and Publish Docker Image
on:
push:
tags:
- 'v*'
jobs:
build-and-push:
build-apk:
runs-on:
- ubuntu-24.04
container:
image: alpine:latest
strategy:
matrix:
include:
- goarch: amd64
pkgarch: x86_64
- goarch: arm64
pkgarch: aarch64
steps:
- name: Install build dependencies
run: |
apk update
apk add --no-cache git nodejs go abuild curl sudo build-base
- name: Checkout repository
uses: actions/checkout@v4
- name: Create build user
run: |
adduser -D -G abuild build
echo "build ALL=(ALL) NOPASSWD:ALL" >> /etc/sudoers
chown -R build:abuild .
- name: Configure git safe directory
run: git config --global --add safe.directory "$PWD"
- name: Setup abuild for package signing
run: |
su build -c "abuild-keygen -a -n"
cp /home/build/.abuild/*.pub /etc/apk/keys/
- name: Prepare source
run: |
pkgver=$(echo "${{ github.ref_name }}" | sed 's/^v//')
pkgname="axolotl"
sed -i "s/pkgver=.*/pkgver=$pkgver/" packaging/alpine/APKBUILD
sed -i "s/^arch=.*/arch=\"${{ matrix.pkgarch }}\"/" packaging/alpine/APKBUILD
git archive --format=tar.gz --prefix="$pkgname-$pkgver/" -o "packaging/alpine/$pkgname-$pkgver.tar.gz" HEAD
sed -i "s|source=.*|source=\"\$pkgname-\$pkgver.tar.gz\"|" packaging/alpine/APKBUILD
chown -R build:abuild .
- name: Generate checksums
run: su build -c "cd $PWD/packaging/alpine && abuild checksum"
- name: Build package
run: su build -c "cd $PWD/packaging/alpine && GOARCH=${{ matrix.goarch }} CARCH=${{ matrix.pkgarch }} abuild -r"
- name: Publish to Gitea Registry
run: |
apk_file=$(find ~build/packages -name "*.apk" -type f | head -1)
curl --fail-with-body \
--user "${{ github.repository_owner }}:${{ secrets.ACCESS_TOKEN }}" \
--upload-file "$apk_file" \
"${{ github.server_url }}/api/packages/${{ github.repository_owner }}/alpine/edge/main"
build-and-push-docker:
runs-on:
- ubuntu-24.04
steps:
- name: Login to Docker Hub
- name: Checkout repository
uses: actions/checkout@v4
- name: Set up Go
uses: actions/setup-go@v5
with:
go-version-file: src/go.mod
- name: Cross-compile binaries
run: |
cd src
CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -ldflags="-s -w" -trimpath -o ../out/amd64/ax .
CGO_ENABLED=0 GOOS=linux GOARCH=arm64 go build -ldflags="-s -w" -trimpath -o ../out/arm64/ax .
- name: Login to Docker Registry
uses: docker/login-action@v3
with:
registry: g.eliaskohout.de
@@ -25,6 +101,7 @@ jobs:
- name: Build and push
uses: docker/build-push-action@v6
with:
context: .
push: true
platforms: linux/amd64,linux/arm64
tags: "g.eliaskohout.de/eliaskohout/axolotl-server:${{gitea.ref_name}},g.eliaskohout.de/eliaskohout/axolotl-server:latest"
+4 -18
View File
@@ -1,25 +1,11 @@
FROM golang:1.25-alpine AS builder
WORKDIR /app
ENV GOTOOLCHAIN=local
COPY src/go.mod src/go.sum ./
RUN go mod download
COPY src/ ./
RUN CGO_ENABLED=0 GOOS=$TARGETOS GOARCH=$TARGETARCH \
go build -ldflags="-s -w" -trimpath -o /ax .
FROM alpine:latest
ARG TARGETARCH
RUN apk --no-cache add ca-certificates
COPY out/${TARGETARCH}/ax /usr/local/bin/ax
WORKDIR /data
COPY --from=builder /ax /usr/local/bin/ax
EXPOSE 7000
ENTRYPOINT ["ax", "serve"]
+3 -1
View File
@@ -173,7 +173,9 @@ func (h *authHandler) deviceStart(w http.ResponseWriter, r *http.Request) {
return
}
da, err := h.oauth2.DeviceAuth(r.Context())
da, err := h.oauth2.DeviceAuth(r.Context(),
oauth2.SetAuthURLParam("client_secret", h.cfg.ClientSecret),
)
if err != nil {
writeError(w, http.StatusBadGateway, "device authorization request failed: "+err.Error())
return