|
|
|
@ -15,43 +15,59 @@ type Result struct { |
|
|
|
Removed int |
|
|
|
Removed int |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
func SyncPackages(packages []string, logWriter io.Writer) error { |
|
|
|
func InstallAUR(pkgName string, packageBase string, logWriter io.Writer) error { |
|
|
|
start := time.Now() |
|
|
|
start := time.Now() |
|
|
|
log.Debug("SyncPackages: starting...") |
|
|
|
log.Debug("InstallAUR: starting...") |
|
|
|
|
|
|
|
|
|
|
|
if logWriter == nil { |
|
|
|
if logWriter == nil { |
|
|
|
logWriter = os.Stderr |
|
|
|
logWriter = os.Stderr |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
args := append([]string{"-S", "--needed", "--noconfirm"}, packages...) |
|
|
|
sudoUser := os.Getenv("SUDO_USER") |
|
|
|
cmd := log.Command("pacman", args...) |
|
|
|
if sudoUser == "" { |
|
|
|
cmd.Stdout = logWriter |
|
|
|
sudoUser = os.Getenv("USER") |
|
|
|
cmd.Stderr = logWriter |
|
|
|
if sudoUser == "" { |
|
|
|
err := cmd.Run() |
|
|
|
sudoUser = "root" |
|
|
|
if err != nil { |
|
|
|
} |
|
|
|
return fmt.Errorf("pacman sync failed: %w", err) |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
log.Debug("SyncPackages: done (%.2fs)", time.Since(start).Seconds()) |
|
|
|
tmpDir := "/tmp/declpac/" + pkgName |
|
|
|
return nil |
|
|
|
mkdirCmd := log.Command("su", "-", sudoUser, "-c", "rm -rf "+tmpDir+" && mkdir -p "+tmpDir) |
|
|
|
} |
|
|
|
if err := mkdirCmd.Run(); err != nil { |
|
|
|
|
|
|
|
return fmt.Errorf("failed to create temp directory: %w", err) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
defer os.RemoveAll(tmpDir) |
|
|
|
|
|
|
|
|
|
|
|
func RefreshDB(logWriter io.Writer) error { |
|
|
|
cloneURL := "https://aur.archlinux.org/" + packageBase + ".git" |
|
|
|
start := time.Now() |
|
|
|
cloneCmd := log.Command("su", "-", sudoUser, "-c", "git clone "+cloneURL+" "+tmpDir) |
|
|
|
log.Debug("RefreshDB: starting...") |
|
|
|
cloneCmd.Stdout = logWriter |
|
|
|
|
|
|
|
cloneCmd.Stderr = logWriter |
|
|
|
|
|
|
|
if err := cloneCmd.Run(); err != nil { |
|
|
|
|
|
|
|
return fmt.Errorf("failed to clone AUR repo: %w", err) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
log.Debug("InstallAUR: cloned (%.2fs)", time.Since(start).Seconds()) |
|
|
|
|
|
|
|
|
|
|
|
if logWriter == nil { |
|
|
|
makepkgCmd := log.Command("su", "-", sudoUser, "-c", "cd "+tmpDir+" && makepkg -s --noconfirm") |
|
|
|
logWriter = os.Stderr |
|
|
|
makepkgCmd.Stdout = logWriter |
|
|
|
|
|
|
|
makepkgCmd.Stderr = logWriter |
|
|
|
|
|
|
|
if err := makepkgCmd.Run(); err != nil { |
|
|
|
|
|
|
|
return fmt.Errorf("makepkg failed to build AUR package: %w", err) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
log.Debug("InstallAUR: built (%.2fs)", time.Since(start).Seconds()) |
|
|
|
|
|
|
|
|
|
|
|
cmd := log.Command("pacman", "-Syy") |
|
|
|
pkgFile, err := findPKGFile(pkgName, tmpDir) |
|
|
|
cmd.Stdout = logWriter |
|
|
|
if err != nil { |
|
|
|
cmd.Stderr = logWriter |
|
|
|
return fmt.Errorf("failed to find built package: %w", err) |
|
|
|
if err := cmd.Run(); err != nil { |
|
|
|
|
|
|
|
return fmt.Errorf("failed to refresh pacman database: %w", err) |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
log.Debug("RefreshDB: done (%.2fs)", time.Since(start).Seconds()) |
|
|
|
installCmd := log.Command("pacman", "-U", "--noconfirm", pkgFile) |
|
|
|
|
|
|
|
installCmd.Stdout = logWriter |
|
|
|
|
|
|
|
installCmd.Stderr = logWriter |
|
|
|
|
|
|
|
if err := installCmd.Run(); err != nil { |
|
|
|
|
|
|
|
return fmt.Errorf("failed to install package: %w", err) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
log.Debug("InstallAUR: done (%.2fs)", time.Since(start).Seconds()) |
|
|
|
|
|
|
|
|
|
|
|
return nil |
|
|
|
return nil |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
@ -80,6 +96,25 @@ func MarkAs(packages []string, flag string, logWriter io.Writer) error { |
|
|
|
return nil |
|
|
|
return nil |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
func RefreshDB(logWriter io.Writer) error { |
|
|
|
|
|
|
|
start := time.Now() |
|
|
|
|
|
|
|
log.Debug("RefreshDB: starting...") |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if logWriter == nil { |
|
|
|
|
|
|
|
logWriter = os.Stderr |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
cmd := log.Command("pacman", "-Syy") |
|
|
|
|
|
|
|
cmd.Stdout = logWriter |
|
|
|
|
|
|
|
cmd.Stderr = logWriter |
|
|
|
|
|
|
|
if err := cmd.Run(); err != nil { |
|
|
|
|
|
|
|
return fmt.Errorf("failed to refresh pacman database: %w", err) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
log.Debug("RefreshDB: done (%.2fs)", time.Since(start).Seconds()) |
|
|
|
|
|
|
|
return nil |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
func RemoveOrphans(orphans []string, logWriter io.Writer) (int, error) { |
|
|
|
func RemoveOrphans(orphans []string, logWriter io.Writer) (int, error) { |
|
|
|
start := time.Now() |
|
|
|
start := time.Now() |
|
|
|
log.Debug("RemoveOrphans: starting...") |
|
|
|
log.Debug("RemoveOrphans: starting...") |
|
|
|
@ -110,62 +145,30 @@ func RemoveOrphans(orphans []string, logWriter io.Writer) (int, error) { |
|
|
|
return count, nil |
|
|
|
return count, nil |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
func InstallAUR(pkgName string, packageBase string, logWriter io.Writer) error { |
|
|
|
func SyncPackages(packages []string, logWriter io.Writer) error { |
|
|
|
start := time.Now() |
|
|
|
start := time.Now() |
|
|
|
log.Debug("InstallAUR: starting...") |
|
|
|
log.Debug("SyncPackages: starting...") |
|
|
|
|
|
|
|
|
|
|
|
if logWriter == nil { |
|
|
|
if logWriter == nil { |
|
|
|
logWriter = os.Stderr |
|
|
|
logWriter = os.Stderr |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
sudoUser := os.Getenv("SUDO_USER") |
|
|
|
args := append([]string{"-S", "--needed", "--noconfirm"}, packages...) |
|
|
|
if sudoUser == "" { |
|
|
|
cmd := log.Command("pacman", args...) |
|
|
|
sudoUser = os.Getenv("USER") |
|
|
|
cmd.Stdout = logWriter |
|
|
|
if sudoUser == "" { |
|
|
|
cmd.Stderr = logWriter |
|
|
|
sudoUser = "root" |
|
|
|
err := cmd.Run() |
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
tmpDir := "/tmp/declpac/" + pkgName |
|
|
|
|
|
|
|
mkdirCmd := log.Command("su", "-", sudoUser, "-c", "rm -rf "+tmpDir+" && mkdir -p "+tmpDir) |
|
|
|
|
|
|
|
if err := mkdirCmd.Run(); err != nil { |
|
|
|
|
|
|
|
return fmt.Errorf("failed to create temp directory: %w", err) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
defer os.RemoveAll(tmpDir) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
cloneURL := "https://aur.archlinux.org/" + packageBase + ".git" |
|
|
|
|
|
|
|
cloneCmd := log.Command("su", "-", sudoUser, "-c", "git clone "+cloneURL+" "+tmpDir) |
|
|
|
|
|
|
|
cloneCmd.Stdout = logWriter |
|
|
|
|
|
|
|
cloneCmd.Stderr = logWriter |
|
|
|
|
|
|
|
if err := cloneCmd.Run(); err != nil { |
|
|
|
|
|
|
|
return fmt.Errorf("failed to clone AUR repo: %w", err) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
log.Debug("InstallAUR: cloned (%.2fs)", time.Since(start).Seconds()) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
makepkgCmd := log.Command("su", "-", sudoUser, "-c", "cd "+tmpDir+" && makepkg -s --noconfirm") |
|
|
|
|
|
|
|
makepkgCmd.Stdout = logWriter |
|
|
|
|
|
|
|
makepkgCmd.Stderr = logWriter |
|
|
|
|
|
|
|
if err := makepkgCmd.Run(); err != nil { |
|
|
|
|
|
|
|
return fmt.Errorf("makepkg failed to build AUR package: %w", err) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
log.Debug("InstallAUR: built (%.2fs)", time.Since(start).Seconds()) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
pkgFile, err := findPKGFile(pkgName, tmpDir) |
|
|
|
|
|
|
|
if err != nil { |
|
|
|
if err != nil { |
|
|
|
return fmt.Errorf("failed to find built package: %w", err) |
|
|
|
return fmt.Errorf("pacman sync failed: %w", err) |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
installCmd := log.Command("pacman", "-U", "--noconfirm", pkgFile) |
|
|
|
|
|
|
|
installCmd.Stdout = logWriter |
|
|
|
|
|
|
|
installCmd.Stderr = logWriter |
|
|
|
|
|
|
|
if err := installCmd.Run(); err != nil { |
|
|
|
|
|
|
|
return fmt.Errorf("failed to install package: %w", err) |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
log.Debug("InstallAUR: done (%.2fs)", time.Since(start).Seconds()) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
log.Debug("SyncPackages: done (%.2fs)", time.Since(start).Seconds()) |
|
|
|
return nil |
|
|
|
return nil |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// -----------------------------------------
|
|
|
|
|
|
|
|
// private
|
|
|
|
|
|
|
|
|
|
|
|
func findPKGFile(pkgName string, dir string) (string, error) { |
|
|
|
func findPKGFile(pkgName string, dir string) (string, error) { |
|
|
|
entries, err := os.ReadDir(dir) |
|
|
|
entries, err := os.ReadDir(dir) |
|
|
|
if err != nil { |
|
|
|
if err != nil { |
|
|
|
|