2016-10-20 20:54:38 +02:00
|
|
|
with import <stockholm/lib>;
|
2017-08-01 22:37:41 +02:00
|
|
|
{ config, pkgs, ... }: {
|
2016-03-31 03:48:43 +02:00
|
|
|
|
|
|
|
imports = [
|
2018-09-16 21:31:14 +02:00
|
|
|
<stockholm/tv>
|
2018-10-03 10:14:20 +02:00
|
|
|
<stockholm/tv/2configs/br.nix>
|
2017-07-06 21:47:47 +02:00
|
|
|
<stockholm/tv/2configs/exim-retiolum.nix>
|
2018-12-17 17:11:31 +01:00
|
|
|
<stockholm/tv/2configs/hw/x220.nix>
|
2017-07-06 21:47:47 +02:00
|
|
|
<stockholm/tv/2configs/retiolum.nix>
|
2016-03-31 03:48:43 +02:00
|
|
|
];
|
|
|
|
|
|
|
|
krebs.build.host = config.krebs.hosts.mu;
|
|
|
|
krebs.build.user = mkForce config.krebs.users.vv;
|
|
|
|
|
2017-08-02 02:14:49 +02:00
|
|
|
tv.x0vncserver.enable = true;
|
|
|
|
|
2018-12-17 17:10:24 +01:00
|
|
|
boot.initrd.luks.devices.muca.device = "/dev/sda2";
|
2016-03-31 03:48:43 +02:00
|
|
|
boot.initrd.luks.cryptoModules = [ "aes" "sha512" "xts" ];
|
|
|
|
boot.initrd.availableKernelModules = [ "ahci" ];
|
|
|
|
boot.kernelModules = [ "fbcon" "kvm-intel" ];
|
|
|
|
boot.extraModulePackages = [ ];
|
|
|
|
|
|
|
|
fileSystems = {
|
|
|
|
"/" = {
|
2017-08-18 09:06:27 +02:00
|
|
|
device = "/dev/mapper/muvga-root";
|
2018-11-08 19:25:24 +01:00
|
|
|
fsType = "ext4";
|
|
|
|
options = [ "defaults" "discard" ];
|
2016-03-31 03:48:43 +02:00
|
|
|
};
|
|
|
|
"/home" = {
|
2017-08-18 09:06:27 +02:00
|
|
|
device = "/dev/mapper/muvga-home";
|
2018-11-08 19:25:24 +01:00
|
|
|
fsType = "ext4";
|
|
|
|
options = [ "defaults" "discard" ];
|
2016-03-31 03:48:43 +02:00
|
|
|
};
|
|
|
|
"/boot" = {
|
2018-12-17 17:10:24 +01:00
|
|
|
device = "/dev/sda1";
|
2018-11-08 19:25:24 +01:00
|
|
|
fsType = "vfat";
|
2016-03-31 03:48:43 +02:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
nixpkgs.config.allowUnfree = true;
|
|
|
|
hardware.opengl.driSupport32Bit = true;
|
|
|
|
|
|
|
|
hardware.pulseaudio.enable = true;
|
|
|
|
|
2017-07-12 19:20:22 +02:00
|
|
|
hardware.enableRedistributableFirmware = true;
|
2016-03-31 03:48:43 +02:00
|
|
|
|
|
|
|
boot.loader.efi.canTouchEfiVariables = true;
|
2017-08-02 02:14:23 +02:00
|
|
|
boot.loader.systemd-boot.enable = true;
|
2016-03-31 03:48:43 +02:00
|
|
|
|
|
|
|
networking.networkmanager.enable = true;
|
|
|
|
|
2019-08-02 17:03:12 +02:00
|
|
|
# XXX reload to work around occasional "Failed to load firmware chunk!"
|
|
|
|
# TODO only do this if firmware is actually broken(?)
|
|
|
|
system.activationScripts.reload-iwlwifi = /* sh */ ''
|
|
|
|
${pkgs.kmod}/bin/modprobe -vr iwlwifi
|
|
|
|
${pkgs.kmod}/bin/modprobe -v iwlwifi
|
|
|
|
'';
|
|
|
|
|
2016-03-31 03:48:43 +02:00
|
|
|
environment.systemPackages = with pkgs; [
|
2017-08-31 22:02:52 +02:00
|
|
|
chromium
|
|
|
|
firefoxWrapper
|
|
|
|
gimp
|
|
|
|
iptables
|
|
|
|
libreoffice
|
2018-09-16 22:02:16 +02:00
|
|
|
plasma-pa
|
2017-11-02 21:13:00 +01:00
|
|
|
(pkgs.pidgin-with-plugins.override {
|
|
|
|
plugins = [ pkgs.pidginotr ];
|
|
|
|
})
|
2017-08-31 22:02:52 +02:00
|
|
|
skype
|
2016-03-31 03:48:43 +02:00
|
|
|
slock
|
2016-06-30 01:05:21 +02:00
|
|
|
tinc_pre
|
2016-03-31 03:48:43 +02:00
|
|
|
vim
|
|
|
|
xsane
|
|
|
|
|
|
|
|
#foomatic_filters
|
|
|
|
#gutenprint
|
|
|
|
#cups_pdf_filter
|
|
|
|
#ghostscript
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
|
|
i18n.defaultLocale = "de_DE.UTF-8";
|
|
|
|
|
|
|
|
programs.ssh.startAgent = false;
|
|
|
|
|
2017-03-02 20:02:01 +01:00
|
|
|
security.wrappers = {
|
2017-06-27 21:30:05 +02:00
|
|
|
slock.source = "${pkgs.slock}/bin/slock";
|
2017-03-02 20:02:01 +01:00
|
|
|
};
|
2016-03-31 03:48:43 +02:00
|
|
|
|
|
|
|
security.pam.loginLimits = [
|
|
|
|
# for jack
|
|
|
|
{ domain = "@audio"; item = "memlock"; type = "-"; value = "unlimited"; }
|
|
|
|
{ domain = "@audio"; item = "rtprio"; type = "-"; value = "99"; }
|
|
|
|
];
|
|
|
|
|
|
|
|
fonts.fonts = [
|
|
|
|
pkgs.xlibs.fontschumachermisc
|
|
|
|
];
|
|
|
|
|
|
|
|
services.xserver.enable = true;
|
|
|
|
services.xserver.layout = "de";
|
|
|
|
services.xserver.xkbOptions = "eurosign:e";
|
|
|
|
|
|
|
|
# TODO this is host specific
|
2019-10-16 09:21:17 +02:00
|
|
|
services.xserver.libinput.enable = false;
|
2016-03-31 03:48:43 +02:00
|
|
|
services.xserver.synaptics = {
|
|
|
|
enable = true;
|
|
|
|
twoFingerScroll = true;
|
|
|
|
};
|
|
|
|
|
2017-06-27 21:30:22 +02:00
|
|
|
services.xserver.desktopManager.plasma5 = {
|
|
|
|
enable = true;
|
|
|
|
};
|
2016-03-31 03:48:43 +02:00
|
|
|
services.xserver.displayManager.auto = {
|
|
|
|
enable = true;
|
|
|
|
user = "vv";
|
|
|
|
};
|
|
|
|
|
|
|
|
users.users.vv = {
|
|
|
|
inherit (config.krebs.users.vv) home uid;
|
|
|
|
isNormalUser = true;
|
|
|
|
extraGroups = [
|
|
|
|
"audio"
|
|
|
|
"video"
|
|
|
|
"networkmanager"
|
|
|
|
];
|
|
|
|
};
|
|
|
|
}
|