core/pkgs/build-support/oci-tools/default.nix

91 lines
2.2 KiB
Nix
Raw Normal View History

2024-05-02 00:46:19 +00:00
{ lib, writeText, runCommand, writeClosure }:
{
buildContainer =
2024-05-13 21:24:10 +00:00
{ 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" ];
};
2024-05-02 00:46:19 +00:00
};
2024-05-13 21:24:10 +00:00
config = writeText "config.json" (builtins.toJSON {
ociVersion = "1.0.0";
platform = { inherit os arch; };
2024-05-02 00:46:19 +00:00
2024-05-13 21:24:10 +00:00
linux = {
namespaces = map (type: { inherit type; }) [
"pid"
"network"
"mount"
"ipc"
"uts"
];
};
2024-05-02 00:46:19 +00:00
2024-05-13 21:24:10 +00:00
root = {
path = "rootfs";
inherit readonly;
};
2024-05-02 00:46:19 +00:00
2024-05-13 21:24:10 +00:00
process = {
inherit args;
user = {
uid = 0;
gid = 0;
};
cwd = "/";
};
2024-05-02 00:46:19 +00:00
2024-05-13 21:24:10 +00:00
mounts = lib.mapAttrsToList (destination:
{ type, source, options ? null }: {
inherit destination type source options;
}) sysMounts;
});
in runCommand "join" { } ''
2024-05-02 00:46:19 +00:00
set -o pipefail
mkdir -p $out/rootfs/{dev,proc,sys}
cp ${config} $out/config.json
xargs tar c < ${writeClosure args} | tar -xC $out/rootfs/
'';
}