2015-08-22 23:28:41 +00:00
|
|
|
#
|
|
|
|
#
|
|
|
|
#
|
2018-09-16 22:45:48 +00:00
|
|
|
{ config, pkgs, lib, ... }:
|
2015-08-22 23:28:41 +00:00
|
|
|
{
|
|
|
|
imports =
|
2016-11-28 22:29:05 +00:00
|
|
|
[ # base
|
2017-07-15 17:01:02 +00:00
|
|
|
<stockholm/makefu>
|
2018-08-06 14:35:47 +00:00
|
|
|
<stockholm/makefu/2configs/nur.nix>
|
2018-09-19 00:53:18 +00:00
|
|
|
<stockholm/makefu/2configs/home-manager>
|
|
|
|
<stockholm/makefu/2configs/home-manager/desktop.nix>
|
|
|
|
<stockholm/makefu/2configs/home-manager/cli.nix>
|
|
|
|
<stockholm/makefu/2configs/home-manager/mail.nix>
|
2017-07-15 17:01:02 +00:00
|
|
|
<stockholm/makefu/2configs/main-laptop.nix>
|
|
|
|
<stockholm/makefu/2configs/extra-fonts.nix>
|
|
|
|
<stockholm/makefu/2configs/tools/all.nix>
|
2019-01-28 07:27:57 +00:00
|
|
|
<stockholm/makefu/2configs/dict.nix>
|
2018-03-07 16:05:50 +00:00
|
|
|
|
2018-10-21 21:34:54 +00:00
|
|
|
<stockholm/makefu/2configs/backup/state.nix>
|
2018-09-08 10:50:14 +00:00
|
|
|
# <stockholm/makefu/2configs/dnscrypt/client.nix>
|
2017-07-15 17:01:02 +00:00
|
|
|
<stockholm/makefu/2configs/avahi.nix>
|
2019-01-28 07:29:54 +00:00
|
|
|
<stockholm/makefu/2configs/support-nixos.nix>
|
2015-08-23 00:48:35 +00:00
|
|
|
|
2017-06-26 14:00:54 +00:00
|
|
|
# Debugging
|
2017-07-15 17:01:02 +00:00
|
|
|
# <stockholm/makefu/2configs/disable_v6.nix>
|
2018-05-31 08:33:08 +00:00
|
|
|
# <stockholm/makefu/2configs/pyload.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>
|
2017-07-15 17:01:02 +00:00
|
|
|
# <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
|
2017-07-15 17:01:02 +00:00
|
|
|
<stockholm/makefu/2configs/tinc/retiolum.nix>
|
2018-09-08 10:50:14 +00:00
|
|
|
<stockholm/makefu/2configs/share/gum-client.nix>
|
|
|
|
|
2016-11-28 22:29:05 +00:00
|
|
|
|
|
|
|
# applications
|
2017-07-15 17:01:02 +00:00
|
|
|
<stockholm/makefu/2configs/exim-retiolum.nix>
|
|
|
|
<stockholm/makefu/2configs/mail-client.nix>
|
|
|
|
<stockholm/makefu/2configs/printer.nix>
|
|
|
|
<stockholm/makefu/2configs/task-client.nix>
|
2018-09-16 22:39:39 +00:00
|
|
|
# <stockholm/makefu/2configs/syncthing.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>
|
2019-01-28 12:51:36 +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" ];
|
|
|
|
};
|
|
|
|
}
|
2017-06-26 14:00:54 +00:00
|
|
|
# Services
|
2017-07-15 17:01:02 +00:00
|
|
|
<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>
|
2017-07-15 17:01:02 +00:00
|
|
|
# <stockholm/makefu/2configs/buildbot-standalone.nix>
|
2019-01-28 07:29:54 +00:00
|
|
|
<stockholm/makefu/2configs/remote-build/aarch64-community.nix>
|
2015-08-31 17:56:47 +00:00
|
|
|
|
2017-06-26 14:00:54 +00:00
|
|
|
# Hardware
|
2017-07-15 17:01:02 +00:00
|
|
|
<stockholm/makefu/2configs/hw/tp-x230.nix>
|
2018-08-06 14:35:47 +00:00
|
|
|
<stockholm/makefu/2configs/hw/mceusb.nix>
|
2019-01-22 07:14:34 +00:00
|
|
|
<stockholm/makefu/2configs/hw/malduino_elite.nix>
|
2018-02-06 10:55:12 +00:00
|
|
|
# <stockholm/makefu/2configs/hw/tpm.nix>
|
2018-02-15 09:17:41 +00:00
|
|
|
# <stockholm/makefu/2configs/hw/rtl8812au.nix>
|
2018-02-06 10:55:12 +00:00
|
|
|
<stockholm/makefu/2configs/hw/network-manager.nix>
|
2018-01-28 12:57:55 +00:00
|
|
|
<stockholm/makefu/2configs/hw/stk1160.nix>
|
2018-05-31 08:33:08 +00:00
|
|
|
<stockholm/makefu/2configs/hw/irtoy.nix>
|
2018-10-21 21:34:54 +00:00
|
|
|
<stockholm/makefu/2configs/hw/switch.nix>
|
2018-05-31 08:33:08 +00:00
|
|
|
<stockholm/makefu/2configs/hw/bluetooth.nix>
|
|
|
|
# <stockholm/makefu/2configs/hw/rad1o.nix>
|
2018-09-08 10:50:14 +00:00
|
|
|
<stockholm/makefu/2configs/hw/smartcard.nix>
|
2017-02-12 18:47:36 +00:00
|
|
|
|
2017-06-26 14:00:54 +00:00
|
|
|
# Filesystem
|
2017-07-15 17:01:02 +00:00
|
|
|
<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
|
2017-07-15 17:01:02 +00:00
|
|
|
<stockholm/makefu/2configs/sshd-totp.nix>
|
2018-10-21 21:34:54 +00:00
|
|
|
{ programs.adb.enable = true; }
|
2017-11-14 09:17:16 +00:00
|
|
|
# temporary
|
2018-10-21 21:34:54 +00:00
|
|
|
{ services.redis.enable = true; }
|
2018-09-08 10:50:14 +00:00
|
|
|
<stockholm/makefu/2configs/pyload.nix>
|
2018-10-21 21:34:54 +00:00
|
|
|
# <stockholm/makefu/2configs/dcpp/airdcpp.nix>
|
2018-09-08 10:50:14 +00:00
|
|
|
# <stockholm/makefu/2configs/nginx/rompr.nix>
|
2017-11-14 09:17:16 +00:00
|
|
|
# <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>
|
2018-02-15 09:17:41 +00:00
|
|
|
|
|
|
|
{
|
|
|
|
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-05-31 08:33:08 +00:00
|
|
|
# {
|
|
|
|
# services.zerotierone.enable = true;
|
|
|
|
# }
|
2017-06-30 23:13:28 +00:00
|
|
|
|
2015-08-22 23:28:41 +00:00
|
|
|
];
|
2017-03-01 14:51:48 +00:00
|
|
|
|
|
|
|
makefu.server.primary-itf = "wlp3s0";
|
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
|
|
|
|
2015-10-13 22:10:56 +00:00
|
|
|
# configure pulseAudio to provide a HDMI sink as well
|
2016-02-11 16:06:50 +00:00
|
|
|
networking.firewall.enable = true;
|
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;
|
2016-07-20 15:18:57 +00:00
|
|
|
|
2018-08-06 14:35:47 +00:00
|
|
|
krebs.tinc.retiolum.connectTo = [ "omo" "gum" "prism" "nextgum" ];
|
2016-07-20 15:18:57 +00:00
|
|
|
|
2016-06-02 12:44:11 +00:00
|
|
|
networking.extraHosts = ''
|
2018-02-06 10:59:08 +00:00
|
|
|
192.168.1.11 omo.local
|
2018-04-04 12:39:44 +00:00
|
|
|
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-08-06 14:35:47 +00:00
|
|
|
# avoid full boot dir
|
|
|
|
boot.loader.grub.configurationLimit = 3;
|
2018-02-06 10:59:08 +00:00
|
|
|
|
2018-10-21 21:34:54 +00:00
|
|
|
environment.systemPackages = [ pkgs.passwdqc-utils ];
|
2018-02-06 10:59:08 +00:00
|
|
|
|
|
|
|
# environment.variables = { GOROOT = [ "${pkgs.go.out}/share/go" ]; };
|
2018-09-08 10:50:14 +00:00
|
|
|
state = [
|
|
|
|
"/home/makefu/stockholm"
|
2018-10-21 21:34:54 +00:00
|
|
|
"/home/makefu/.ssh/"
|
|
|
|
"/home/makefu/.zsh_history"
|
|
|
|
"/home/makefu/.bash_history"
|
|
|
|
"/home/makefu/.zshrc"
|
|
|
|
"/home/makefu/bin"
|
|
|
|
"/home/makefu/.gnupg"
|
|
|
|
"/home/makefu/.imapfilter"
|
|
|
|
"/home/makefu/.mutt"
|
|
|
|
"/home/makefu/docs"
|
|
|
|
"/home/makefu/.password-store"
|
|
|
|
"/home/makefu/.secrets-pass"
|
|
|
|
"/home/makefu/autosync/Database.kdb"
|
2018-09-08 10:50:14 +00:00
|
|
|
];
|
2018-10-21 21:34:54 +00:00
|
|
|
|
2018-09-16 22:39:39 +00:00
|
|
|
services.syncthing.user = lib.mkForce "makefu";
|
|
|
|
services.syncthing.dataDir = lib.mkForce "/home/makefu/.config/syncthing/";
|
2015-08-22 23:28:41 +00:00
|
|
|
}
|