Swap to unmarshalling the JSON.

This commit is contained in:
root 2025-03-02 19:57:39 -05:00
parent f9f2413e44
commit e1322051e1

47
main.go
View file

@ -5,40 +5,53 @@ import (
"os"
"os/exec"
"github.com/bitly/go-simplejson"
"github.com/hjson/hjson-go/v4"
)
type Config struct {
System SystemConfig
Networking NetworkingConfig
Services map[string]ServiceConfig
}
type SystemConfig struct {
Packages []string
}
type NetworkingConfig struct {
}
type ServiceConfig struct {
Enable string
Provider string
Src string
Ports []string
Volumes []string
}
func main() {
var err error
var config Config
fd, err := os.Open("goolinux.json")
defer fd.Close()
file, err := os.ReadFile("goolinux.json")
if err != nil {
fmt.Println(err)
return
}
userJSON, err := simplejson.NewFromReader(fd)
err = hjson.Unmarshal(file, &config)
if err != nil {
fmt.Println(err)
return
}
// Parse services
services := userJSON.Get("services").MustMap()
for service, _ := range services {
s := userJSON.Get("services").Get(service).MustMap()
if s["enable"] == "false" { continue }
fmt.Printf("Service: %s\n", service)
for key, value := range s {
fmt.Printf(" %s: %s\n", key, value)
}
for name, service := range config.Services {
fmt.Printf("Service: %s\n", name)
fmt.Printf(" %v\n", service)
}
// Parse package list
packages := userJSON.Get("system").Get("packages").MustStringArray()
fmt.Println(packages)
// Add extra packages needed
// ...
@ -48,7 +61,7 @@ func main() {
var testArgs, args []string
var out []byte
testArgs = append(installString, "-s")
testArgs = append(testArgs, packages...)
testArgs = append(testArgs, config.System.Packages...)
out, err = exec.Command("/sbin/apk", testArgs...).CombinedOutput()
if err != nil {
fmt.Println("===")
@ -59,7 +72,7 @@ func main() {
return
}
args = append(installString, packages...)
args = append(installString, config.System.Packages...)
out, err = exec.Command("/sbin/apk", args...).CombinedOutput()
if err != nil {
fmt.Println("===")