with (import ); { config, lib, pkgs, ... }: { imports = [ ./bitlbee.nix ./mail.nix ./pass.nix ]; environment.systemPackages = with pkgs; [ ag brain dic nmap git-preview l-gen-secrets ]; services.tor.enable = true; services.tor.client.enable = true; krebs.iptables.tables.filter.INPUT.rules = [ { predicate = "-i retiolum -p udp --dport 60000:61000"; target = "ACCEPT";} { predicate = "-i wiregrill -p udp --dport 60000:61000"; target = "ACCEPT";} { predicate = "-i retiolum -p tcp --dport 9998:9999"; target = "ACCEPT";} { predicate = "-i wiregrill -p tcp --dport 9998:9999"; target = "ACCEPT";} { predicate = "-i retiolum -p tcp --dport imap"; target = "ACCEPT";} { predicate = "-i wiregrill -p tcp --dport imap"; target = "ACCEPT";} ]; systemd.services.chat = let tmux = pkgs.writeDash "tmux" '' exec ${pkgs.tmux}/bin/tmux -f ${pkgs.writeText "tmux.conf" '' set-option -g prefix ` unbind-key C-b bind ` send-prefix set-option -g status off set-option -g default-terminal screen-256color #use session instead of windows bind-key c new-session bind-key p switch-client -p bind-key n switch-client -n bind-key C-s switch-client -l ''} "$@" ''; in { description = "chat environment setup"; after = [ "network.target" ]; wantedBy = [ "multi-user.target" ]; restartIfChanged = false; path = [ pkgs.rxvt_unicode.terminfo ]; serviceConfig = { User = "lass"; RemainAfterExit = true; Type = "oneshot"; ExecStart = "${tmux} -2 new-session -d -s IM ${pkgs.weechat}/bin/weechat"; ExecStop = "${tmux} kill-session -t IM"; }; }; services.dovecot2 = { enable = true; mailLocation = "maildir:~/Maildir"; }; }