mirror of
https://github.com/NixOS/nix
synced 2025-06-25 10:41:16 +02:00
Merge 2caccbed11
into c437e27abc
This commit is contained in:
commit
b18bf45815
1 changed files with 19 additions and 25 deletions
44
docker.nix
44
docker.nix
|
@ -147,23 +147,11 @@ let
|
||||||
"${k}:x:${toString gid}:${lib.concatStringsSep "," members}";
|
"${k}:x:${toString gid}:${lib.concatStringsSep "," members}";
|
||||||
groupContents = (lib.concatStringsSep "\n" (lib.attrValues (lib.mapAttrs groupToGroup groups)));
|
groupContents = (lib.concatStringsSep "\n" (lib.attrValues (lib.mapAttrs groupToGroup groups)));
|
||||||
|
|
||||||
defaultNixConf = {
|
|
||||||
sandbox = "false";
|
|
||||||
build-users-group = "nixbld";
|
|
||||||
trusted-public-keys = [ "cache.nixos.org-1:6NCHdD59X431o0gWypbMrAURkbJ16ZPMQFGspcDShjY=" ];
|
|
||||||
};
|
|
||||||
|
|
||||||
nixConfContents =
|
nixConfContents =
|
||||||
(lib.concatStringsSep "\n" (
|
pkgs.dockerTools.nixConf
|
||||||
lib.mapAttrsToList (
|
{
|
||||||
n: v:
|
build-users-group = "nixbld";
|
||||||
let
|
};
|
||||||
vStr = if builtins.isList v then lib.concatStringsSep " " v else v;
|
|
||||||
in
|
|
||||||
"${n} = ${vStr}"
|
|
||||||
) (defaultNixConf // nixConf)
|
|
||||||
))
|
|
||||||
+ "\n";
|
|
||||||
|
|
||||||
userHome = if uid == 0 then "/root" else "/home/${uname}";
|
userHome = if uid == 0 then "/root" else "/home/${uname}";
|
||||||
|
|
||||||
|
@ -182,10 +170,7 @@ let
|
||||||
echo "[]" > $out/manifest.nix
|
echo "[]" > $out/manifest.nix
|
||||||
fi
|
fi
|
||||||
'';
|
'';
|
||||||
rootEnv = pkgs.buildPackages.buildEnv {
|
# doc/manual/source/command-ref/files/manifest.nix.md
|
||||||
name = "root-profile-env";
|
|
||||||
paths = defaultPkgs;
|
|
||||||
};
|
|
||||||
manifest = pkgs.buildPackages.runCommand "manifest.nix" { } ''
|
manifest = pkgs.buildPackages.runCommand "manifest.nix" { } ''
|
||||||
cat > $out <<EOF
|
cat > $out <<EOF
|
||||||
[
|
[
|
||||||
|
@ -215,11 +200,15 @@ let
|
||||||
]
|
]
|
||||||
EOF
|
EOF
|
||||||
'';
|
'';
|
||||||
profile = pkgs.buildPackages.runCommand "user-environment" { } ''
|
profile = pkgs.buildPackages.buildEnv {
|
||||||
mkdir $out
|
name = "root-profile-env";
|
||||||
cp -a ${rootEnv}/* $out/
|
paths = defaultPkgs;
|
||||||
ln -s ${manifest} $out/manifest.nix
|
|
||||||
'';
|
postBuild = ''
|
||||||
|
mv $out/manifest $out/manifest.nix
|
||||||
|
'';
|
||||||
|
inherit manifest;
|
||||||
|
};
|
||||||
flake-registry-path =
|
flake-registry-path =
|
||||||
if (flake-registry == null) then
|
if (flake-registry == null) then
|
||||||
null
|
null
|
||||||
|
@ -251,6 +240,7 @@ let
|
||||||
set -x
|
set -x
|
||||||
mkdir -p $out/etc
|
mkdir -p $out/etc
|
||||||
|
|
||||||
|
# may get replaced by pkgs.dockerTools.caCertificates
|
||||||
mkdir -p $out/etc/ssl/certs
|
mkdir -p $out/etc/ssl/certs
|
||||||
ln -s /nix/var/nix/profiles/default/etc/ssl/certs/ca-bundle.crt $out/etc/ssl/certs
|
ln -s /nix/var/nix/profiles/default/etc/ssl/certs/ca-bundle.crt $out/etc/ssl/certs
|
||||||
|
|
||||||
|
@ -278,17 +268,21 @@ let
|
||||||
mkdir -p $out${userHome}
|
mkdir -p $out${userHome}
|
||||||
mkdir -p $out/nix/var/nix/profiles/per-user/${uname}
|
mkdir -p $out/nix/var/nix/profiles/per-user/${uname}
|
||||||
|
|
||||||
|
# see doc/manual/source/command-ref/files/profiles.md
|
||||||
ln -s ${profile} $out/nix/var/nix/profiles/default-1-link
|
ln -s ${profile} $out/nix/var/nix/profiles/default-1-link
|
||||||
ln -s /nix/var/nix/profiles/default-1-link $out/nix/var/nix/profiles/default
|
ln -s /nix/var/nix/profiles/default-1-link $out/nix/var/nix/profiles/default
|
||||||
ln -s /nix/var/nix/profiles/default $out${userHome}/.nix-profile
|
ln -s /nix/var/nix/profiles/default $out${userHome}/.nix-profile
|
||||||
|
|
||||||
|
# see doc/manual/source/command-ref/files/channels.md
|
||||||
ln -s ${channel} $out/nix/var/nix/profiles/per-user/${uname}/channels-1-link
|
ln -s ${channel} $out/nix/var/nix/profiles/per-user/${uname}/channels-1-link
|
||||||
ln -s /nix/var/nix/profiles/per-user/${uname}/channels-1-link $out/nix/var/nix/profiles/per-user/${uname}/channels
|
ln -s /nix/var/nix/profiles/per-user/${uname}/channels-1-link $out/nix/var/nix/profiles/per-user/${uname}/channels
|
||||||
|
|
||||||
|
# see doc/manual/source/command-ref/files/default-nix-expression.md
|
||||||
mkdir -p $out${userHome}/.nix-defexpr
|
mkdir -p $out${userHome}/.nix-defexpr
|
||||||
ln -s /nix/var/nix/profiles/per-user/${uname}/channels $out${userHome}/.nix-defexpr/channels
|
ln -s /nix/var/nix/profiles/per-user/${uname}/channels $out${userHome}/.nix-defexpr/channels
|
||||||
echo "${channelURL} ${channelName}" > $out${userHome}/.nix-channels
|
echo "${channelURL} ${channelName}" > $out${userHome}/.nix-channels
|
||||||
|
|
||||||
|
# may get replaced by pkgs.dockerTools.binSh & pkgs.dockerTools.usrBinEnv
|
||||||
mkdir -p $out/bin $out/usr/bin
|
mkdir -p $out/bin $out/usr/bin
|
||||||
ln -s ${pkgs.coreutils}/bin/env $out/usr/bin/env
|
ln -s ${pkgs.coreutils}/bin/env $out/usr/bin/env
|
||||||
ln -s ${pkgs.bashInteractive}/bin/bash $out/bin/sh
|
ln -s ${pkgs.bashInteractive}/bin/bash $out/bin/sh
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue