Skip to content

Commit

Permalink
build(release): publish the archives so they can be downloaded
Browse files Browse the repository at this point in the history
  • Loading branch information
aybabtme committed Oct 19, 2024
1 parent d6ad70f commit ca7d868
Show file tree
Hide file tree
Showing 7 changed files with 62 additions and 14 deletions.
7 changes: 4 additions & 3 deletions .github/workflows/release-dev.yml
Original file line number Diff line number Diff line change
Expand Up @@ -22,18 +22,19 @@ jobs:
with:
go-version: ">=1.23"
cache: true
- run: echo "${HOME}/.humanlog/bin" >> $GITHUB_PATH
- run: curl https://humanlog.dev/install_apictl.sh | bash
- uses: goreleaser/goreleaser-action@v6
with:
distribution: goreleaser
version: latest
args: release --clean --draft --snapshot --config .goreleaser-dev.yaml
args: release --clean --draft --skip validate --config .goreleaser-dev.yaml
env:
GITHUB_TOKEN: ${{ secrets.GORELEASER_GITHUB_TOKEN }}
- run: echo "${HOME}/.humanlog/bin" >> $GITHUB_PATH
- run: curl https://humanlog.dev/install_apictl.sh | bash
- run: ./script/create_version_artifacts.sh
env:
CHANNEL: "dev"
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
API_URL: "https://api.humanlog.dev"
HMAC_KEY_ID: ${{ secrets.DEV_HMAC_KEY_ID }}
HMAC_PRIVATE_KEY: ${{ secrets.DEV_HMAC_PRIVATE_KEY }}
2 changes: 2 additions & 0 deletions .github/workflows/release.yml
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
name: Create a release

