Skip to content

Commit

Permalink
Allow customizing the system config to include in the tarball
Browse files Browse the repository at this point in the history
  • Loading branch information
terlar committed Jun 21, 2023
1 parent a8486b5 commit 3fa0103
Showing 1 changed file with 20 additions and 10 deletions.
30 changes: 20 additions & 10 deletions modules/build-tarball.nix
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
{ config, pkgs, lib, ... }:
with builtins; with lib;
let
cfg = config.wsl.tarball;

pkgs2storeContents = l: map (x: { object = x; symlink = "none"; }) l;

nixpkgs = lib.cleanSource pkgs.path;
Expand All @@ -19,7 +21,7 @@ let
echo ${toString config.system.nixos.versionSuffix} | sed -e s/pre// > $out/nixos/svn-revision
'';

preparer = pkgs.writeShellScriptBin "wsl-prepare" ''
preparer = pkgs.writeShellScriptBin "wsl-prepare" (''
set -e
mkdir -m 0755 ./bin ./etc
Expand Down Expand Up @@ -49,15 +51,17 @@ let
# Write wsl.conf so that it is present when NixOS is started for the first time
cp ${config.environment.etc."wsl.conf".source} ./etc/wsl.conf
${lib.optionalString config.wsl.tarball.includeConfig ''
# Copy the system configuration
mkdir -p ./etc/nixos/nixos-wsl
cp -R ${lib.cleanSource ../.}/. ./etc/nixos/nixos-wsl
mv ./etc/nixos/nixos-wsl/configuration.nix ./etc/nixos/configuration.nix
# Patch the import path to avoid having a flake.nix in /etc/nixos
sed -i 's|import \./default\.nix|import \./nixos-wsl|' ./etc/nixos/configuration.nix
''}
'';
'' + lib.optionalString cfg.includeConfig (if cfg.configPath == null then ''
# Copy the system configuration
mkdir -p ./etc/nixos/nixos-wsl
cp -R ${lib.cleanSource ../.}/. ./etc/nixos/nixos-wsl
mv ./etc/nixos/nixos-wsl/configuration.nix ./etc/nixos/configuration.nix
# Patch the import path to avoid having a flake.nix in /etc/nixos
sed -i 's|import \./default\.nix|import \./nixos-wsl|' ./etc/nixos/configuration.nix
'' else ''
mkdir -p ./etc/nixos
cp -R ${lib.cleanSource cfg.configPath}/. ./etc/nixos
''));

in
{
Expand All @@ -68,6 +72,12 @@ in
default = true;
description = "Whether or not to copy the system configuration into the tarball";
};

configPath = mkOption {
type = types.nullOr types.path;
default = null;
description = "Path to system configuration which is copied into the tarball";
};
};


Expand Down

0 comments on commit 3fa0103

Please sign in to comment.