Compare commits
No commits in common. "master" and "v0.0.18" have entirely different histories.
2
Makefile
2
Makefile
|
@ -5,7 +5,7 @@
|
||||||
# go install
|
# go install
|
||||||
|
|
||||||
|
|
||||||
all: package.pb.go machine.pb.go goimports vet
|
all: package.pb.go machine.pb.go vet
|
||||||
|
|
||||||
vet:
|
vet:
|
||||||
@GO111MODULE=off go vet
|
@GO111MODULE=off go vet
|
||||||
|
|
|
@ -1,6 +1 @@
|
||||||
protobuf definition files for zookeeper
|
protobuf definition files for zookeeper
|
||||||
|
|
||||||
* experimental. at this point, it's just stubbed in
|
|
||||||
* zookeeper is similar to the apache zookeeper project
|
|
||||||
* you can use it to maintain the systems in your cluster
|
|
||||||
* zookeeper works with virtigo to maintain your private cloud
|
|
||||||
|
|
42
apt.go
42
apt.go
|
@ -2,9 +2,8 @@ package zoopb
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"runtime"
|
|
||||||
|
|
||||||
"golang.org/x/sys/unix"
|
"go.wit.com/log"
|
||||||
)
|
)
|
||||||
|
|
||||||
// init the installed package list
|
// init the installed package list
|
||||||
|
@ -25,40 +24,17 @@ func (me *Machine) initPackages() {
|
||||||
new1 := new(Package)
|
new1 := new(Package)
|
||||||
new1.Name = pkg
|
new1.Name = pkg
|
||||||
new1.Version = version
|
new1.Version = version
|
||||||
me.Packages.Append(new1)
|
if me.Packages.Append(new1) {
|
||||||
// log.Info("added", new1.Name, "failed")
|
// log.Info("added", new1.Name, "ok")
|
||||||
|
} else {
|
||||||
|
log.Info("added", new1.Name, "failed")
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
me.getMemory()
|
func (me *Machine) addNew(name string, version string) bool {
|
||||||
}
|
|
||||||
|
|
||||||
func (me *Machine) addNew(name string, version string) {
|
|
||||||
new1 := new(Package)
|
new1 := new(Package)
|
||||||
new1.Name = name
|
new1.Name = name
|
||||||
new1.Version = version
|
new1.Version = version
|
||||||
me.Packages.Append(new1)
|
return me.Packages.Append(new1)
|
||||||
}
|
|
||||||
|
|
||||||
// simple memory and cpu count
|
|
||||||
func (me *Machine) getMemory() {
|
|
||||||
// Get number of CPUs
|
|
||||||
numCPUs := runtime.NumCPU()
|
|
||||||
|
|
||||||
// Get total system memory
|
|
||||||
var sysInfo unix.Sysinfo_t
|
|
||||||
err := unix.Sysinfo(&sysInfo)
|
|
||||||
if err != nil {
|
|
||||||
fmt.Println("Error getting system info:", err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
// Convert memory from bytes to GB
|
|
||||||
m := float64(sysInfo.Totalram) * float64(sysInfo.Unit)
|
|
||||||
me.Memory = int64(m)
|
|
||||||
me.Cpus = int64(numCPUs)
|
|
||||||
|
|
||||||
// totalMemGB := float64(sysInfo.Totalram) * float64(sysInfo.Unit) / (1024 * 1024 * 1024)
|
|
||||||
// Print results
|
|
||||||
// fmt.Printf("Total Memory: %.2f GB\n", totalMemGB)
|
|
||||||
// fmt.Printf("Number of CPUs: %d\n", numCPUs)
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -71,13 +71,11 @@ func dpkgQuery() (map[string]string, error) {
|
||||||
return installedPackages, scanner.Err()
|
return installedPackages, scanner.Err()
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
func (me *Machine) UpdatePackages() string {
|
func (me *Machine) UpdatePackages() string {
|
||||||
log.Info("fixme. broken after move to autogenpb")
|
log.Info("fixme. broken after move to autogenpb")
|
||||||
return ""
|
return ""
|
||||||
}
|
}
|
||||||
*/
|
/*
|
||||||
|
|
||||||
func (me *Machine) UpdatePackages() string {
|
func (me *Machine) UpdatePackages() string {
|
||||||
// Get the list of installed packages for the detected distro
|
// Get the list of installed packages for the detected distro
|
||||||
newP, err := getPackageList(me.Distro)
|
newP, err := getPackageList(me.Distro)
|
||||||
|
@ -96,7 +94,7 @@ func (me *Machine) UpdatePackages() string {
|
||||||
newCounter += 1
|
newCounter += 1
|
||||||
} else {
|
} else {
|
||||||
found.Version = version
|
found.Version = version
|
||||||
// panic("redo this. broken after autogenpb. was never right anyway")
|
panic("redo this. broken after autogenpb. was never right anyway")
|
||||||
//if me.Packages.Update(found) {
|
//if me.Packages.Update(found) {
|
||||||
// changeCounter += 1
|
// changeCounter += 1
|
||||||
//}
|
//}
|
||||||
|
@ -112,3 +110,4 @@ func (me *Machine) UpdatePackages() string {
|
||||||
}
|
}
|
||||||
return footer
|
return footer
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
|
|
153
config.go
153
config.go
|
@ -4,20 +4,157 @@ package zoopb
|
||||||
// data to and from config files
|
// data to and from config files
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"go.wit.com/lib/config"
|
"errors"
|
||||||
|
"os"
|
||||||
|
"path/filepath"
|
||||||
|
|
||||||
|
"go.wit.com/log"
|
||||||
|
"google.golang.org/protobuf/proto"
|
||||||
)
|
)
|
||||||
|
|
||||||
// writes out the cluster information it seperate files
|
// writes out the cluster information it seperate files
|
||||||
// to make it humanly possible to hand edit things as needed
|
// to make it humanly possible to hand edit things as needed
|
||||||
func (m *Machines) ConfigSave(fullname string) error {
|
func (m *Machines) ConfigSave() error {
|
||||||
return config.SavePB(m, fullname)
|
data, err := m.Marshal()
|
||||||
|
if err != nil {
|
||||||
|
log.Info("proto.Marshal() failed len", len(data), err)
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
log.Info("proto.Marshal() worked len", len(data))
|
||||||
|
configWrite(data)
|
||||||
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *Machines) ConfigLoad() (string, error) {
|
// when running on a single machine, save the file in forge/
|
||||||
fullname, err := config.LoadPB(m, "/var/lib", "machines")
|
// as <hostname>.pb
|
||||||
|
// write to ~/.config/forge/ unless ENV{FORGE_HOME} is set
|
||||||
|
func (m *Machine) ConfigSave() error {
|
||||||
|
if os.Getenv("FORGE_HOME") == "" {
|
||||||
|
homeDir, _ := os.UserHomeDir()
|
||||||
|
fullpath := filepath.Join(homeDir, ".config/forge")
|
||||||
|
os.Setenv("FORGE_HOME", fullpath)
|
||||||
|
}
|
||||||
|
data, err := m.Marshal()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
// log.Info("zoopb.ConfigLoad() failed", err, fullname)
|
log.Info("proto.Marshal() failed len", len(data), err)
|
||||||
|
return err
|
||||||
}
|
}
|
||||||
fullname, err = config.LoadPB(m, "zookeeper", "machines")
|
|
||||||
return fullname, err
|
log.Info("ConfigSave() proto.Marshal() worked len", len(data))
|
||||||
|
|
||||||
|
hostname, _ := os.Hostname()
|
||||||
|
fname := hostname + ".pb"
|
||||||
|
return m.configWrite(fname, data)
|
||||||
|
}
|
||||||
|
|
||||||
|
func ConfigSaveRaw(data []byte) error {
|
||||||
|
configWrite(data)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *Machines) ConfigLoad() error {
|
||||||
|
if m == nil {
|
||||||
|
return errors.New("It's not safe to run ConfigLoad() on a nil ?")
|
||||||
|
}
|
||||||
|
|
||||||
|
if data, err := loadFile("zookeeper.pb"); err == nil {
|
||||||
|
if err = proto.Unmarshal(data, m); err != nil {
|
||||||
|
log.Warn("broken zookeeper.pb config file")
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *Machine) ConfigLoad() error {
|
||||||
|
if m == nil {
|
||||||
|
return errors.New("It's not safe to run ConfigLoad() on a nil ?")
|
||||||
|
}
|
||||||
|
if os.Getenv("FORGE_HOME") == "" {
|
||||||
|
homeDir, _ := os.UserHomeDir()
|
||||||
|
fullpath := filepath.Join(homeDir, ".config/forge")
|
||||||
|
os.Setenv("FORGE_HOME", fullpath)
|
||||||
|
}
|
||||||
|
|
||||||
|
hostname, _ := os.Hostname()
|
||||||
|
fname := hostname + ".pb"
|
||||||
|
|
||||||
|
var data []byte
|
||||||
|
var err error
|
||||||
|
if data, err = loadFile(fname); err != nil {
|
||||||
|
// something went wrong loading the file
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
if data != nil {
|
||||||
|
if err = proto.Unmarshal(data, m); err != nil {
|
||||||
|
log.Warn("broken zookeeper.pb config file", fname)
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
m.Hostname = hostname
|
||||||
|
m.Distro = detectDistro()
|
||||||
|
m.initPackages()
|
||||||
|
log.Info("zoopb.ConfigLoad()", m.Hostname, "runs", m.Distro, "with", m.Packages.Len(), "packages")
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func loadFile(filename string) ([]byte, error) {
|
||||||
|
homeDir, err := os.UserHomeDir()
|
||||||
|
p := filepath.Join(homeDir, ".config/zookeeper")
|
||||||
|
fullname := filepath.Join(p, filename)
|
||||||
|
data, err := os.ReadFile(fullname)
|
||||||
|
if errors.Is(err, os.ErrNotExist) {
|
||||||
|
// if file does not exist, just return nil. this
|
||||||
|
// will cause ConfigLoad() to try the next config file like "forge.text"
|
||||||
|
// because the user might want to edit the .config by hand
|
||||||
|
return nil, nil
|
||||||
|
}
|
||||||
|
if err != nil {
|
||||||
|
// log.Info("open config file :", err)
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return data, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *Machine) loadFile(fname string) ([]byte, error) {
|
||||||
|
fullname := filepath.Join(os.Getenv("FORGE_HOME"), fname)
|
||||||
|
|
||||||
|
data, err := os.ReadFile(fullname)
|
||||||
|
if err != nil {
|
||||||
|
// log.Info("open config file :", err)
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return data, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func configWrite(data []byte) error {
|
||||||
|
homeDir, err := os.UserHomeDir()
|
||||||
|
p := filepath.Join(homeDir, ".config/zookeeper")
|
||||||
|
fname := filepath.Join(p, "zookeeper.pb")
|
||||||
|
cfgfile, err := os.OpenFile(fname, os.O_RDWR|os.O_CREATE, 0666)
|
||||||
|
defer cfgfile.Close()
|
||||||
|
if err != nil {
|
||||||
|
log.Warn("open config file :", err)
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
cfgfile.Write(data)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *Machine) configWrite(fname string, data []byte) error {
|
||||||
|
fullname := filepath.Join(os.Getenv("FORGE_HOME"), fname)
|
||||||
|
|
||||||
|
cfgfile, err := os.OpenFile(fullname, os.O_RDWR|os.O_CREATE, 0666)
|
||||||
|
defer cfgfile.Close()
|
||||||
|
if err != nil {
|
||||||
|
log.Warn("open config file :", err)
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
cfgfile.Write(data)
|
||||||
|
return nil
|
||||||
}
|
}
|
||||||
|
|
75
http.go
75
http.go
|
@ -1,75 +0,0 @@
|
||||||
// Copyright 1994-2025 WIT.COM Inc Licensed GPL 3.0
|
|
||||||
|
|
||||||
package zoopb
|
|
||||||
|
|
||||||
import (
|
|
||||||
"bytes"
|
|
||||||
"fmt"
|
|
||||||
"io/ioutil"
|
|
||||||
"net/http"
|
|
||||||
"os/user"
|
|
||||||
|
|
||||||
"go.wit.com/log"
|
|
||||||
)
|
|
||||||
|
|
||||||
func (m *Machine) HttpPostMachine(url string) ([]byte, error) {
|
|
||||||
if m == nil {
|
|
||||||
// run f.InitMachine() here?
|
|
||||||
log.Info("you must run f.InitMachine()")
|
|
||||||
return nil, fmt.Errorf("you must run f.InitMachine()")
|
|
||||||
}
|
|
||||||
if m.Hostname == "" {
|
|
||||||
log.Info("WTF. hostname is blank")
|
|
||||||
} else {
|
|
||||||
// log.Info("GOOD. hostname is set to", m.Hostname)
|
|
||||||
}
|
|
||||||
// log.Info("GOOD2. hostname is set to", m.Hostname)
|
|
||||||
msg, err := m.Marshal()
|
|
||||||
if err != nil {
|
|
||||||
log.Info("proto.Marshal() failed:", err)
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
// log.Info("GOOD3. hostname is set to", m.Hostname)
|
|
||||||
|
|
||||||
check := new(Machine)
|
|
||||||
check.Unmarshal(msg)
|
|
||||||
if check == nil {
|
|
||||||
log.Info("WTF. check == nil")
|
|
||||||
}
|
|
||||||
// log.Info("good? check.hostname =", m.Hostname)
|
|
||||||
return m.HttpPostOld(url, msg)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (m *Machine) HttpPostOld(url string, data []byte) ([]byte, error) {
|
|
||||||
var err error
|
|
||||||
var req *http.Request
|
|
||||||
|
|
||||||
req, err = http.NewRequest(http.MethodPost, url, bytes.NewBuffer(data))
|
|
||||||
// log.Info("httpPost() with len", len(data), "url", url)
|
|
||||||
|
|
||||||
usr, _ := user.Current()
|
|
||||||
req.Header.Set("author", usr.Username)
|
|
||||||
// if f.Machine == nil {
|
|
||||||
// // run f.InitMachine() here?
|
|
||||||
// log.Info("you must run f.InitMachine()")
|
|
||||||
// return nil, fmt.Errorf("you must run f.InitMachine()")
|
|
||||||
// }
|
|
||||||
req.Header.Set("hostname", m.Hostname)
|
|
||||||
|
|
||||||
client := &http.Client{}
|
|
||||||
resp, err := client.Do(req)
|
|
||||||
if err != nil {
|
|
||||||
log.Error(err)
|
|
||||||
return []byte("client.Do(req) error"), err
|
|
||||||
}
|
|
||||||
defer resp.Body.Close()
|
|
||||||
// log.Info("httpPost() with len", len(data))
|
|
||||||
|
|
||||||
body, err := ioutil.ReadAll(resp.Body)
|
|
||||||
if err != nil {
|
|
||||||
log.Error(err)
|
|
||||||
return body, err
|
|
||||||
}
|
|
||||||
|
|
||||||
return body, nil
|
|
||||||
}
|
|
49
init.go
49
init.go
|
@ -1,49 +0,0 @@
|
||||||
package zoopb
|
|
||||||
|
|
||||||
import (
|
|
||||||
"os"
|
|
||||||
"time"
|
|
||||||
|
|
||||||
"go.wit.com/lib/config"
|
|
||||||
"go.wit.com/log"
|
|
||||||
)
|
|
||||||
|
|
||||||
// sent via -ldflags
|
|
||||||
var VERSION string
|
|
||||||
var BUILDTIME string
|
|
||||||
|
|
||||||
func (m *Machine) SinceLastUpdate() time.Duration {
|
|
||||||
age := m.Laststamp.AsTime()
|
|
||||||
return time.Since(age)
|
|
||||||
}
|
|
||||||
|
|
||||||
func InitMachine() (*Machine, string) {
|
|
||||||
var fullname string
|
|
||||||
var err error
|
|
||||||
m := new(Machine)
|
|
||||||
if fullname, err = config.LoadPB(m, "forge", "machine"); err != nil {
|
|
||||||
log.Info("zoopb.ConfigLoad() failed", err)
|
|
||||||
}
|
|
||||||
hostname, _ := os.Hostname()
|
|
||||||
m.Hostname = hostname
|
|
||||||
m.Distro = detectDistro()
|
|
||||||
m.initPackages()
|
|
||||||
|
|
||||||
m.InitWitMirrors()
|
|
||||||
config.SavePB(m, fullname)
|
|
||||||
|
|
||||||
return m, fullname
|
|
||||||
}
|
|
||||||
|
|
||||||
func InitDaemon() (*Machine, string) {
|
|
||||||
var fullname string
|
|
||||||
var err error
|
|
||||||
machine := new(Machine)
|
|
||||||
if fullname, err = config.LoadPB(machine, "/etc/zookeeper", "machine"); err != nil {
|
|
||||||
log.Info("zoopb.ConfigLoad() failed", err)
|
|
||||||
}
|
|
||||||
machine.InitWitMirrors()
|
|
||||||
config.SavePB(machine, fullname)
|
|
||||||
|
|
||||||
return machine, fullname
|
|
||||||
}
|
|
16
log.go
16
log.go
|
@ -1,16 +0,0 @@
|
||||||
package zoopb
|
|
||||||
|
|
||||||
import (
|
|
||||||
"go.wit.com/log"
|
|
||||||
)
|
|
||||||
|
|
||||||
var INFO *log.LogFlag
|
|
||||||
var WARN *log.LogFlag
|
|
||||||
|
|
||||||
func init() {
|
|
||||||
full := "go.wit.com/lib/protobuf/zoopb"
|
|
||||||
short := "zoopb"
|
|
||||||
|
|
||||||
INFO = log.NewFlag("INFO", false, full, short, "general forgepb things")
|
|
||||||
WARN = log.NewFlag("WARN", true, full, short, "zoopb warnings")
|
|
||||||
}
|
|
|
@ -7,8 +7,8 @@ import "google/protobuf/timestamp.proto"; // Import the well-known type for Time
|
||||||
|
|
||||||
// global settings for autogenpb `autogenpb:mutex`
|
// global settings for autogenpb `autogenpb:mutex`
|
||||||
|
|
||||||
message Machine { // `autogenpb:marshal` `autogenpb:http`
|
message Machine { // `autogenpb:marshal`
|
||||||
string hostname = 1; // `autogenpb:unique` `autogenpb:sort`
|
string hostname = 1; // `autogenpb:unique`
|
||||||
int64 memory = 2;
|
int64 memory = 2;
|
||||||
int64 cpus = 3;
|
int64 cpus = 3;
|
||||||
string distro = 4;
|
string distro = 4;
|
||||||
|
@ -17,14 +17,10 @@ message Machine { // `autogenpb:marshal`
|
||||||
Packages installed = 7; // packages that are installed
|
Packages installed = 7; // packages that are installed
|
||||||
Packages available = 8; // packages that are available
|
Packages available = 8; // packages that are available
|
||||||
Packages wit = 9; // packages that are available from mirrors.wit.com
|
Packages wit = 9; // packages that are available from mirrors.wit.com
|
||||||
string userAgent = 10;
|
|
||||||
string uuid = 11;
|
|
||||||
bool upgrade = 12; // upgrade is needed
|
|
||||||
string upgradeCmd = 13; // upgrade cmd
|
|
||||||
}
|
}
|
||||||
|
|
||||||
message Machines { // `autogenpb:marshal` `autogenpb:gui` `autogenpb:http`
|
message Machines { // `autogenpb:marshal`
|
||||||
string uuid = 1; // `autogenpb:uuid:b57e7fac-a8fc-4949-9d50-fa38312dec87`
|
string uuid = 1; // I guess why not just have this on each file
|
||||||
string version = 2; // `autogenpb:version:v0.0.1`
|
string version = 2; // maybe can be used for protobuf schema change violations
|
||||||
repeated Machine machines = 3;
|
repeated Machine machines = 3;
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,7 +8,7 @@ import "google/protobuf/timestamp.proto"; // Import the well-known type for Time
|
||||||
// global settings for autogenpb `autogenpb:mutex`
|
// global settings for autogenpb `autogenpb:mutex`
|
||||||
|
|
||||||
message Package {
|
message Package {
|
||||||
string name = 1; // `autogenpb:unique` `autogenpb:sort`
|
string name = 1; // `autogenpb:unique` // name: zookeeper-go
|
||||||
string version = 2; // version: 0.0.3
|
string version = 2; // version: 0.0.3
|
||||||
google.protobuf.Timestamp laststamp = 3; // the last time this package was seen (used to timeout entries)
|
google.protobuf.Timestamp laststamp = 3; // the last time this package was seen (used to timeout entries)
|
||||||
string srcPath = 4; // path to the sources (go.wit.com/apps/zookeeper)
|
string srcPath = 4; // path to the sources (go.wit.com/apps/zookeeper)
|
||||||
|
@ -17,7 +17,7 @@ message Package {
|
||||||
}
|
}
|
||||||
|
|
||||||
message Packages { // `autogenpb:marshal`
|
message Packages { // `autogenpb:marshal`
|
||||||
string uuid = 1; // `autogenpb:uuid:2f26cc03-ea30-4481-a333-ad0acc86e1d3`
|
string uuid = 1; // I guess why not just have this on each file
|
||||||
string version = 2; // `autogenpb:version:v0.0.1`
|
string version = 2; // maybe can be used for protobuf schema change violations
|
||||||
repeated Package packages = 3;
|
repeated Package packages = 3;
|
||||||
}
|
}
|
||||||
|
|
13
print.go
13
print.go
|
@ -1,13 +0,0 @@
|
||||||
package zoopb
|
|
||||||
|
|
||||||
import "go.wit.com/log"
|
|
||||||
|
|
||||||
// init the installed package list
|
|
||||||
func (m *Machine) Dump() {
|
|
||||||
log.Infof("mem=%d cpus=%d\n", m.Memory, m.Cpus)
|
|
||||||
|
|
||||||
// totalMemGB := float64(sysInfo.Totalram) * float64(sysInfo.Unit) / (1024 * 1024 * 1024)
|
|
||||||
// Print results
|
|
||||||
// fmt.Printf("Total Memory: %.2f GB\n", totalMemGB)
|
|
||||||
// fmt.Printf("Number of CPUs: %d\n", numCPUs)
|
|
||||||
}
|
|
43
wit.go
43
wit.go
|
@ -6,8 +6,14 @@ import (
|
||||||
"strings"
|
"strings"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
// sent via -ldflags
|
||||||
|
var VERSION string
|
||||||
|
var BUILDTIME string
|
||||||
|
|
||||||
func (m *Machine) IsInstalled(name string) bool {
|
func (m *Machine) IsInstalled(name string) bool {
|
||||||
for p := range m.Packages.IterByName() {
|
loop := m.Packages.SortByName()
|
||||||
|
for loop.Scan() {
|
||||||
|
p := loop.Next()
|
||||||
if name == p.Name {
|
if name == p.Name {
|
||||||
// log.Info("package installed:", p.Name, p.Version, p.PkgName)
|
// log.Info("package installed:", p.Name, p.Version, p.PkgName)
|
||||||
return true
|
return true
|
||||||
|
@ -19,13 +25,9 @@ func (m *Machine) IsInstalled(name string) bool {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *Machine) FindInstalledByName(name string) *Package {
|
func (m *Machine) FindInstalledByName(name string) *Package {
|
||||||
if m == nil {
|
loop := m.Packages.SortByName()
|
||||||
panic("m == nil")
|
for loop.Scan() {
|
||||||
}
|
p := loop.Next()
|
||||||
if m.Packages == nil {
|
|
||||||
panic("m.Packages == nil")
|
|
||||||
}
|
|
||||||
for p := range m.Packages.IterByName() {
|
|
||||||
if name == p.Name {
|
if name == p.Name {
|
||||||
// log.Info("package installed:", p.Name, p.Version, p.PkgName)
|
// log.Info("package installed:", p.Name, p.Version, p.PkgName)
|
||||||
return p
|
return p
|
||||||
|
@ -38,21 +40,11 @@ func (m *Machine) FindInstalledByName(name string) *Package {
|
||||||
|
|
||||||
// looks to see if any package matches a name and version
|
// looks to see if any package matches a name and version
|
||||||
// if version == "", return the first name found
|
// if version == "", return the first name found
|
||||||
func (m *Machine) FindVersion(name string) string {
|
func (m *Machine) FindVersion(name string, version string) *Package {
|
||||||
// first check all installed versions
|
// first check all installed versions
|
||||||
for p := range m.Packages.IterByName() {
|
loop := m.Packages.SortByName()
|
||||||
if name == p.Name {
|
for loop.Scan() {
|
||||||
return p.Version
|
p := loop.Next()
|
||||||
}
|
|
||||||
}
|
|
||||||
return ""
|
|
||||||
}
|
|
||||||
|
|
||||||
// looks to see if any package matches a name and version
|
|
||||||
// if version == "", return the first name found
|
|
||||||
func (m *Machine) FindByVersion(name string, version string) *Package {
|
|
||||||
// first check all installed versions
|
|
||||||
for p := range m.Packages.IterByName() {
|
|
||||||
if name == p.Name {
|
if name == p.Name {
|
||||||
if version == "" {
|
if version == "" {
|
||||||
return p
|
return p
|
||||||
|
@ -65,7 +57,9 @@ func (m *Machine) FindByVersion(name string, version string) *Package {
|
||||||
}
|
}
|
||||||
|
|
||||||
// check all wit packages
|
// check all wit packages
|
||||||
for p := range m.Wit.IterByName() {
|
loop = m.Wit.SortByName()
|
||||||
|
for loop.Scan() {
|
||||||
|
p := loop.Next()
|
||||||
if name == p.Name {
|
if name == p.Name {
|
||||||
if version == "" {
|
if version == "" {
|
||||||
return p
|
return p
|
||||||
|
@ -82,8 +76,7 @@ func (m *Machine) FindByVersion(name string, version string) *Package {
|
||||||
}
|
}
|
||||||
|
|
||||||
// read the package list file from mirrors.wit.com
|
// read the package list file from mirrors.wit.com
|
||||||
// obviously a hack at this point
|
func (m *Machine) InitWit() error {
|
||||||
func (m *Machine) InitWitMirrors() error {
|
|
||||||
if m.Wit == nil {
|
if m.Wit == nil {
|
||||||
m.Wit = new(Packages)
|
m.Wit = new(Packages)
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue