summaryrefslogtreecommitdiff
path: root/modules/common.nix
blob: 161d3763dfc6c735847f4a10173cd2be5a0358b9 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
{ config, lib, pkgs, ... }:
{
  programs.zsh.enable = true;
  programs.tmux.enable = true;

  nixpkgs.config.packageOverrides = pkgs: {
    libsignal-protocol-c = pkgs.callPackage ../pkgs/libsignal-c/default.nix { };
    keycloak = pkgs.callPackage ../pkgs/keycloak/default.nix { };
  };

  environment.shellAliases = {
    vim = "nvim";
  };
  environment.systemPackages = with pkgs; [
    dnsutils
    git
    gnupg
    haskellPackages.hledger
    htop
    mosh
    neovim
    # nox  # Broken as of 2017-06-12
    pass
    silver-searcher
    whois
    unzip
    p7zip
    unrar
  ];
  time.timeZone = "America/New_York";

  services = {
    postgresql = {
      dataDir = "/var/db/postgresql";
      package = pkgs.postgresql95;
    };
    openssh.passwordAuthentication = false;
  };

  nix = rec {
    useSandbox = lib.mkDefault true;
    maxJobs = lib.mkOverride 110 16;
    buildCores = lib.mkDefault 0;  # auto configure
    gc.automatic = lib.mkDefault true;
    trustedBinaryCaches = [
      "https://cache.nixos.org"
    ];
    binaryCaches = trustedBinaryCaches;
    daemonNiceLevel = 10;
    daemonIONiceLevel = 10;
    package = pkgs.nixFlakes;
    extraOptions = ''
      experimental-features = nix-command flakes
    '';
  };

  boot.cleanTmpDir = true;

  nixpkgs.config.allowUnfree = true;
}