feat(cli): add first implementation for install command
This commit is contained in:
parent
c1e913641e
commit
c0be9a6b43
11 changed files with 257 additions and 77 deletions
83
cmd.go
83
cmd.go
|
|
@ -2,10 +2,7 @@ package main
|
|||
|
||||
import (
|
||||
"fmt"
|
||||
"log"
|
||||
"os"
|
||||
"os/exec"
|
||||
"strings"
|
||||
|
||||
"github.com/spf13/cobra"
|
||||
"github.com/spf13/viper"
|
||||
|
|
@ -17,24 +14,6 @@ var rootCmd = &cobra.Command{
|
|||
Run: run,
|
||||
}
|
||||
|
||||
var searchCmd = &cobra.Command{
|
||||
Use: "search [package_name]",
|
||||
Short: "Search for a package across package managers (will search in os|flatpak|homebrew)",
|
||||
Args: cobra.ExactArgs(1),
|
||||
Run: func(cmd *cobra.Command, args []string) {
|
||||
packageName := args[0]
|
||||
|
||||
managers := []string{"brew", "os", "flatpak"}
|
||||
|
||||
for _, manager := range managers {
|
||||
fmt.Printf("Searching in %s:\n", manager)
|
||||
results := searchPackage(packageName, manager)
|
||||
displayResults(results, manager)
|
||||
fmt.Println()
|
||||
}
|
||||
},
|
||||
}
|
||||
|
||||
func init() {
|
||||
cobra.OnInitialize(initConfig)
|
||||
rootCmd.PersistentFlags().StringP("config", "c", "", "Path to the configuration file")
|
||||
|
|
@ -52,8 +31,14 @@ func init() {
|
|||
|
||||
enableCmd.Flags().Bool("value", true, "Set to true to enable, false to disable")
|
||||
|
||||
installCmd.Flags().StringP("manager", "m", "os", "The package manager you want to install a package with. (Options: os|homebrew|pipx|flatpak|cargo)")
|
||||
|
||||
removeCmd.Flags().StringP("manager", "m", "os", "The package manager you want to remove a package with. (Options: os|homebrew|pipx|flatpak|cargo)")
|
||||
|
||||
searchCmd.Flags().StringP("manager", "m", "", "The package manager you want to search a package with. (Options: os|homebrew|flatpak)")
|
||||
|
||||
packageCmd.AddCommand(addCmd, deleteCmd, showCmd, enableCmd)
|
||||
rootCmd.AddCommand(packageCmd, searchCmd)
|
||||
rootCmd.AddCommand(packageCmd, searchCmd, installCmd, removeCmd)
|
||||
}
|
||||
|
||||
func initConfig() {
|
||||
|
|
@ -70,57 +55,3 @@ func initConfig() {
|
|||
os.Exit(1)
|
||||
}
|
||||
}
|
||||
|
||||
func displayResults(results []string, manager string) {
|
||||
if len(results) == 0 {
|
||||
fmt.Printf("No results found in %s\n", manager)
|
||||
return
|
||||
}
|
||||
for _, result := range results {
|
||||
fmt.Printf("- %s\n", result)
|
||||
}
|
||||
}
|
||||
|
||||
func searchPackage(packageName, manager string) []string {
|
||||
switch manager {
|
||||
case "brew":
|
||||
cmd := exec.Command("brew", "search", packageName)
|
||||
packages, err := cmd.Output()
|
||||
if err != nil {
|
||||
log.Printf("error fetching %s packages: %v", manager, err)
|
||||
}
|
||||
packageList := strings.Split(strings.TrimSpace(string(packages)), "\n")
|
||||
return packageList
|
||||
case "os":
|
||||
opSys, err := getLinuxDistribution()
|
||||
if err != nil {
|
||||
log.Printf("Error getting OS information: %v", err)
|
||||
return []string{}
|
||||
}
|
||||
|
||||
cmdParts := strings.Fields(opSys.SearchCommand)
|
||||
if len(cmdParts) == 0 {
|
||||
log.Printf("Invalid search command for OS package manager")
|
||||
return []string{}
|
||||
}
|
||||
|
||||
cmd := exec.Command(cmdParts[0], append(cmdParts[1:], packageName)...)
|
||||
packages, err := cmd.Output()
|
||||
if err != nil {
|
||||
log.Printf("Error fetching %s packages: %v", manager, err)
|
||||
return []string{}
|
||||
}
|
||||
|
||||
packageList := strings.Split(strings.TrimSpace(string(packages)), "\n")
|
||||
return packageList
|
||||
case "flatpak":
|
||||
cmd := exec.Command("flatpak", "search", packageName)
|
||||
packages, err := cmd.Output()
|
||||
if err != nil {
|
||||
log.Printf("error fetching %s packages: %v", manager, err)
|
||||
}
|
||||
packageList := strings.Split(strings.TrimSpace(string(packages)), "\n")
|
||||
return packageList
|
||||
}
|
||||
return []string{"Beispielpaket 1", "Beispielpaket 2"} // Platzhalter
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue