stockholm/makefu/1systems/x/config.nix

176 lines
5.8 KiB
Nix
Raw Normal View History

2015-08-22 23:28:41 +00:00
#
#
#
{ config, pkgs, ... }:
2017-04-17 11:11:32 +00:00
with import <stockholm/lib>;
2015-08-22 23:28:41 +00:00
{
imports =
2016-11-28 22:29:05 +00:00
[ # base
<stockholm/makefu>
<stockholm/makefu/2configs/main-laptop.nix>
<stockholm/makefu/2configs/extra-fonts.nix>
<stockholm/makefu/2configs/tools/all.nix>
2018-03-07 16:05:50 +00:00
<stockholm/makefu/2configs/tools/mic92.nix>
<stockholm/makefu/2configs/laptop-backup.nix>
2017-09-04 08:12:30 +00:00
<stockholm/makefu/2configs/dnscrypt/client.nix>
<stockholm/makefu/2configs/avahi.nix>
2017-06-26 14:00:54 +00:00
# Debugging
# <stockholm/makefu/2configs/disable_v6.nix>
2015-08-24 09:06:10 +00:00
2017-06-26 14:00:54 +00:00
# Testing
2017-07-31 12:23:25 +00:00
# <stockholm/makefu/2configs/deployment/gitlab.nix>
2017-09-04 12:35:56 +00:00
# <stockholm/makefu/2configs/deployment/wiki-irc-bot>
2017-07-31 12:23:25 +00:00
2017-07-16 13:16:45 +00:00
# <stockholm/makefu/2configs/torrent.nix>
# <stockholm/makefu/2configs/deployment/dirctator.nix>
# <stockholm/makefu/2configs/vncserver.nix>
# <stockholm/makefu/2configs/deployment/led-fader>
# <stockholm/makefu/2configs/deployment/hound>
2018-03-07 16:05:50 +00:00
# <stockholm/makefu/2configs/deployment/photostore.krebsco.de.nix>
# <stockholm/makefu/2configs/deployment/bureautomation/hass.nix>
2015-08-24 09:06:10 +00:00
2016-11-28 22:29:05 +00:00
# Krebs
<stockholm/makefu/2configs/tinc/retiolum.nix>
2016-11-28 22:29:05 +00:00
# applications
<stockholm/makefu/2configs/exim-retiolum.nix>
<stockholm/makefu/2configs/mail-client.nix>
<stockholm/makefu/2configs/printer.nix>
<stockholm/makefu/2configs/task-client.nix>
2017-06-26 14:00:54 +00:00
# Virtualization
2017-07-31 12:23:25 +00:00
<stockholm/makefu/2configs/virtualisation/libvirt.nix>
<stockholm/makefu/2configs/virtualisation/docker.nix>
2018-03-13 10:33:26 +00:00
<stockholm/makefu/2configs/virtualisation/virtualbox.nix>
2017-08-16 10:14:00 +00:00
{
networking.firewall.allowedTCPPorts = [ 8080 ];
networking.nat = {
enable = true;
externalInterface = "wlp3s0";
internalInterfaces = [ "vboxnet0" ];
};
}
2015-08-22 23:28:41 +00:00
2017-06-26 14:00:54 +00:00
# Services
<stockholm/makefu/2configs/git/brain-retiolum.nix>
<stockholm/makefu/2configs/tor.nix>
2017-09-04 08:12:51 +00:00
<stockholm/makefu/2configs/vpn/vpngate.nix>
# <stockholm/makefu/2configs/buildbot-standalone.nix>
2017-10-07 09:29:04 +00:00
# <stockholm/makefu/2configs/remote-build/master.nix>
2017-06-26 14:00:54 +00:00
# Hardware
<stockholm/makefu/2configs/hw/tp-x230.nix>
2018-02-06 10:55:12 +00:00
# <stockholm/makefu/2configs/hw/tpm.nix>
# <stockholm/makefu/2configs/hw/rtl8812au.nix>
2018-02-06 10:55:12 +00:00
<stockholm/makefu/2configs/hw/network-manager.nix>
<stockholm/makefu/2configs/hw/stk1160.nix>
# <stockholm/makefu/2configs/rad1o.nix>
2017-02-12 18:47:36 +00:00
2017-06-26 14:00:54 +00:00
# Filesystem
<stockholm/makefu/2configs/fs/sda-crypto-root-home.nix>
2016-06-02 12:44:11 +00:00
2017-06-30 23:13:28 +00:00
# Security
<stockholm/makefu/2configs/sshd-totp.nix>
2017-08-02 20:17:41 +00:00
{
programs.adb.enable = true;
}
2017-11-14 09:17:16 +00:00
# temporary
# <stockholm/makefu/2configs/lanparty/lancache.nix>
# <stockholm/makefu/2configs/lanparty/lancache-dns.nix>
# <stockholm/makefu/2configs/lanparty/samba.nix>
# <stockholm/makefu/2configs/lanparty/mumble-server.nix>
{
networking.wireguard.interfaces.wg0 = {
ips = [ "10.244.0.2/24" ];
privateKeyFile = (toString <secrets>) + "/wireguard.key";
allowedIPsAsRoutes = true;
peers = [
{
# gum
endpoint = "${config.krebs.hosts.gum.nets.internet.ip4.addr}:51820";
allowedIPs = [ "10.244.0.0/24" ];
publicKey = "yAKvxTvcEVdn+MeKsmptZkR3XSEue+wSyLxwcjBYxxo=";
}
#{
# # vbob
# allowedIPs = [ "10.244.0.3/32" ];
# publicKey = "Lju7EsCu1OWXhkhdNR7c/uiN60nr0TUPHQ+s8ULPQTw=";
#}
];
};
}
2018-02-21 15:00:33 +00:00
{ # bluetooth+pulse config
# for blueman-applet
users.users.makefu.packages = [
pkgs.blueman
];
hardware.pulseaudio = {
enable = true;
package = pkgs.pulseaudioFull;
# systemWide = true;
support32Bit = true;
configFile = pkgs.writeText "default.pa" ''
load-module module-udev-detect
load-module module-bluetooth-policy
load-module module-bluetooth-discover
load-module module-native-protocol-unix
load-module module-always-sink
load-module module-console-kit
load-module module-systemd-login
load-module module-intended-roles
load-module module-position-event-sounds
load-module module-filter-heuristics
load-module module-filter-apply
load-module module-switch-on-connect
2018-03-07 00:53:41 +00:00
load-module module-switch-on-port-available
2018-02-21 15:00:33 +00:00
'';
};
2018-02-21 15:00:33 +00:00
# presumably a2dp Sink
# Enable profile:
## pacmd set-card-profile "$(pactl list cards short | egrep -o bluez_card[[:alnum:]._]+)" a2dp_sink
hardware.bluetooth.extraConfig = '';
[general]
Enable=Source,Sink,Media,Socket
'';
# connect via https://nixos.wiki/wiki/Bluetooth#Using_Bluetooth_headsets_with_PulseAudio
hardware.bluetooth.enable = true;
}
2017-06-30 23:13:28 +00:00
2015-08-22 23:28:41 +00:00
];
makefu.server.primary-itf = "wlp3s0";
2016-08-21 10:06:31 +00:00
makefu.full-populate = true;
2016-09-02 10:50:07 +00:00
2016-10-22 10:47:22 +00:00
nixpkgs.config.allowUnfree = true;
2016-06-02 12:44:11 +00:00
# configure pulseAudio to provide a HDMI sink as well
2016-02-11 16:06:50 +00:00
networking.firewall.enable = true;
2016-10-19 10:31:13 +00:00
networking.firewall.allowedTCPPorts = [ 80 24800 26061 8000 3000 ];
2016-07-28 10:58:54 +00:00
networking.firewall.allowedUDPPorts = [ 665 26061 ];
2017-08-16 10:14:00 +00:00
networking.firewall.trustedInterfaces = [ "vboxnet0" ];
2015-08-22 23:28:41 +00:00
2016-07-28 10:58:54 +00:00
krebs.build.host = config.krebs.hosts.x;
krebs.tinc.retiolum.connectTo = [ "omo" "gum" "prism" ];
2016-06-02 12:44:11 +00:00
networking.extraHosts = ''
2018-02-06 10:59:08 +00:00
192.168.1.11 omo.local
80.92.65.53 www.wifionice.de wifionice.de
2016-06-02 12:44:11 +00:00
'';
2016-06-12 17:44:54 +00:00
# hard dependency because otherwise the device will not be unlocked
boot.initrd.luks.devices = [ { name = "luksroot"; device = "/dev/sda2"; allowDiscards=true; }];
2018-02-06 10:59:08 +00:00
nix.package = pkgs.nixUnstable;
environment.systemPackages = [ pkgs.passwdqc-utils pkgs.nixUnstable ];
nixpkgs.overlays = [ (import <python/overlay.nix>) ];
# environment.variables = { GOROOT = [ "${pkgs.go.out}/share/go" ]; };
2015-08-22 23:28:41 +00:00
}