using internal
This commit is contained in:
@@ -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)
|
||||||
|
|
||||||
|
|||||||
@@ -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
70
internal/internal.go
Normal 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")
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user