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