nixos-config/1systems/x/config.nix

197 lines
6.7 KiB
Nix
Raw Normal View History

2015-08-23 01:28:41 +02:00
#
#
#
{ config, pkgs, lib, ... }:
2015-08-23 01:28:41 +02:00
{
imports =
2016-11-28 23:29:05 +01:00
[ # base
<stockholm/makefu>
2018-08-06 16:35:47 +02:00
<stockholm/makefu/2configs/nur.nix>
2018-09-19 02:53:18 +02: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>
<stockholm/makefu/2configs/home-manager/taskwarrior.nix>
<stockholm/makefu/2configs/main-laptop.nix>
2020-07-02 08:32:52 +02:00
<stockholm/makefu/2configs/kdeconnect.nix>
<stockholm/makefu/2configs/extra-fonts.nix>
<stockholm/makefu/2configs/editor/neovim>
<stockholm/makefu/2configs/tools/all.nix>
{ programs.adb.enable = true; }
{ systemd.services.docker.wantedBy = lib.mkForce []; }
2019-01-28 08:27:57 +01:00
<stockholm/makefu/2configs/dict.nix>
2020-07-02 08:32:52 +02:00
# <stockholm/makefu/2configs/legacy_only.nix>
2019-02-08 15:17:23 +01:00
#<stockholm/makefu/3modules/netboot_server.nix>
#{
# netboot_server = {
# network.wan = "wlp3s0";
# network.lan = "enp0s25";
# };
#}
2018-03-07 17:05:50 +01:00
# Restore:
# systemctl cat borgbackup-job-state
# export BORG_PASSCOMMAND BORG_REPO BORG_RSH
# borg list "$BORG_REPO"
# mount newroot somewhere && cd somewhere
# borg extract "$BORG_REPO::x-state-2019-04-17T01:41:51" --progress # < extract to cwd
<stockholm/makefu/2configs/backup/state.nix>
2018-09-08 12:50:14 +02:00
# <stockholm/makefu/2configs/dnscrypt/client.nix>
<stockholm/makefu/2configs/avahi.nix>
2019-01-28 08:29:54 +01:00
<stockholm/makefu/2configs/support-nixos.nix>
2017-06-26 16:00:54 +02:00
# Debugging
# <stockholm/makefu/2configs/disable_v6.nix>
2018-05-31 10:33:08 +02:00
# <stockholm/makefu/2configs/pyload.nix>
2015-08-24 11:06:10 +02:00
2017-06-26 16:00:54 +02:00
# Testing
2017-07-31 14:23:25 +02:00
# <stockholm/makefu/2configs/deployment/gitlab.nix>
2020-07-02 08:32:52 +02:00
# <stockholm/makefu/2configs/deployment/docker/etherpad.nix>
2017-09-04 14:35:56 +02:00
# <stockholm/makefu/2configs/deployment/wiki-irc-bot>
2017-07-31 14:23:25 +02:00
2017-07-16 15:16:45 +02: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 17:05:50 +01:00
# <stockholm/makefu/2configs/deployment/photostore.krebsco.de.nix>
# <stockholm/makefu/2configs/deployment/bureautomation/hass.nix>
2015-08-24 11:06:10 +02:00
2016-11-28 23:29:05 +01:00
# Krebs
<stockholm/makefu/2configs/tinc/retiolum.nix>
2020-03-13 10:48:14 +01:00
# <stockholm/makefu/2configs/share/gum-client.nix>
# <stockholm/makefu/2configs/share/temp-share-samba.nix>
2018-09-08 12:50:14 +02:00
2016-11-28 23:29:05 +01:00
# applications
<stockholm/makefu/2configs/exim-retiolum.nix>
<stockholm/makefu/2configs/mail-client.nix>
<stockholm/makefu/2configs/printer.nix>
2018-09-17 00:39:39 +02:00
# <stockholm/makefu/2configs/syncthing.nix>
2017-06-26 16:00:54 +02:00
# Virtualization
# <stockholm/makefu/2configs/virtualisation/libvirt.nix>
<stockholm/makefu/2configs/virtualisation/docker.nix>
<stockholm/makefu/2configs/virtualisation/virtualbox.nix>
2019-02-08 15:17:23 +01:00
#{
# networking.firewall.allowedTCPPorts = [ 8080 ];
# networking.nat = {
# enable = true;
# externalInterface = "wlp3s0";
# internalInterfaces = [ "vboxnet0" ];
# };
#}
2017-06-26 16:00:54 +02:00
# Services
<stockholm/makefu/2configs/git/brain-retiolum.nix>
<stockholm/makefu/2configs/tor.nix>
# <stockholm/makefu/2configs/vpn/vpngate.nix>
# <stockholm/makefu/2configs/buildbot-standalone.nix>
2019-01-28 08:29:54 +01:00
<stockholm/makefu/2configs/remote-build/aarch64-community.nix>
# <stockholm/makefu/2configs/remote-build/gum.nix>
# { nixpkgs.overlays = [ (self: super: super.prefer-remote-fetch self super) ]; }
<stockholm/makefu/2configs/binary-cache/gum.nix>
<stockholm/makefu/2configs/binary-cache/lass.nix>
2017-06-26 16:00:54 +02:00
# Hardware
2019-10-15 08:45:39 +02:00
<stockholm/makefu/2configs/hw/tp-x230.nix> # + bluetooth
# <stockholm/makefu/2configs/hw/mceusb.nix>
2019-10-15 08:45:39 +02:00
<stockholm/makefu/2configs/hw/tpm.nix>
# <stockholm/makefu/2configs/hw/rtl8812au.nix>
2018-02-06 11:55:12 +01:00
<stockholm/makefu/2configs/hw/network-manager.nix>
# <stockholm/makefu/2configs/hw/stk1160.nix>
# <stockholm/makefu/2configs/hw/irtoy.nix>
# <stockholm/makefu/2configs/hw/malduino_elite.nix>
<stockholm/makefu/2configs/hw/switch.nix>
2018-05-31 10:33:08 +02:00
# <stockholm/makefu/2configs/hw/rad1o.nix>
2020-03-13 10:48:14 +01:00
<stockholm/makefu/2configs/hw/cc2531.nix>
2018-09-08 12:50:14 +02:00
<stockholm/makefu/2configs/hw/smartcard.nix>
2019-10-15 08:45:39 +02:00
<stockholm/makefu/2configs/hw/upower.nix>
2017-06-26 16:00:54 +02:00
# Filesystem
<stockholm/makefu/2configs/fs/sda-crypto-root-home.nix>
2016-06-02 14:44:11 +02:00
2017-07-01 01:13:28 +02:00
# Security
<stockholm/makefu/2configs/sshd-totp.nix>
2017-11-14 10:17:16 +01:00
# temporary
# { services.redis.enable = true; }
# <stockholm/makefu/2configs/pyload.nix>
# <stockholm/makefu/2configs/dcpp/airdcpp.nix>
2018-09-08 12:50:14 +02:00
# <stockholm/makefu/2configs/nginx/rompr.nix>
2017-11-14 10:17:16 +01: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>
{
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=";
#}
];
};
}
2015-08-23 01:28:41 +02:00
];
makefu.server.primary-itf = "wlp3s0";
2016-09-02 12:50:07 +02:00
2016-10-22 12:47:22 +02:00
nixpkgs.config.allowUnfree = true;
nixpkgs.config.oraclejdk.accept_license = true;
2016-06-02 14:44:11 +02:00
# configure pulseAudio to provide a HDMI sink as well
2016-02-11 17:06:50 +01:00
networking.firewall.enable = true;
2016-07-28 12:58:54 +02:00
networking.firewall.allowedUDPPorts = [ 665 26061 ];
2017-08-16 12:14:00 +02:00
networking.firewall.trustedInterfaces = [ "vboxnet0" ];
2015-08-23 01:28:41 +02:00
2016-07-28 12:58:54 +02:00
krebs.build.host = config.krebs.hosts.x;
2019-10-15 08:45:39 +02:00
krebs.tinc.retiolum.connectTo = [ "omo" "prism" "nextgum" "wbob" ];
2016-06-12 19:44:54 +02:00
# hard dependency because otherwise the device will not be unlocked
boot.initrd.luks.devices.luksroot =
{
device = "/dev/sda2";
allowDiscards = true;
};
2018-02-06 11:59:08 +01:00
environment.systemPackages = [ pkgs.passwdqc-utils ];
2018-02-06 11:59:08 +01:00
# environment.variables = { GOROOT = [ "${pkgs.go.out}/share/go" ]; };
2018-09-08 12:50:14 +02:00
state = [
"/home/makefu/stockholm"
"/home/makefu/.ssh/"
"/home/makefu/.zsh_history"
"/home/makefu/.bash_history"
"/home/makefu/bin"
"/home/makefu/.gnupg"
"/home/makefu/.imapfilter"
"/home/makefu/.mutt"
"/home/makefu/docs"
"/home/makefu/notes"
"/home/makefu/.password-store"
"/home/makefu/.secrets-pass"
"/home/makefu/.config/syncthing"
2018-09-08 12:50:14 +02:00
];
2018-09-17 00:39:39 +02:00
services.syncthing.user = lib.mkForce "makefu";
services.syncthing.dataDir = lib.mkForce "/home/makefu/.config/syncthing/";
2015-08-23 01:28:41 +02:00
}