Compare commits
7 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| dcefb2502f | |||
| afbd69d695 | |||
| 0e66267d39 | |||
| 7a88b0c407 | |||
| ac786f6eab | |||
| d65f53d00f | |||
| 2e34c48354 |
@@ -122,3 +122,91 @@ jobs:
|
||||
files: |
|
||||
dist/**/status-dashboard-*.tar.gz
|
||||
dist/**/status-dashboard-*.zip
|
||||
publish-agent:
|
||||
if: startsWith(github.ref, 'refs/tags/')
|
||||
needs: release
|
||||
runs-on: ubuntu-fast
|
||||
env:
|
||||
PRODUCT: status-dashboard
|
||||
AGENT_URL: ${{ secrets.AGENT_URL }}
|
||||
AGENT_TOKEN: ${{ secrets.AGENT_TOKEN }}
|
||||
|
||||
# Funktioniert in GitHub und Gitea (Actions) weitgehend gleich:
|
||||
SERVER_URL: ${{ github.server_url }} # z.B. https://github.com oder https://gitea.example.com
|
||||
REPOSITORY: ${{ github.repository }} # owner/repo
|
||||
TAG: ${{ github.ref_name }} # vX.Y.Z
|
||||
|
||||
steps:
|
||||
- name: Download artifacts
|
||||
uses: actions/download-artifact@v3
|
||||
with:
|
||||
path: ./dist
|
||||
|
||||
- name: Publish release metadata to Version Agent
|
||||
shell: bash
|
||||
run: |
|
||||
set -euo pipefail
|
||||
|
||||
if [[ -z "${AGENT_URL:-}" || -z "${AGENT_TOKEN:-}" ]]; then
|
||||
echo "Missing AGENT_URL or AGENT_TOKEN" >&2; exit 1
|
||||
fi
|
||||
|
||||
VERSION="${TAG#v}" # 12.3.1[-rc.1|-beta.1]
|
||||
MAJOR="${VERSION%%.*}" # 12
|
||||
BRANCH="${MAJOR}.x" # 12.x
|
||||
|
||||
CHANNEL="stable"
|
||||
[[ "$VERSION" == *"-rc"* ]] && CHANNEL="rc"
|
||||
[[ "$VERSION" == *"-beta"* ]] && CHANNEL="beta"
|
||||
# Optional: Nightly-Channel bei Non-Tag-Builds (separater Job, siehe unten)
|
||||
|
||||
RELEASED_AT="$(date -u +"%Y-%m-%dT%H:%M:%SZ")"
|
||||
NOTES_URL="${SERVER_URL}/${REPOSITORY}/releases/tag/${TAG}"
|
||||
|
||||
publish() { # args: OS ARCH FILE
|
||||
local OS="$1" ARCH="$2" FILE="$3"
|
||||
local BIT="64"
|
||||
case "$ARCH" in 386|armv7) BIT="32";; esac
|
||||
|
||||
local FNAME="$(basename "$FILE")"
|
||||
local URL="${SERVER_URL}/${REPOSITORY}/releases/download/${TAG}/${FNAME}"
|
||||
|
||||
local SHA256 SIZE
|
||||
SHA256="$(sha256sum "$FILE" | awk '{print $1}')"
|
||||
SIZE="$(stat -c%s "$FILE")"
|
||||
|
||||
jq -n \
|
||||
--arg branch "$BRANCH" \
|
||||
--arg channel "$CHANNEL" \
|
||||
--arg arch "$ARCH" \
|
||||
--arg bit "$BIT" \
|
||||
--arg os "$OS" \
|
||||
--arg version "$VERSION" \
|
||||
--arg released_at "$RELEASED_AT" \
|
||||
--arg notes "$NOTES_URL" \
|
||||
--arg url "$URL" \
|
||||
--arg sha256 "$SHA256" \
|
||||
--argjson size "$SIZE" \
|
||||
'{
|
||||
branch:$branch, channel:$channel, arch:$arch, bit:$bit, os:$os,
|
||||
release:{
|
||||
version:$version, released_at:$released_at, notes_url:$notes,
|
||||
assets:[{url:$url, sha256:$sha256, size_bytes:$size}]
|
||||
}
|
||||
}' > payload.json
|
||||
echo @payload.json
|
||||
curl -fsS -H "Content-Type: application/json" \
|
||||
-H "Authorization: Bearer ${AGENT_TOKEN}" \
|
||||
-d @payload.json "${AGENT_URL}/v1/publish"
|
||||
}
|
||||
|
||||
shopt -s nullglob
|
||||
|
||||
# linux/amd64
|
||||
for f in dist/**/${PRODUCT}-linux-amd64.tar.gz; do publish linux amd64 "$f"; done
|
||||
# linux/arm64
|
||||
for f in dist/**/${PRODUCT}-linux-arm64.tar.gz; do publish linux arm64 "$f"; done
|
||||
# linux/armv7
|
||||
for f in dist/**/${PRODUCT}-linux-armv7.tar.gz; do publish linux armv7 "$f"; done
|
||||
# windows/amd64
|
||||
for f in dist/**/${PRODUCT}-windows-amd64.zip; do publish windows amd64 "$f"; done
|
||||
@@ -1,4 +1,4 @@
|
||||
FROM golang:1.24.4
|
||||
FROM golang:1.25
|
||||
WORKDIR /app
|
||||
COPY go.mod ./
|
||||
RUN go mod download
|
||||
@@ -6,6 +6,7 @@ COPY *.go ./
|
||||
RUN CGO_ENABLED=0 GOOS=linux go build -o /goprg
|
||||
RUN mkdir /data
|
||||
COPY services.json /data/services.json
|
||||
##COPY services.json /services.json
|
||||
VOLUME ["/data"]
|
||||
EXPOSE 8080
|
||||
CMD ["/goprg"]
|
||||
15
main.go
15
main.go
@@ -190,7 +190,7 @@ func envOr(k, def string) string {
|
||||
|
||||
func main() {
|
||||
addr := envOr("addr", ":8080")
|
||||
cfgPath := envOr("config", "/data/services.json")
|
||||
cfgPath := envOr("config", "./services.json")
|
||||
|
||||
state := newState()
|
||||
|
||||
@@ -318,16 +318,11 @@ func writeJSON(w http.ResponseWriter, v any) {
|
||||
_ = enc.Encode(v)
|
||||
}
|
||||
|
||||
func readConfig(path string) (*Config, error) {
|
||||
func readConfig(p string) (*Config, error) {
|
||||
b, err := os.ReadFile(p)
|
||||
if err != nil { return nil, err }
|
||||
var cfg Config
|
||||
f, err := http.Dir(".").Open(path) // schlichtes Lesen aus CWD
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
defer f.Close()
|
||||
if err := json.NewDecoder(f).Decode(&cfg); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
if err := json.Unmarshal(b, &cfg); err != nil { return nil, err }
|
||||
return &cfg, nil
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user