{ pkgs, lib, config, options, ... }: let inherit (lib.strings) makeBinPath; inherit (import ) localAddresses kieran; in { imports = [ { boot.supportedFilesystems = [ "ntfs" ]; } { nix.nixPath = [ "/var/src" "nixpkgs-overlays=${toString ../overlays}" ]; } { services.dbus.packages = [ pkgs.gnome3.dconf ]; } { nixpkgs = { config = { allowUnfree = true; packageOverrides = pkgs: { nur = import { inherit pkgs; }; writeDashBin = pkgs.writers.writeDashBin; writeDash = pkgs.writers.writeDash; gfs-fonts = pkgs.callPackage {}; iolanguage = pkgs.callPackage { }; ix = pkgs.callPackage { }; }; }; overlays = [ (self: super: { scripts = import { pkgs = super; lib = super.lib; }; }) (import ) (import ) (import ) ]; }; } { boot.cleanTmpDir = true; boot.loader.timeout = 1; } { home-manager.users.me = { programs.zathura = { enable = true; options = { selection-clipboard = "clipboard"; # first-page-column = "1:1"; # makes side-by-side mode start on the left side }; }; }; } { users.mutableUsers = false; users.defaultUserShell = pkgs.zsh; users.users.me = { name = "kfm"; description = kieran.name; hashedPassword = "$6$w9hXyGFl/.IZBXk$5OiWzS1G.5hImhh1YQmZiCXYNAJhi3X6Y3uSLupJNYYXPLMsQpx2fwF4Xr2uYzGMV8Foqh8TgUavx1APD9rcb/"; isNormalUser = true; uid = 1000; }; home-manager.users.me.xdg.enable = true; } { sound.enable = true; hardware.pulseaudio = { enable = true; package = pkgs.pulseaudioFull; extraModules = [ pkgs.pulseaudio-modules-bt ]; # copy server:/run/pulse/.config/pulse/cookie to client:~/.config/pulse/cookie to authenticate a client machine zeroconf.discovery.enable = true; extraConfig = '' load-module ${toString [ "module-tunnel-sink-new" "server=zaatar.r" "sink_name=zaatar" "channels=2" "rate=44100" ]} ''; }; users.users.me.extraGroups = [ "audio" ]; environment.systemPackages = [ pkgs.pavucontrol pkgs.ncpamixer pkgs.pamixer pkgs.pulsemixer ]; } { environment.interactiveShellInit = "export PATH=$PATH:$HOME/projects/niveum"; environment.shellAliases = let wcd = pkgs.writers.writeDash "wcd" '' cd "$(readlink "$(${pkgs.which}/bin/which --skip-alias "$1")" | xargs dirname)/.." ''; where = pkgs.writers.writeDash "where" '' readlink "$(${pkgs.which}/bin/which --skip-alias "$1")" | xargs dirname ''; take = pkgs.writers.writeDash "take" '' mkdir "$1" && cd "$1" ''; swallow = command: "${pkgs.scripts.swallow}/bin/swallow ${command}"; in { "ß" = "${pkgs.utillinux}/bin/setsid"; cat = "${pkgs.bat}/bin/bat --style=plain"; chromium-incognito = "chromium --user-data-dir=$(mktemp -d /tmp/chr.XXXXXX) --no-first-run --incognito"; cp = "cp --interactive"; ip = "${pkgs.iproute}/bin/ip -c"; l = "ls --color=auto --time-style=long-iso --almost-all"; ls = "ls --color=auto --time-style=long-iso"; ll = "ls --color=auto --time-style=long-iso -l"; la = "ls --color=auto --time-style=long-iso --almost-all -l"; mv = "mv --interactive"; nixi = "nix repl ''"; ns = "nix-shell --run zsh"; o = "${pkgs.xdg_utils}/bin/xdg-open"; pbcopy = "${pkgs.xclip}/bin/xclip -selection clipboard -in"; pbpaste = "${pkgs.xclip}/bin/xclip -selection clipboard -out"; rm = "rm --interactive"; s = "${pkgs.systemd}/bin/systemctl"; take = "source ${take}"; tmux = "${pkgs.tmux}/bin/tmux -2"; sxiv = swallow "${pkgs.sxiv}/bin/sxiv"; zathura = swallow "${pkgs.zathura}/bin/zathura"; us = "${pkgs.systemd}/bin/systemctl --user"; wcd = "source ${wcd}"; im = "${pkgs.openssh}/bin/ssh weechat@makanek -t tmux attach-session -t IM"; where = "source ${where}"; yt = "${pkgs.youtube-dl}/bin/youtube-dl --add-metadata -ic"; # Download video link yta = "${pkgs.youtube-dl}/bin/youtube-dl --add-metadata -xic"; # Download with audio }; } { i18n.defaultLocale = "en_GB.UTF-8"; } { services.illum.enable = true; } { services.xserver = { enable = true; displayManager = { autoLogin = { enable = true; user = config.users.users.me.name; }; lightdm = { enable = true; greeters.gtk = { enable = true; indicators = [ "~spacer" "~host" "~spacer" "~session" "~power" ]; }; }; }; }; } { security.wrappers = { pmount.source = "${pkgs.pmount}/bin/pmount"; pumount.source = "${pkgs.pmount}/bin/pumount"; }; } { programs.command-not-found.enable = true; } { programs.gnupg.agent.enable = true; environment.systemPackages = [ pkgs.gnupg (pkgs.pass.withExtensions (e: [e.pass-otp])) ]; } { services.atd.enable = true; } { services.getty = { greetingLine = lib.mkForce ""; helpLine = lib.mkForce ""; }; } { networking.hosts = lib.mapAttrs' (name: address: { name = address; value = [ "${name}.local" ]; }) localAddresses; } ./alacritty.nix ./bash.nix ./beets.nix ./bluetooth.nix ./ccc.nix # ./kleiter.nix ./khal.nix ./engiadina.nix ./chromium.nix ./cloud.nix ./compton.nix ./direnv.nix ./distrobump.nix ./docker.nix ./dunst.nix ./flix.nix ./fonts.nix ./fzf.nix ./gaslight.nix ./git.nix ./hledger.nix ./htop.nix ./hu-berlin.nix ./i3.nix ./keybase.nix ./keyboard.nix ./mail/client.nix ./mpv.nix ./mime.nix ./nano.nix ./neovim.nix ./nix.nix ./newsboat.nix ./flameshot-once.nix ./packages ./power-action.nix ./printing.nix ./openweathermap.nix ./wallpaper.nix ./redshift.nix ./retiolum.nix ./rofi.nix ./spacetime.nix ./seafile.nix ./ssh.nix ./sshd.nix ./sudo.nix ./sxiv.nix ./theming.nix ./tmux.nix ./tor.nix ./traadfri.nix ./unclutter.nix ./version.nix ./vscode.nix ./watson.nix ./wifi.nix ./zsh.nix ]; }