blob: e579183f28160e6ef97a682ad5722ecddeab3e2f (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
|
{ pkgs
, name ? "sandbox"
, user ? "dummy"
, config ? { }
, restrictNetwork ? true # to be replaced with virtualisation.restrictNetwork
, patchQemu9p ? false
}:
let
# Patched QEMU to fix slow 9p file share.
# https://linus.schreibt.jetzt/posts/qemu-9p-performance.html
qemu_kvm_patched_9p =
assert !(pkgs.lib.versionAtLeast pkgs.qemu_kvm.version "7.2.0");
pkgs.qemu_kvm.overrideAttrs (o: {
patches = o.patches ++ [ (pkgs.fetchpatch {
name = "qemu-9p-performance-fix.patch";
url = "https://github.com/qemu/qemu/commit/f5265c8.patch";
sha256 = "sha256-PSOv0dhiEq9g6B1uIbs6vbhGr7BQWCtAoLHnk4vnvVg=";
}) ];
});
in rec {
nixosConfigurations.${name} = pkgs.nixos ({ modulesPath, lib, pkgs, ... }: {
imports = [
(modulesPath + "/profiles/minimal.nix")
{ environment.noXlibs = false; } # avoid mass rebuild
(modulesPath + "/profiles/qemu-guest.nix")
(modulesPath + "/virtualisation/qemu-vm.nix")
config
];
system.stateVersion = lib.mkDefault lib.trivial.release;
networking = {
hostName = name;
firewall.enable = lib.mkDefault false;
};
users.users.${user} = {
isNormalUser = lib.mkDefault true;
password = lib.mkDefault "";
extraGroups = lib.mkDefault [ "wheel" ];
};
security.sudo.wheelNeedsPassword = lib.mkDefault false;
services.getty = {
autologinUser = lib.mkDefault user;
helpLine = lib.mkDefault ''
Press <CTRL-a> <x> to terminate the virtual machine.
The working directory on the host is mounted to /mnt.
'';
};
virtualisation = {
graphics = lib.mkDefault false;
diskImage = lib.mkDefault "$(mktemp).qcow2";
sharedDirectories.host = {
source = "$SHARED_CWD";
target = "/mnt";
};
# Uncomment when this is merged:
# https://github.com/NixOS/nixpkgs/pull/200225
#restrictNetwork = lib.mkDefault true;
qemu.package = lib.mkDefault
(if patchQemu9p then qemu_kvm_patched_9p else pkgs.qemu_kvm);
};
});
packages.${name} = nixosConfigurations.${name}.config.system.build.vm;
apps.${name} = {
type = "app";
program = toString (pkgs.writeShellScript "sandbox-vm" (
(pkgs.lib.optionalString restrictNetwork ''
# Isolate from network
# Stopgap solution until this is merged:
# https://github.com/NixOS/nixpkgs/pull/200225
QEMU_NET_OPTS="restrict=yes,''${QEMU_NET_OPTS:+,$QEMU_NET_OPTS}"
export QEMU_NET_OPTS
'') + ''
# Save current directory for mounting in VM
SHARED_CWD=$PWD
export SHARED_CWD
${packages.${name}}/bin/run-${name}-vm
reset
echo "Exited virtual machine."
''));
};
}
|