on:
workflow_dispatch:
push:
tags:
- "*"
Expand Down Expand Up @@ -34,5 +35,6 @@ jobs:
env:
CHANNEL: "main"
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
API_URL: "https://api.humanlog.io"
HMAC_KEY_ID: ${{ secrets.PROD_HMAC_KEY_ID }}
HMAC_PRIVATE_KEY: ${{ secrets.PROD_HMAC_PRIVATE_KEY }}
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -2,3 +2,4 @@
dist
debug.log
logdump.json
dist-extra
16 changes: 13 additions & 3 deletions .goreleaser-dev.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -4,13 +4,15 @@ before:
hooks:
- go mod tidy
- go generate ./...
- mkdir -p dist-extra
- script/write_version_info.sh "{{.Major}}" "{{.Minor}}" "{{.Patch}}" "next.{{ .Timestamp }}" "{{.ShortCommit}}"
builds:
- main: ./cmd/humanlog/
binary: humanlog
env:
- CGO_ENABLED=0
ldflags:
- -s -w -X main.versionMajor={{.Major}} -X main.versionMinor={{.Minor}} -X main.versionPatch={{.Patch}} -X main.versionPrerelease={{.Prerelease}} -X main.versionBuild={{.ShortCommit}} -X main.defaultApiAddr="https://api.humanlog.dev"
- -s -w -X main.versionMajor={{.Major}} -X main.versionMinor={{.Minor}} -X main.versionPatch={{.Patch}} -X main.versionPrerelease=next.{{ .Timestamp }} -X main.versionBuild={{.ShortCommit}} -X main.defaultApiAddr="https://api.humanlog.dev"
goos:
# - windows
- darwin
Expand All @@ -24,15 +26,23 @@ release:
name: humanlog
target_commitish: "{{ .Commit }}"
prerelease: true
draft: true
replace_existing_draft: true
replace_existing_artifacts: true
name_template: "{{ incpatch .Version }}-next.{{ .Timestamp }}+{{ .ShortCommit }}"
header: |
## very unstable dev build of humanlog ({{ .Date }})
Do not use. For folks iterating on humanlog and wanting to test their work.
archives:
- name_template: "{{ .ProjectName }}_{{ .Version }}_{{ .Os }}_{{ .Arch }}"
- name_template: "{{ .ProjectName }}_{{ incpatch .Version }}-next.{{ .Timestamp }}+{{ .ShortCommit }}_{{ .Os }}_{{ .Arch }}"
format_overrides:
- goos: windows
format: zip
checksum:
name_template: "checksums.txt"
snapshot:
version_template: "{{ incpatch .Version }}-next.{{ .Timestamp }}.{{ .ShortCommit }}"
version_template: "{{ incpatch .Version }}-next.{{ .Timestamp }}+{{ .ShortCommit }}"
changelog:
sort: asc
filters:
Expand Down
6 changes: 5 additions & 1 deletion cmd/humanlog/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,11 @@ var (
version = func() *types.Version {
var prerelease []string
if versionPrerelease != "" {
prerelease = append(prerelease, versionPrerelease)
for _, pre := range strings.Split(versionPrerelease, ".") {
if pre != "" {
prerelease = append(prerelease, pre)
}
}
}
return &types.Version{
Major: int32(mustatoi(versionMajor)),
Expand Down
27 changes: 20 additions & 7 deletions script/create_version_artifacts.sh
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
#!/usr/bin/env bash

set -euo pipefail
set -euox pipefail

root=$(git rev-parse --show-toplevel)

Expand All @@ -12,14 +12,17 @@ function handle_archive() {
while read -r filename; read -r path; read -r goos; read -r goarch; do
local url=$(get_archive_url ${filename})
if [ -z "${url}" ]; then echo "no archive for ${filename}"; continue; fi
local sig=$(get_signature ${path})

apictl create version-artifact \
local sig=$(get_signature ${root}/${path})

apictl --api.url ${api_url} create version-artifact \
--project ${project} \
--major $(get_version_major) \
--minor $(get_version_minor) \
--patch $(get_version_patch) \
--sha256 $(get_sha256sum ${path}) \
--pre $(get_prerelease) \
--build $(get_build) \
--url ${url} \
--os ${goos} \
--arch ${goarch} \
Expand Down Expand Up @@ -49,8 +52,9 @@ function get_sha256sum() {
}

function get_signature() {
local filename=${1}
cat ${filename}.sig
local filename=${1}.sig
if [ -f "${filename}" ]; then cat < ${filename};
else echo "no-signature"; fi
}

function get_version_major() {
Expand All @@ -69,27 +73,36 @@ function get_version_patch() {
}

function get_version() {
jq < dist/metadata.json -r '.version'
jq < dist-extra/version.json -r '.version'
}

function get_project_name() {
jq < dist/metadata.json -r '.project_name'
}

function get_prerelease() {
jq < dist-extra/version.json -r '.pre'
}

function get_build() {
jq < dist-extra/version.json -r '.build'
}

function get_channel() {
local channel=${CHANNEL:-main}
echo ${channel}
}

function main() {
owner=humanlogio
api_url=${API_URL:-"https://api.humanlog.io"}
project=$(get_project_name)
tag=$(get_version)
channel=$(get_channel)

list_archives | handle_archive

apictl create published-version \
apictl --api.url ${api_url} create published-version \
--project ${project} \
--channel ${channel} \
--version $(get_version)
Expand Down
17 changes: 17 additions & 0 deletions script/write_version_info.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
#!/usr/bin/env bash

set -euox pipefail

root=$(git rev-parse --show-toplevel)

function main() {
major=${1}
minor=${2}
patch=${3}
pre=${4}
build=${5}
mkdir -p ${root}/dist-extra
echo > ${root}/dist-extra/version.json "{\"version\":\"${major}.${minor}.${patch}-${pre}+${build}\",\"major\": \"${major}\",\"minor\": \"${minor}\",\"patch\": \"${patch}\",\"pre\": \"${pre}\",\"build\": \"${build}\"}"
}

main ${1} ${2} ${3} ${4} ${5}

0 comments on commit ca7d868

Please sign in to comment.