Compare commits

..

4 Commits

4 changed files with 65 additions and 11 deletions

View File

@@ -1,5 +1,5 @@
BINARY=ginie BINARY=ginie
VERSION=0.1.4 VERSION=0.1.6
build: build:
go build -o $(BINARY) ./cmd/ginie go build -o $(BINARY) ./cmd/ginie

View File

@@ -95,11 +95,20 @@ func main() {
case "update": case "update":
if len(os.Args) < 3 { if len(os.Args) < 3 {
fmt.Println("Usage: ginie update <name>") fmt.Println("Usage: ginie update <name|--all>")
return return
} }
target := os.Args[2] target := os.Args[2]
if target == "--all" {
err := install.UpdateAll()
if err != nil {
fmt.Println("Fehler:", err)
return
}
return
}
err := install.Update(target) err := install.Update(target)
if err != nil { if err != nil {
fmt.Println("Fehler:", err) fmt.Println("Fehler:", err)

View File

@@ -21,6 +21,11 @@ type Installed struct {
AssetURL string `json:"url"` AssetURL string `json:"url"`
} }
type releaseAsset struct {
Name string `json:"name"`
BrowserDownloadURL string `json:"browser_download_url"`
}
func configPath() (string, error) { func configPath() (string, error) {
home, err := os.UserHomeDir() home, err := os.UserHomeDir()
if err != nil { if err != nil {
@@ -108,11 +113,8 @@ func Install(pkg string) error {
} }
var release struct { var release struct {
TagName string `json:"tag_name"` TagName string `json:"tag_name"`
Assets []struct { Assets []releaseAsset `json:"assets"`
Name string `json:"name"`
BrowserDownloadURL string `json:"browser_download_url"`
} `json:"assets"`
} }
if err := json.NewDecoder(resp.Body).Decode(&release); err != nil { if err := json.NewDecoder(resp.Body).Decode(&release); err != nil {
@@ -128,9 +130,20 @@ func Install(pkg string) error {
installedVersion = version installedVersion = version
} }
var debAssets []releaseAsset
for _, a := range release.Assets {
if strings.HasSuffix(strings.ToLower(a.Name), ".deb") {
debAssets = append(debAssets, a)
}
}
if len(debAssets) == 0 {
return errors.New("Release enthält keine .deb Assets")
}
// Asset-Auswahl // Asset-Auswahl
fmt.Println("Verfügbare Assets:") fmt.Println("Verfügbare Assets:")
for i, a := range release.Assets { for i, a := range debAssets {
fmt.Printf("[%d] %s\n", i, a.Name) fmt.Printf("[%d] %s\n", i, a.Name)
} }
@@ -138,11 +151,11 @@ func Install(pkg string) error {
var choice int var choice int
fmt.Scan(&choice) fmt.Scan(&choice)
if choice < 0 || choice >= len(release.Assets) { if choice < 0 || choice >= len(debAssets) {
return errors.New("Ungültige Auswahl") return errors.New("Ungültige Auswahl")
} }
asset := release.Assets[choice] asset := debAssets[choice]
// Datei herunterladen // Datei herunterladen
fmt.Println("Lade herunter:", asset.Name) fmt.Println("Lade herunter:", asset.Name)
@@ -254,3 +267,35 @@ func Update(pkg string) error {
return Install(fmt.Sprintf("%s:%s", repo.Name, release.TagName)) return Install(fmt.Sprintf("%s:%s", repo.Name, release.TagName))
} }
func UpdateAll() error {
reposList, err := repos.LoadRepos()
if err != nil {
return err
}
var installed []repos.Repo
for _, r := range reposList {
if r.InstalledVersion != "" {
installed = append(installed, r)
}
}
if len(installed) == 0 {
return errors.New("Keine installierten Pakete gefunden. Nutze: ginie install <name>")
}
var failed []string
for _, r := range installed {
fmt.Printf("Prüfe Updates für %s...\n", r.Name)
if err := Update(r.Name); err != nil {
failed = append(failed, fmt.Sprintf("%s: %v", r.Name, err))
}
}
if len(failed) > 0 {
return fmt.Errorf("Einige Updates fehlgeschlagen:\n%s", strings.Join(failed, "\n"))
}
return nil
}

View File

@@ -1,4 +1,4 @@
package version package version
// Wird vom Build-Prozess überschrieben, falls gewünscht // Wird vom Build-Prozess überschrieben, falls gewünscht
var Version = "0.1.4" var Version = "0.1.6"