Borg/examples/collect_github_release/main.go
Claude fe0f85a069
Some checks failed
Go / build (push) Failing after 3s
mkdocs / deploy (push) Failing after 10s
Release / release (push) Failing after 4s
chore: migrate module path from github.com to forge.lthn.ai
Move module declaration and all internal imports from
github.com/Snider/Borg to forge.lthn.ai/Snider/Borg. Also updates
Enchantrix dependency path to forge.lthn.ai/Snider/Enchantrix.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-02-22 21:39:18 +00:00

42 lines
925 B
Go

package main
import (
"log"
"os"
"forge.lthn.ai/Snider/Borg/pkg/github"
)
func main() {
log.Println("Collecting GitHub release...")
owner, repo, err := github.ParseRepoFromURL("https://forge.lthn.ai/Snider/Borg")
if err != nil {
log.Fatalf("Failed to parse repo from URL: %v", err)
}
release, err := github.GetLatestRelease(owner, repo)
if err != nil {
log.Fatalf("Failed to get latest release: %v", err)
}
if len(release.Assets) == 0 {
log.Println("No assets found in the latest release.")
return
}
asset := release.Assets[0]
log.Printf("Downloading asset: %s", asset.GetName())
data, err := github.DownloadReleaseAsset(asset)
if err != nil {
log.Fatalf("Failed to download asset: %v", err)
}
err = os.WriteFile(asset.GetName(), data, 0644)
if err != nil {
log.Fatalf("Failed to write asset to file: %v", err)
}
log.Printf("Successfully downloaded asset to %s", asset.GetName())
}