All checks were successful
Test / Create distribution (push) Successful in 35s
Test / Sandbox (push) Successful in 2m22s
Test / Hpkg (push) Successful in 4m2s
Test / Sandbox (race detector) (push) Successful in 4m28s
Test / Hakurei (race detector) (push) Successful in 5m21s
Test / Hakurei (push) Successful in 2m9s
Test / Flake checks (push) Successful in 1m29s
This package is quite useful. This change allows it to be imported without importing container. Signed-off-by: Ophestra <cat@gensokyo.uk>
52 lines
1.7 KiB
Go
52 lines
1.7 KiB
Go
package container
|
|
|
|
import (
|
|
"bytes"
|
|
"os"
|
|
"strconv"
|
|
"sync"
|
|
|
|
"hakurei.app/container/fhs"
|
|
"hakurei.app/message"
|
|
)
|
|
|
|
var (
|
|
kernelOverflowuid int
|
|
kernelOverflowgid int
|
|
kernelCapLastCap int
|
|
|
|
sysctlOnce sync.Once
|
|
)
|
|
|
|
const (
|
|
kernelOverflowuidPath = fhs.ProcSys + "kernel/overflowuid"
|
|
kernelOverflowgidPath = fhs.ProcSys + "kernel/overflowgid"
|
|
kernelCapLastCapPath = fhs.ProcSys + "kernel/cap_last_cap"
|
|
)
|
|
|
|
func mustReadSysctl(msg message.Msg) {
|
|
sysctlOnce.Do(func() {
|
|
if v, err := os.ReadFile(kernelOverflowuidPath); err != nil {
|
|
msg.GetLogger().Fatalf("cannot read %q: %v", kernelOverflowuidPath, err)
|
|
} else if kernelOverflowuid, err = strconv.Atoi(string(bytes.TrimSpace(v))); err != nil {
|
|
msg.GetLogger().Fatalf("cannot interpret %q: %v", kernelOverflowuidPath, err)
|
|
}
|
|
|
|
if v, err := os.ReadFile(kernelOverflowgidPath); err != nil {
|
|
msg.GetLogger().Fatalf("cannot read %q: %v", kernelOverflowgidPath, err)
|
|
} else if kernelOverflowgid, err = strconv.Atoi(string(bytes.TrimSpace(v))); err != nil {
|
|
msg.GetLogger().Fatalf("cannot interpret %q: %v", kernelOverflowgidPath, err)
|
|
}
|
|
|
|
if v, err := os.ReadFile(kernelCapLastCapPath); err != nil {
|
|
msg.GetLogger().Fatalf("cannot read %q: %v", kernelCapLastCapPath, err)
|
|
} else if kernelCapLastCap, err = strconv.Atoi(string(bytes.TrimSpace(v))); err != nil {
|
|
msg.GetLogger().Fatalf("cannot interpret %q: %v", kernelCapLastCapPath, err)
|
|
}
|
|
})
|
|
}
|
|
|
|
func OverflowUid(msg message.Msg) int { mustReadSysctl(msg); return kernelOverflowuid }
|
|
func OverflowGid(msg message.Msg) int { mustReadSysctl(msg); return kernelOverflowgid }
|
|
func LastCap(msg message.Msg) uintptr { mustReadSysctl(msg); return uintptr(kernelCapLastCap) }
|