using internal

This commit is contained in:
2025-07-31 17:24:57 -03:00
parent 625fe7c05b
commit ca90f929d7
3 changed files with 79 additions and 44 deletions

View File

@@ -6,6 +6,8 @@ import (
"net/http" "net/http"
"os" "os"
"packets/internal"
"github.com/BurntSushi/toml" "github.com/BurntSushi/toml"
) )
@@ -17,6 +19,8 @@ type ConfigTOML struct {
} }
func main() { func main() {
internal.PacketsPackageDir()
var cfg ConfigTOML var cfg ConfigTOML
toml.Decode("opt/packets/packets/config.toml", &cfg) toml.Decode("opt/packets/packets/config.toml", &cfg)

View File

@@ -17,6 +17,7 @@ import (
"net/url" "net/url"
"os" "os"
"os/exec" "os/exec"
"packets/internal"
"path" "path"
"path/filepath" "path/filepath"
"strconv" "strconv"
@@ -96,12 +97,8 @@ var PacketsDir string
func main() { func main() {
out, _ := exec.Command("uname", "-s").Output() PacketsDir := internal.PacketsPackageDir()
if uname := strings.TrimSpace(string(out)); uname == "OpenTTY" {
PacketsDir = "/mnt/packets"
} else {
PacketsDir = "/etc/packets"
}
_, err := os.Stat(filepath.Join(PacketsDir, "config.toml")) _, err := os.Stat(filepath.Join(PacketsDir, "config.toml"))
if os.IsNotExist(err) { if os.IsNotExist(err) {
fmt.Println("can't find config.toml, generating a default one") fmt.Println("can't find config.toml, generating a default one")
@@ -373,45 +370,9 @@ func main() {
} }
} }
func ManifestReadXZ(path string) (*Manifest, error) {
f, err := os.Open(path)
if err != nil {
return nil, err
}
defer f.Close()
xzr, err := xz.NewReader(f)
if err != nil {
return nil, err
}
tr := tar.NewReader(xzr)
for {
hdr, err := tr.Next()
if err == io.EOF {
break
}
if err != nil {
return nil, err
}
if strings.HasSuffix(hdr.Name, "/manifest.json") || hdr.Name == "manifest.json" {
var manifest Manifest
decoder := json.NewDecoder(tr)
if err := decoder.Decode(&manifest); err != nil {
return nil, err
}
return &manifest, nil
}
}
return nil, fmt.Errorf("can't find manifest.json")
}
func Install(packagepath string, serial uint) error { func Install(packagepath string, serial uint) error {
manifest, err := ManifestReadXZ(packagepath) manifest, err := internal.ManifestReadXZ(packagepath)
if err != nil { if err != nil {
log.Panic(err) log.Panic(err)
} }
@@ -1107,7 +1068,7 @@ func Upgrade(packagepath string, og_realname string, serial uint) error {
return fmt.Errorf("this package isn't installed") return fmt.Errorf("this package isn't installed")
} }
manifest, err := ManifestReadXZ(packagepath) manifest, err := internal.ManifestReadXZ(packagepath)
if err != nil { if err != nil {
log.Panic(err) log.Panic(err)
} }

70
internal/internal.go Normal file
View File

@@ -0,0 +1,70 @@
package internal
import (
"archive/tar"
"encoding/json"
"fmt"
"io"
"os"
"os/exec"
"strings"
"github.com/ulikunitz/xz"
)
type Manifest struct {
Name string `json:"name"`
Version string `json:"version"`
Description string `json:"description"`
Dependencies []string `json:"dependencies"`
Author string `json:"author"`
Family string `json:"family"`
Serial uint `json:"serial"`
}
func PacketsPackageDir() string {
out, _ := exec.Command("uname", "-s").Output()
if uname := strings.TrimSpace(string(out)); uname == "OpenTTY" {
return "/mnt/....."
} else {
return "/etc/packets"
}
}
func ManifestReadXZ(path string) (*Manifest, error) {
f, err := os.Open(path)
if err != nil {
return nil, err
}
defer f.Close()
xzr, err := xz.NewReader(f)
if err != nil {
return nil, err
}
tr := tar.NewReader(xzr)
for {
hdr, err := tr.Next()
if err == io.EOF {
break
}
if err != nil {
return nil, err
}
if strings.HasSuffix(hdr.Name, "/manifest.json") || hdr.Name == "manifest.json" {
var manifest Manifest
decoder := json.NewDecoder(tr)
if err := decoder.Decode(&manifest); err != nil {
return nil, err
}
return &manifest, nil
}
}
return nil, fmt.Errorf("can't find manifest.json")
}