AllPac/pkg/packagemanager/installer_utils.go
VetheonGames 50af1b9613 Major update 4
This should be the final code update before we start testing things.
I think all the code is now in place to have the program function, barring any bugs in my code.

So, with that said, here's the changelog:

global changes:
```
- implement logger.go across the whole program
```

changes to main.go:
```
- add an import for strings
- implement the roughed in handling functions
```

changes to logger.go:
```
- create this little helper package to just handle all our logging nice and gracefully
```

changes to all_updater.go:
```
- basically completely redone. Accomplishes the same thing, just in a different, more efficient way.
```

changes to aur.go:
```
- add a function to clear the AllPac build cache for aur
```

changes to install.go:
```
- removed a duplicate function, set install.go to call the right one
```

changes to pacman.go:
```
- removed GetVersionFromPacman function (it shouldn't be here, it should be in search.go)
```

changes to search.go:
```
- add functions for getting info from, and parsing output from Snap, Pacman, Flatpak, and aur
```
2024-01-04 19:17:43 -07:00

154 lines
4.3 KiB
Go

package packagemanager
import (
"bufio"
"os"
"os/user"
"path/filepath"
"strings"
"fmt"
"encoding/json"
"pixelridgesoftworks.com/AllPac/pkg/logger"
)
// extractVersionFromPKGBUILD reads the PKGBUILD file and extracts the package version
func ExtractVersionFromPKGBUILD(repoDir string) (string, error) {
pkgbuildPath := filepath.Join(repoDir, "PKGBUILD")
file, err := os.Open(pkgbuildPath)
if err != nil {
logger.Errorf("An error has occured:", err)
return "", err
}
defer file.Close()
scanner := bufio.NewScanner(file)
for scanner.Scan() {
line := scanner.Text()
if strings.HasPrefix(line, "pkgver=") {
return strings.TrimPrefix(line, "pkgver="), nil
}
}
if err := scanner.Err(); err != nil {
logger.Errorf("An error has occured:", err)
return "", err
}
logger.Errorf("pkgver not found in PKGBUILD")
return "", fmt.Errorf("pkgver not found in PKGBUILD")
}
type PackageInfo struct {
Source string `json:"source"`
Version string `json:"version"`
}
type PackageList map[string]PackageInfo
const pkgListFilename = "pkg.list"
// getPkgListPath returns the file path for the package list
func GetPkgListPath() (string, error) {
usr, err := user.Current()
if err != nil {
logger.Errorf("error getting current user: %v", err)
return "", fmt.Errorf("error getting current user: %v", err)
}
return filepath.Join(usr.HomeDir, ".allpac", pkgListFilename), nil
}
// readPackageList reads the package list from the file
func ReadPackageList() (PackageList, error) {
pkgListPath, err := GetPkgListPath()
if err != nil {
logger.Errorf("An error has occured:", err)
return nil, err
}
file, err := os.Open(pkgListPath)
if err != nil {
if os.IsNotExist(err) {
return PackageList{}, nil // Return an empty list if file doesn't exist
}
logger.Errorf("error opening package list file: %v", err)
return nil, fmt.Errorf("error opening package list file: %v", err)
}
defer file.Close()
var pkgList PackageList
err = json.NewDecoder(file).Decode(&pkgList)
if err != nil {
logger.Errorf("error decoding package list: %v", err)
return nil, fmt.Errorf("error decoding package list: %v", err)
}
return pkgList, nil
}
// writePackageList writes the package list to the file
func writePackageList(pkgList PackageList) error {
pkgListPath, err := GetPkgListPath()
if err != nil {
logger.Errorf("An error has occured:", err)
return err
}
file, err := os.Create(pkgListPath)
if err != nil {
logger.Errorf("error creating package list file: %v", err)
return fmt.Errorf("error creating package list file: %v", err)
}
defer file.Close()
err = json.NewEncoder(file).Encode(pkgList)
if err != nil {
logger.Errorf("error encoding package list: %v", err)
return fmt.Errorf("error encoding package list: %v", err)
}
return nil
}
// logInstallation logs the package installation details
func LogInstallation(packageName, source, version string) error {
pkgList, err := readPackageList()
if err != nil {
logger.Errorf("An error has occured:", err)
return err
}
pkgList[packageName] = PackageInfo{
Source: source,
Version: version,
}
return writePackageList(pkgList)
}
// requestRootPermissions prompts the user for root permissions
func requestRootPermissions() bool {
fmt.Println("Root permissions are required to install AUR packages.")
return confirmAction("Do you want to continue with root permissions?")
}
// confirmAction prompts the user with a yes/no question and returns true if the answer is yes
func confirmAction(question string) bool {
reader := bufio.NewReader(os.Stdin)
for {
fmt.Printf("%s [Y/n]: ", question)
response, err := reader.ReadString('\n')
if err != nil {
logger.Errorf("Error reading response: %v", err)
fmt.Println("Error reading response:", err)
return false
}
response = strings.ToLower(strings.TrimSpace(response))
if response == "y" || response == "yes" {
return true
} else if response == "n" || response == "no" {
return false
}
}
}