1
0
mirror of https://github.com/containers/buildah.git synced 2025-09-17 15:42:18 +03:00
Files
buildah/chroot/seccomp_test.go
2025-08-29 15:04:28 +02:00

38 lines
930 B
Go

//go:build linux && seccomp
package chroot
import (
"fmt"
"os"
specs "github.com/opencontainers/runtime-spec/specs-go"
"go.podman.io/common/pkg/seccomp"
)
const seccompAvailable = true
func setupSeccomp(spec *specs.Spec, seccompProfilePath string) error {
switch seccompProfilePath {
case "unconfined":
spec.Linux.Seccomp = nil
case "":
seccompConfig, err := seccomp.GetDefaultProfile(spec)
if err != nil {
return fmt.Errorf("loading default seccomp profile failed: %w", err)
}
spec.Linux.Seccomp = seccompConfig
default:
seccompProfile, err := os.ReadFile(seccompProfilePath)
if err != nil {
return fmt.Errorf("opening seccomp profile failed: %w", err)
}
seccompConfig, err := seccomp.LoadProfile(string(seccompProfile), spec)
if err != nil {
return fmt.Errorf("loading seccomp profile (%s) failed: %w", seccompProfilePath, err)
}
spec.Linux.Seccomp = seccompConfig
}
return nil
}