cmd/mbf: migrate shell to enter
Test / Create distribution (push) Successful in 57s
Test / Sandbox (push) Successful in 2m54s
Test / ShareFS (push) Successful in 3m56s
Test / Hakurei (push) Successful in 4m3s
Test / Sandbox (race detector) (push) Successful in 5m39s
Test / Hakurei (race detector) (push) Successful in 6m40s
Test / Flake checks (push) Successful in 1m12s
Test / Create distribution (push) Successful in 57s
Test / Sandbox (push) Successful in 2m54s
Test / ShareFS (push) Successful in 3m56s
Test / Hakurei (push) Successful in 4m3s
Test / Sandbox (race detector) (push) Successful in 5m39s
Test / Hakurei (race detector) (push) Successful in 6m40s
Test / Flake checks (push) Successful in 1m12s
This reduces duplicate code. This change also adds resolv.conf to the container. Signed-off-by: Ophestra <cat@gensokyo.uk>
This commit is contained in:
+44
-111
@@ -32,12 +32,11 @@ import (
|
|||||||
"syscall"
|
"syscall"
|
||||||
"time"
|
"time"
|
||||||
"unique"
|
"unique"
|
||||||
|
"unsafe"
|
||||||
|
|
||||||
"hakurei.app/check"
|
"hakurei.app/check"
|
||||||
"hakurei.app/command"
|
"hakurei.app/command"
|
||||||
"hakurei.app/container"
|
"hakurei.app/container"
|
||||||
"hakurei.app/container/seccomp"
|
|
||||||
"hakurei.app/container/std"
|
|
||||||
"hakurei.app/ext"
|
"hakurei.app/ext"
|
||||||
"hakurei.app/fhs"
|
"hakurei.app/fhs"
|
||||||
"hakurei.app/internal/pkg"
|
"hakurei.app/internal/pkg"
|
||||||
@@ -731,7 +730,7 @@ func main() {
|
|||||||
return cache.EnterExec(
|
return cache.EnterExec(
|
||||||
ctx,
|
ctx,
|
||||||
a,
|
a,
|
||||||
true, os.Stdin, os.Stdout, os.Stderr,
|
"", true, os.Stdin, os.Stdout, os.Stderr,
|
||||||
rosa.AbsSystem.Append("bin", "mksh"),
|
rosa.AbsSystem.Append("bin", "mksh"),
|
||||||
"sh",
|
"sh",
|
||||||
)
|
)
|
||||||
@@ -934,6 +933,17 @@ func main() {
|
|||||||
"shell",
|
"shell",
|
||||||
"Interactive shell in the specified Rosa OS environment",
|
"Interactive shell in the specified Rosa OS environment",
|
||||||
func(args []string) error {
|
func(args []string) error {
|
||||||
|
resolvconf := "nameserver 1.1.1.1\nnameserver 1.0.0.1\n"
|
||||||
|
if p, err := os.ReadFile(fhs.AbsEtc.Append(
|
||||||
|
"resolv.conf",
|
||||||
|
).String()); err != nil {
|
||||||
|
if !errors.Is(err, os.ErrNotExist) {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
resolvconf = unsafe.String(unsafe.SliceData(p), len(p))
|
||||||
|
}
|
||||||
|
|
||||||
handles := make([]rosa.ArtifactH, len(args), len(args)+3)
|
handles := make([]rosa.ArtifactH, len(args), len(args)+3)
|
||||||
for i, arg := range args {
|
for i, arg := range args {
|
||||||
handles[i] = rosa.ArtifactH(unique.Make(arg))
|
handles[i] = rosa.ArtifactH(unique.Make(arg))
|
||||||
@@ -953,119 +963,42 @@ func main() {
|
|||||||
)
|
)
|
||||||
|
|
||||||
root := make(pkg.Collect, 0, 6+len(args))
|
root := make(pkg.Collect, 0, 6+len(args))
|
||||||
|
root = append(root, rosa.NewEtc(false))
|
||||||
root = rosa.Native().Std().Append(root, handles...)
|
root = rosa.Native().Std().Append(root, handles...)
|
||||||
|
|
||||||
if err := cm.Do(func(cache *pkg.Cache) error {
|
return cm.Do(func(cache *pkg.Cache) error {
|
||||||
_, _, err := cache.Cure(&root)
|
return cache.EnterExec(
|
||||||
return err
|
ctx,
|
||||||
}); err == nil {
|
pkg.NewExec(
|
||||||
return errors.New("unreachable")
|
"",
|
||||||
} else if !pkg.IsCollected(err) {
|
rosa.Native().Arch(),
|
||||||
return err
|
new(pkg.Checksum),
|
||||||
}
|
1,
|
||||||
|
flagNet,
|
||||||
type cureRes struct {
|
false,
|
||||||
pathname *check.Absolute
|
fhs.AbsRoot,
|
||||||
checksum unique.Handle[pkg.Checksum]
|
[]string{
|
||||||
}
|
|
||||||
cured := make(map[pkg.Artifact]cureRes)
|
|
||||||
for _, a := range root {
|
|
||||||
if err := cm.Do(func(cache *pkg.Cache) error {
|
|
||||||
pathname, checksum, err := cache.Cure(a)
|
|
||||||
if err == nil {
|
|
||||||
cured[a] = cureRes{pathname, checksum}
|
|
||||||
}
|
|
||||||
return err
|
|
||||||
}); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// explicitly open for direct error-free use from this point
|
|
||||||
if cm.c == nil {
|
|
||||||
if err := cm.open(); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
layers := pkg.PromoteLayers(root, func(a pkg.Artifact) (
|
|
||||||
*check.Absolute,
|
|
||||||
unique.Handle[pkg.Checksum],
|
|
||||||
) {
|
|
||||||
res := cured[a]
|
|
||||||
return res.pathname, res.checksum
|
|
||||||
}, func(i int, d pkg.Artifact) {
|
|
||||||
r := pkg.Encode(cm.c.Ident(d).Value())
|
|
||||||
if s, ok := d.(fmt.Stringer); ok {
|
|
||||||
if name := s.String(); name != "" {
|
|
||||||
r += "-" + name
|
|
||||||
}
|
|
||||||
}
|
|
||||||
msg.Verbosef("promoted layer %d as %s", i, r)
|
|
||||||
})
|
|
||||||
|
|
||||||
z := container.New(ctx, msg)
|
|
||||||
z.WaitDelay = 3 * time.Second
|
|
||||||
z.SeccompPresets = pkg.SeccompPresets
|
|
||||||
z.SeccompFlags |= seccomp.AllowMultiarch
|
|
||||||
z.ParentPerm = 0700
|
|
||||||
z.HostNet = flagNet
|
|
||||||
z.RetainSession = flagSession
|
|
||||||
z.Hostname = "localhost"
|
|
||||||
z.Uid, z.Gid = (1<<10)-1, (1<<10)-1
|
|
||||||
z.Stdin, z.Stdout, z.Stderr = os.Stdin, os.Stdout, os.Stderr
|
|
||||||
z.Quiet = !cm.verboseInit
|
|
||||||
if s, ok := os.LookupEnv("TERM"); ok {
|
|
||||||
z.Env = append(z.Env, "TERM="+s)
|
|
||||||
}
|
|
||||||
|
|
||||||
var tempdir *check.Absolute
|
|
||||||
if s, err := filepath.Abs(os.TempDir()); err != nil {
|
|
||||||
return err
|
|
||||||
} else if tempdir, err = check.NewAbs(s); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
z.Dir = fhs.AbsRoot
|
|
||||||
z.Env = []string{
|
|
||||||
"SHELL=/system/bin/mksh",
|
"SHELL=/system/bin/mksh",
|
||||||
"PATH=/system/bin",
|
"PATH=/system/bin",
|
||||||
"HOME=/",
|
"HOME=/",
|
||||||
}
|
},
|
||||||
z.Path = rosa.AbsSystem.Append("bin", "mksh")
|
fhs.AbsProc.Append("nonexistent"),
|
||||||
z.Args = []string{"mksh"}
|
nil,
|
||||||
z.
|
pkg.Path(fhs.AbsRoot, true, root...),
|
||||||
OverlayEphemeral(fhs.AbsRoot, layers...).
|
pkg.Path(
|
||||||
Place(
|
fhs.AbsEtc.Append("resolv.conf"), false,
|
||||||
fhs.AbsEtc.Append("hosts"),
|
pkg.NewFile(
|
||||||
[]byte("127.0.0.1 localhost\n"),
|
"resolv.conf",
|
||||||
).
|
unsafe.Slice(unsafe.StringData(resolvconf), len(resolvconf)),
|
||||||
Place(
|
),
|
||||||
fhs.AbsEtc.Append("passwd"),
|
),
|
||||||
[]byte("media_rw:x:1023:1023::/:/system/bin/sh\n"+
|
),
|
||||||
"nobody:x:65534:65534::/proc/nonexistent:/system/bin/false\n"),
|
"localhost",
|
||||||
).
|
flagSession, os.Stdin, os.Stdout, os.Stderr,
|
||||||
Place(
|
rosa.AbsSystem.Append("bin", "mksh"),
|
||||||
fhs.AbsEtc.Append("group"),
|
"sh",
|
||||||
[]byte("media_rw:x:1023:\nnobody:x:65534:\n"),
|
)
|
||||||
).
|
})
|
||||||
Bind(tempdir, fhs.AbsTmp, std.BindWritable).
|
|
||||||
Proc(fhs.AbsProc).Dev(fhs.AbsDev, true)
|
|
||||||
|
|
||||||
if flagArch != "" && flagArch != runtime.GOARCH {
|
|
||||||
if entry, ok := pkg.Arch()[flagArch]; ok {
|
|
||||||
z.InitAsRoot = true
|
|
||||||
z.Binfmt = []container.BinfmtEntry{entry}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if err := z.Start(); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
if err := z.Serve(); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
return z.Wait()
|
|
||||||
},
|
},
|
||||||
).Flag(
|
).Flag(
|
||||||
&flagNet,
|
&flagNet,
|
||||||
|
|||||||
@@ -591,6 +591,7 @@ var (
|
|||||||
func (c *Cache) EnterExec(
|
func (c *Cache) EnterExec(
|
||||||
ctx context.Context,
|
ctx context.Context,
|
||||||
a Artifact,
|
a Artifact,
|
||||||
|
hostname string,
|
||||||
retainSession bool,
|
retainSession bool,
|
||||||
stdin io.Reader,
|
stdin io.Reader,
|
||||||
stdout, stderr io.Writer,
|
stdout, stderr io.Writer,
|
||||||
@@ -671,6 +672,9 @@ func (c *Cache) EnterExec(
|
|||||||
z.Env = append(z.Env, "TERM="+s)
|
z.Env = append(z.Env, "TERM="+s)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if hostname != "" {
|
||||||
|
z.Hostname = hostname
|
||||||
|
}
|
||||||
|
|
||||||
if err = z.Start(); err != nil {
|
if err = z.Start(); err != nil {
|
||||||
return
|
return
|
||||||
|
|||||||
Reference in New Issue
Block a user