creating new build system
This commit is contained in:
@@ -649,7 +649,7 @@ func UpgradeToThis(id string, installPath string, installedDB *sql.DB, storePkgF
|
|||||||
serial = ?, package_d = ?, filename = ?, os = ?, arch = ?, in_cache = ?
|
serial = ?, package_d = ?, filename = ?, os = ?, arch = ?, in_cache = ?
|
||||||
`,
|
`,
|
||||||
p.QueryName,
|
p.QueryName,
|
||||||
p.Manifest.Info.Id,
|
p.Manifest.Package.Id,
|
||||||
p.Version,
|
p.Version,
|
||||||
p.Description,
|
p.Description,
|
||||||
p.Serial,
|
p.Serial,
|
||||||
|
|||||||
@@ -1,17 +1,21 @@
|
|||||||
package configs
|
package configs
|
||||||
|
|
||||||
type Manifest struct {
|
type Manifest struct {
|
||||||
Info struct {
|
Package struct {
|
||||||
Name string `toml:"name"`
|
Name string `toml:"name"`
|
||||||
Id string `toml:"id"`
|
Id string `toml:"id"`
|
||||||
Version string `toml:"version"`
|
Version string `toml:"version"`
|
||||||
Description string `toml:"description"`
|
Description string `toml:"description"`
|
||||||
Dependencies map[string]string `toml:"dependencies"`
|
Dependencies map[string]string `toml:"dependencies"`
|
||||||
Author string `toml:"author"`
|
Author string `toml:"author"`
|
||||||
} `toml:"Info"`
|
} `toml:"Package"`
|
||||||
|
Build struct {
|
||||||
|
BuildDependencies map[string]string `toml:"dependencies"`
|
||||||
|
}
|
||||||
Hooks struct {
|
Hooks struct {
|
||||||
Install string `toml:"install"`
|
Install string `toml:"install"`
|
||||||
Remove string `toml:"remove"`
|
Remove string `toml:"remove"`
|
||||||
|
Build string `toml:"build"`
|
||||||
} `toml:"Hooks"`
|
} `toml:"Hooks"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
129
internal/build/main.go
Normal file
129
internal/build/main.go
Normal file
@@ -0,0 +1,129 @@
|
|||||||
|
package build
|
||||||
|
|
||||||
|
import (
|
||||||
|
"io"
|
||||||
|
"os"
|
||||||
|
"packets/configs"
|
||||||
|
utils_lua "packets/internal/utils/lua"
|
||||||
|
"path/filepath"
|
||||||
|
|
||||||
|
"github.com/spf13/afero"
|
||||||
|
lua "github.com/yuin/gopher-lua"
|
||||||
|
)
|
||||||
|
|
||||||
|
type Container struct {
|
||||||
|
Root string
|
||||||
|
FS afero.Fs
|
||||||
|
DataDir string
|
||||||
|
Manifest configs.Manifest
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewContainer(Root string, dataDir string, manifest configs.Manifest) (Container, error) {
|
||||||
|
|
||||||
|
var container Container
|
||||||
|
baseFs := afero.NewOsFs()
|
||||||
|
fileSystem := afero.NewBasePathFs(baseFs, Root)
|
||||||
|
|
||||||
|
container.Root = Root
|
||||||
|
container.Manifest = manifest
|
||||||
|
container.DataDir = dataDir
|
||||||
|
container.FS = fileSystem
|
||||||
|
|
||||||
|
if err := container.CopyHostToContainer(dataDir, "/data"); err != nil {
|
||||||
|
return Container{}, err
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := container.FS.MkdirAll("/usr/bin", 0777); err != nil {
|
||||||
|
return Container{}, err
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := afero.Symlinker.SymlinkIfPossible(container.FS.(afero.Symlinker), "/usr/bin", "/bin"); err != nil {
|
||||||
|
return Container{}, err
|
||||||
|
}
|
||||||
|
|
||||||
|
return container, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (container Container) CopyHostToContainer(src string, dest string) error {
|
||||||
|
stats, err := os.Stat(src)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
if stats.IsDir() {
|
||||||
|
files, err := os.ReadDir(src)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := container.FS.MkdirAll(dest, 0755); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, file := range files {
|
||||||
|
srcPath := filepath.Join(src, file.Name())
|
||||||
|
destPath := filepath.Join(dest, file.Name())
|
||||||
|
|
||||||
|
if file.IsDir() {
|
||||||
|
if err := container.CopyHostToContainer(srcPath, destPath); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := container.copySingleFile(srcPath, destPath); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if err := container.copySingleFile(src, dest); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (container Container) copySingleFile(source string, destination string) error {
|
||||||
|
src, err := os.Open(source)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
defer src.Close()
|
||||||
|
|
||||||
|
stats, err := src.Stat()
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
if err := container.FS.MkdirAll(filepath.Dir(destination), 0755); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
dst, err := container.FS.Create(destination)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
defer dst.Close()
|
||||||
|
|
||||||
|
if _, err := io.Copy(dst, src); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := container.FS.Chmod(destination, stats.Mode()); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (container Container) RunBuild() error {
|
||||||
|
|
||||||
|
L, err := utils_lua.GetSandBox()
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
L.SetGlobal("data_dir", lua.LString(container.DataDir))
|
||||||
|
L.SetGlobal("script", lua.LString(container.Manifest.Hooks.Build))
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
@@ -14,7 +14,6 @@ func GetSandBox() (lua.LState, error) {
|
|||||||
}
|
}
|
||||||
L := lua.NewState()
|
L := lua.NewState()
|
||||||
osObject := L.GetGlobal("os").(*lua.LTable)
|
osObject := L.GetGlobal("os").(*lua.LTable)
|
||||||
|
|
||||||
L.SetGlobal("SAFE_MODE", lua.LTrue)
|
L.SetGlobal("SAFE_MODE", lua.LTrue)
|
||||||
|
|
||||||
L.SetGlobal("PACKETS_DATADIR", lua.LString(cfg.Config.Data_d))
|
L.SetGlobal("PACKETS_DATADIR", lua.LString(cfg.Config.Data_d))
|
||||||
|
|||||||
@@ -210,7 +210,7 @@ func (p *Package) AddToInstalledDB(inCache int, packagePath string) error {
|
|||||||
|
|
||||||
defer func() {
|
defer func() {
|
||||||
if !success {
|
if !success {
|
||||||
_, err := db.Exec("DELETE FROM packages WHERE id = ?", p.Manifest.Info.Id)
|
_, err := db.Exec("DELETE FROM packages WHERE id = ?", p.Manifest.Package.Id)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Println("failed to rollback package addition:", err)
|
log.Println("failed to rollback package addition:", err)
|
||||||
}
|
}
|
||||||
@@ -223,7 +223,7 @@ func (p *Package) AddToInstalledDB(inCache int, packagePath string) error {
|
|||||||
serial, package_d, filename, os, arch, in_cache
|
serial, package_d, filename, os, arch, in_cache
|
||||||
) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`,
|
) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`,
|
||||||
p.QueryName,
|
p.QueryName,
|
||||||
p.Manifest.Info.Id,
|
p.Manifest.Package.Id,
|
||||||
p.Version,
|
p.Version,
|
||||||
p.Description,
|
p.Description,
|
||||||
p.Serial,
|
p.Serial,
|
||||||
@@ -238,7 +238,7 @@ func (p *Package) AddToInstalledDB(inCache int, packagePath string) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
for depnName, versionConstraint := range p.Dependencies {
|
for depnName, versionConstraint := range p.Dependencies {
|
||||||
_, err = db.Exec("INSERT INTO package_dependencies (package_id, dependency_name, version_constraint) VALUES (?, ?, ?)", p.Manifest.Info.Id, depnName, versionConstraint)
|
_, err = db.Exec("INSERT INTO package_dependencies (package_id, dependency_name, version_constraint) VALUES (?, ?, ?)", p.Manifest.Package.Id, depnName, versionConstraint)
|
||||||
}
|
}
|
||||||
|
|
||||||
success = true
|
success = true
|
||||||
|
|||||||
@@ -113,6 +113,10 @@ func InstallPackage(file []byte, destDir string) error {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
L.SetGlobal("data_dir", lua.LString(filepath.Join(destDir, "data")))
|
||||||
|
L.SetGlobal("script", lua.LString(manifest.Hooks.Build))
|
||||||
|
|
||||||
L.SetGlobal("data_dir", lua.LString(filepath.Join(destDir, "data")))
|
L.SetGlobal("data_dir", lua.LString(filepath.Join(destDir, "data")))
|
||||||
L.SetGlobal("script", lua.LString(manifest.Hooks.Install))
|
L.SetGlobal("script", lua.LString(manifest.Hooks.Install))
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user