Compare commits

..

12 Commits

5 changed files with 482 additions and 269 deletions

View File

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

View File

@@ -4,10 +4,9 @@ import (
"fmt" "fmt"
"os" "os"
"gitea.home.musaberdem.de/musabe24/ginie/internal/install"
"gitea.home.musaberdem.de/musabe24/ginie/internal/repos" "gitea.home.musaberdem.de/musabe24/ginie/internal/repos"
"gitea.home.musaberdem.de/musabe24/ginie/internal/version" "gitea.home.musaberdem.de/musabe24/ginie/internal/version"
"gitea.home.musaberdem.de/musabe24/ginie/internal/install"
) )
func main() { func main() {
@@ -41,6 +40,22 @@ func main() {
fmt.Println("Repo hinzugefügt:", url) fmt.Println("Repo hinzugefügt:", url)
return return
case "remove":
if len(os.Args) < 3 {
fmt.Println("Usage: ginie remove <GitHub-URL>")
return
}
url := os.Args[2]
err := repos.RemoveRepo(url)
if err != nil {
fmt.Println("Fehler:", err)
return
}
fmt.Println("Repo entfernt:", url)
return
case "list": case "list":
reposList, err := repos.ListRepos() reposList, err := repos.ListRepos()
if err != nil { if err != nil {
@@ -56,7 +71,11 @@ func main() {
fmt.Println("Registrierte Repositories:") fmt.Println("Registrierte Repositories:")
for _, r := range reposList { for _, r := range reposList {
fmt.Printf("- %s/%s (%s)\n", r.Owner, r.Name, r.URL) version := r.InstalledVersion
if version == "" {
version = "nicht installiert"
}
fmt.Printf("- %s/%s (%s) Version: %s\n", r.Owner, r.Name, r.URL, version)
} }
return return
@@ -74,6 +93,28 @@ func main() {
} }
return return
case "update":
if len(os.Args) < 3 {
fmt.Println("Usage: ginie update <name|--all>")
return
}
target := os.Args[2]
if target == "--all" {
err := install.UpdateAll()
if err != nil {
fmt.Println("Fehler:", err)
return
}
return
}
err := install.Update(target)
if err != nil {
fmt.Println("Fehler:", err)
return
}
return
default: default:
fmt.Println("Unbekannter Befehl:", cmd) fmt.Println("Unbekannter Befehl:", cmd)

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 {
@@ -109,10 +114,7 @@ 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 {
@@ -123,9 +125,25 @@ func Install(pkg string) error {
return errors.New("Release hat keine Assets") return errors.New("Release hat keine Assets")
} }
installedVersion := release.TagName
if installedVersion == "" {
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)
} }
@@ -133,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)
@@ -167,9 +185,117 @@ func Install(pkg string) error {
cmd := exec.Command("sudo", "dpkg", "-i", asset.Name) cmd := exec.Command("sudo", "dpkg", "-i", asset.Name)
cmd.Stdout = os.Stdout cmd.Stdout = os.Stdout
cmd.Stderr = os.Stderr cmd.Stderr = os.Stderr
return cmd.Run() // Run the install command
err := cmd.Run()
if err != nil {
fmt.Println("Package konnte nicht installiert werden.")
}
// Remove debian package file
err = os.Remove(asset.Name)
if err != nil {
fmt.Println("Package konnte nicht gelöscht werden.")
}
if installedVersion == "" {
installedVersion = "unknown"
}
if err := repos.SetInstalledVersion(repo.Name, installedVersion); err != nil {
fmt.Println("Speichern der installierten Version nicht möglich.")
return err
}
return nil
} }
return errors.New("Asset-Typ wird noch nicht unterstützt") return errors.New("Asset-Typ wird noch nicht unterstützt")
} }
func Update(pkg string) error {
name := pkg
all, err := repos.LoadRepos()
if err != nil {
return err
}
var repo repos.Repo
found := false
for _, r := range all {
if r.Name == name {
repo = r
found = true
break
}
}
if !found {
return errors.New("Repo nicht gefunden. Nutze: ginie add <URL>")
}
if repo.InstalledVersion == "" {
return errors.New("Package noch nicht installiert. Nutze: ginie install " + name)
}
api := fmt.Sprintf("https://api.github.com/repos/%s/%s/releases/latest", repo.Owner, repo.Name)
resp, err := http.Get(api)
if err != nil {
return err
}
defer resp.Body.Close()
if resp.StatusCode != 200 {
return fmt.Errorf("GitHub API Fehler: %s", resp.Status)
}
var release struct {
TagName string `json:"tag_name"`
}
if err := json.NewDecoder(resp.Body).Decode(&release); err != nil {
return err
}
if release.TagName == "" {
return errors.New("Keine Version im Release gefunden")
}
if release.TagName == repo.InstalledVersion {
fmt.Printf("%s ist bereits auf Version %s\n", repo.Name, repo.InstalledVersion)
return nil
}
fmt.Printf("Aktualisiere %s von %s auf %s\n", repo.Name, repo.InstalledVersion, 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

@@ -12,6 +12,7 @@ type Repo struct {
URL string `json:"url"` URL string `json:"url"`
Owner string `json:"owner"` Owner string `json:"owner"`
Name string `json:"name"` Name string `json:"name"`
InstalledVersion string `json:"installed_version,omitempty"`
} }
func configPath() (string, error) { func configPath() (string, error) {
@@ -103,6 +104,51 @@ func AddRepo(url string) error {
return SaveRepos(repos) return SaveRepos(repos)
} }
func RemoveRepo(url string) error {
repos, err := LoadRepos()
if err != nil {
return err
}
index := -1
for i, r := range repos {
if r.URL == url {
index = i
break
}
}
if index == -1 {
return errors.New("Repo nicht gefunden")
}
repos = append(repos[:index], repos[index+1:]...)
return SaveRepos(repos)
}
func ListRepos() ([]Repo, error) { func ListRepos() ([]Repo, error) {
return LoadRepos() return LoadRepos()
} }
func SetInstalledVersion(name string, version string) error {
repos, err := LoadRepos()
if err != nil {
return err
}
updated := false
for i := range repos {
if repos[i].Name == name {
repos[i].InstalledVersion = version
updated = true
break
}
}
if !updated {
return errors.New("Repo nicht gefunden")
}
return SaveRepos(repos)
}

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.1" var Version = "0.1.6"