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