Track installed packages
This commit is contained in:
parent
78ebdd60ae
commit
ba1b8c4706
70
db/installed.go
Normal file
70
db/installed.go
Normal file
@ -0,0 +1,70 @@
|
|||||||
|
package db
|
||||||
|
|
||||||
|
import (
|
||||||
|
"encoding/json"
|
||||||
|
"os"
|
||||||
|
"path/filepath"
|
||||||
|
|
||||||
|
"github.com/pkg/errors"
|
||||||
|
"mcquay.me/fs"
|
||||||
|
"mcquay.me/pm"
|
||||||
|
)
|
||||||
|
|
||||||
|
const in = "var/lib/pm/installed.json"
|
||||||
|
|
||||||
|
// AddInstalled adds m to the installed package database.
|
||||||
|
func AddInstalled(root string, m pm.Meta) error {
|
||||||
|
db, err := loadi(root)
|
||||||
|
if err != nil {
|
||||||
|
return errors.Wrap(err, "loading installed db")
|
||||||
|
}
|
||||||
|
db[m.Name] = m
|
||||||
|
return savei(root, db)
|
||||||
|
}
|
||||||
|
|
||||||
|
// IsInstalled checks if m is in the installed package database.
|
||||||
|
func IsInstalled(root string, m pm.Meta) (bool, error) {
|
||||||
|
db, err := loadi(root)
|
||||||
|
if err != nil {
|
||||||
|
return false, errors.Wrap(err, "loading installed db")
|
||||||
|
}
|
||||||
|
|
||||||
|
_, r := db[m.Name]
|
||||||
|
return r, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func loadi(root string) (pm.Installed, error) {
|
||||||
|
r := pm.Installed{}
|
||||||
|
dbn := filepath.Join(root, in)
|
||||||
|
|
||||||
|
if !fs.Exists(dbn) {
|
||||||
|
return r, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
f, err := os.Open(dbn)
|
||||||
|
if err != nil {
|
||||||
|
return r, errors.Wrap(err, "open")
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := json.NewDecoder(f).Decode(&r); err != nil {
|
||||||
|
return r, errors.Wrap(err, "decoding db")
|
||||||
|
}
|
||||||
|
|
||||||
|
return r, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func savei(root string, db pm.Installed) error {
|
||||||
|
f, err := os.Create(filepath.Join(root, in))
|
||||||
|
if err != nil {
|
||||||
|
return errors.Wrap(err, "create")
|
||||||
|
}
|
||||||
|
enc := json.NewEncoder(f)
|
||||||
|
enc.SetIndent("", "\t")
|
||||||
|
if err := enc.Encode(&db); err != nil {
|
||||||
|
return errors.Wrap(err, "decoding db")
|
||||||
|
}
|
||||||
|
if err := f.Close(); err != nil {
|
||||||
|
return errors.Wrap(err, "close db")
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
4
installed.go
Normal file
4
installed.go
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
package pm
|
||||||
|
|
||||||
|
// Installed tracks installed packages.
|
||||||
|
type Installed map[Name]Meta
|
@ -60,6 +60,13 @@ func Install(root string, pkgs []string) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
for _, m := range ms {
|
for _, m := range ms {
|
||||||
|
already, err := db.IsInstalled(root, m)
|
||||||
|
if err != nil {
|
||||||
|
return errors.Wrapf(err, "is installed %v", m.Name)
|
||||||
|
}
|
||||||
|
if already {
|
||||||
|
return errors.Errorf("%v already installed!", m.Name)
|
||||||
|
}
|
||||||
if err := verifyManifestIntegrity(root, m); err != nil {
|
if err := verifyManifestIntegrity(root, m); err != nil {
|
||||||
return errors.Wrap(err, "verifying pkg integrity")
|
return errors.Wrap(err, "verifying pkg integrity")
|
||||||
}
|
}
|
||||||
@ -85,6 +92,10 @@ func Install(root string, pkgs []string) error {
|
|||||||
if err := os.Remove(filepath.Join(cacheDir, m.Pkg())); err != nil {
|
if err := os.Remove(filepath.Join(cacheDir, m.Pkg())); err != nil {
|
||||||
return errors.Wrapf(err, "cleaning up pkg %v", m.Pkg())
|
return errors.Wrapf(err, "cleaning up pkg %v", m.Pkg())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if err := db.AddInstalled(root, m); err != nil {
|
||||||
|
return errors.Wrapf(err, "adding ", m.Name)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user