Files
Dark Steveneq 646b892680
Some checks failed
Periodic Merges (6h) / master → staging-nixos (push) Failing after 12m50s
Periodic Merges (6h) / master → staging-next (push) Failing after 12m54s
Periodic Merges (24h) / merge-base(master,staging) → haskell-updates (push) Failing after 11m54s
Periodic Merges (6h) / staging-next → staging (push) Failing after 12m13s
Periodic Merges (24h) / staging-next-25.05 → staging-25.05 (push) Failing after 13m24s
Periodic Merges (24h) / release-25.05 → staging-next-25.05 (push) Failing after 14m28s
push sheeet
2025-10-09 14:15:47 +02:00

144 lines
2.8 KiB
Nix

{
lib,
writeText,
runCommand,
writeClosure,
}:
{
buildContainer =
{
args,
mounts ? { },
os ? "linux",
arch ? "x86_64",
readonly ? false,
}:
let
sysMounts = {
"/proc" = {
type = "proc";
source = "proc";
};
"/dev" = {
type = "tmpfs";
source = "tmpfs";
options = [
"nosuid"
"strictatime"
"mode=755"
"size=65536k"
];
};
"/dev/pts" = {
type = "devpts";
source = "devpts";
options = [
"nosuid"
"noexec"
"newinstance"
"ptmxmode=0666"
"mode=755"
"gid=5"
];
};
"/dev/shm" = {
type = "tmpfs";
source = "shm";
options = [
"nosuid"
"noexec"
"nodev"
"mode=1777"
"size=65536k"
];
};
"/dev/mqueue" = {
type = "mqueue";
source = "mqueue";
options = [
"nosuid"
"noexec"
"nodev"
];
};
"/sys" = {
type = "sysfs";
source = "sysfs";
options = [
"nosuid"
"noexec"
"nodev"
"ro"
];
};
"/sys/fs/cgroup" = {
type = "cgroup";
source = "cgroup";
options = [
"nosuid"
"noexec"
"nodev"
"relatime"
"ro"
];
};
};
config = writeText "config.json" (
builtins.toJSON {
ociVersion = "1.0.0";
platform = {
inherit os arch;
};
linux = {
namespaces = map (type: { inherit type; }) [
"pid"
"network"
"mount"
"ipc"
"uts"
];
};
root = {
path = "rootfs";
inherit readonly;
};
process = {
inherit args;
user = {
uid = 0;
gid = 0;
};
cwd = "/";
};
mounts = lib.mapAttrsToList (
destination:
{
type,
source,
options ? null,
}:
{
inherit
destination
type
source
options
;
}
) sysMounts;
}
);
in
runCommand "join" { } ''
set -o pipefail
mkdir -p $out/rootfs/{dev,proc,sys}
cp ${config} $out/config.json
xargs tar c < ${writeClosure args} | tar -xC $out/rootfs/
'';
}