creating new build system

This commit is contained in:
2025-10-23 23:04:35 -03:00
parent b58173837b
commit 6377de7208
6 changed files with 143 additions and 7 deletions

View File

@@ -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,

View File

@@ -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
View 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
}

View File

@@ -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))

View File

@@ -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

View File

@@ -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))