All checks were successful
Test / Create distribution (push) Successful in 47s
Test / Sandbox (push) Successful in 2m41s
Test / Hakurei (push) Successful in 3m57s
Test / ShareFS (push) Successful in 3m59s
Test / Hpkg (push) Successful in 4m36s
Test / Sandbox (race detector) (push) Successful in 5m0s
Test / Hakurei (race detector) (push) Successful in 5m57s
Test / Flake checks (push) Successful in 1m52s
This is used by some programs and will likely end up in the Rosa OS system image anyway. Signed-off-by: Ophestra <cat@gensokyo.uk>
116 lines
2.5 KiB
Go
116 lines
2.5 KiB
Go
package rosa
|
|
|
|
import (
|
|
"errors"
|
|
"io"
|
|
"os"
|
|
"syscall"
|
|
|
|
"hakurei.app/internal/pkg"
|
|
)
|
|
|
|
// cureEtc contains deterministic elements of /etc, made available as part of
|
|
// [Toolchain]. This silences test suites expecting certain standard files to be
|
|
// available in /etc.
|
|
type cureEtc struct {
|
|
// Optional via newIANAEtc.
|
|
iana pkg.Artifact
|
|
}
|
|
|
|
// Cure writes hardcoded configuration to files under etc.
|
|
func (a cureEtc) Cure(t *pkg.FContext) (err error) {
|
|
etc := t.GetWorkDir().Append("etc")
|
|
if err = os.MkdirAll(etc.String(), 0700); err != nil {
|
|
return
|
|
}
|
|
for _, f := range [][2]string{
|
|
{"hosts", "127.0.0.1 localhost cure cure-net\n"},
|
|
{"passwd", `root:x:0:0:System administrator:/proc/nonexistent:/bin/sh
|
|
cure:x:1023:1023:Cure:/usr/src:/bin/sh
|
|
nobody:x:65534:65534:Overflow user:/proc/nonexistent:/system/bin/false
|
|
`},
|
|
{"group", `root:x:0:
|
|
cure:x:1023:
|
|
nobody:x:65534:
|
|
`},
|
|
} {
|
|
if err = os.WriteFile(
|
|
etc.Append(f[0]).String(),
|
|
[]byte(f[1]),
|
|
0400,
|
|
); err != nil {
|
|
return
|
|
}
|
|
}
|
|
|
|
if a.iana != nil {
|
|
iana, _ := t.GetArtifact(a.iana)
|
|
|
|
buf := make([]byte, syscall.Getpagesize()<<3)
|
|
for _, name := range []string{
|
|
"protocols",
|
|
"services",
|
|
} {
|
|
var dst, src *os.File
|
|
if dst, err = os.OpenFile(
|
|
etc.Append(name).String(),
|
|
syscall.O_CREAT|syscall.O_EXCL|syscall.O_WRONLY,
|
|
0400,
|
|
); err != nil {
|
|
return
|
|
}
|
|
|
|
if src, err = os.Open(
|
|
iana.Append(name).String(),
|
|
); err != nil {
|
|
_ = dst.Close()
|
|
return
|
|
}
|
|
|
|
_, err = io.CopyBuffer(dst, src, buf)
|
|
closeErrs := [...]error{
|
|
dst.Close(),
|
|
src.Close(),
|
|
}
|
|
if err != nil {
|
|
return
|
|
} else if err = errors.Join(closeErrs[:]...); err != nil {
|
|
return
|
|
}
|
|
}
|
|
}
|
|
|
|
return os.Chmod(etc.String(), 0500)
|
|
}
|
|
|
|
// Kind returns the hardcoded [pkg.Kind] value.
|
|
func (cureEtc) Kind() pkg.Kind { return kindEtc }
|
|
|
|
// Params is a noop.
|
|
func (cureEtc) Params(*pkg.IContext) {}
|
|
|
|
// Dependencies returns a slice containing the backing iana-etc release.
|
|
func (a cureEtc) Dependencies() []pkg.Artifact {
|
|
if a.iana != nil {
|
|
return []pkg.Artifact{a.iana}
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// String returns a hardcoded reporting name.
|
|
func (cureEtc) String() string { return "cure-etc" }
|
|
|
|
// newIANAEtc returns an unpacked iana-etc release.
|
|
func newIANAEtc() pkg.Artifact {
|
|
const (
|
|
version = "20251215"
|
|
checksum = "kvKz0gW_rGG5QaNK9ZWmWu1IEgYAdmhj_wR7DYrh3axDfIql_clGRHmelP7525NJ"
|
|
)
|
|
return pkg.NewHTTPGetTar(
|
|
nil, "https://github.com/Mic92/iana-etc/releases/download/"+
|
|
version+"/iana-etc-"+version+".tar.gz",
|
|
mustDecode(checksum),
|
|
pkg.TarGzip,
|
|
)
|
|
}
|