blob: 5117187d6b98627daf98071726ca069f3880986f (
plain) (
blame)
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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
|
{ config, lib, pkgs, ... }:
# Everything in here needs to work on linux or darwin, with or without a desktop
# environment
{
imports = [
../modules/shell.nix
# ../modules/development.nix
../modules/emacs.nix
../modules/vim.nix
../modules/tarsnap.nix
../modules/twitter.nix
../modules/lib/cloneRepo.nix
];
home.username = "aspen";
home.homeDirectory = "/home/aspen";
programs.password-store.enable = true;
aspen.impure.clonedRepos.passwordStore = {
github = "glittershark/pass";
path = ".local/share/password-store";
};
home.packages = with pkgs; [
# System utilities
bat
htop
killall
bind
zip
unzip
tree
nmap
bc
pv
# Security
gnupg
keybase
openssl
# Nix things
nixfmt-classic
nix-prefetch-github
nixpkgs-review
cachix
(writeShellScriptBin "rebuild-mugwump" ''
set -eo pipefail
cd ~/code/depot
nix build -f . users.aspen.system.system.mugwumpSystem -o /tmp/mugwump
nix copy -f . users.aspen.system.system.mugwumpSystem \
--to ssh://mugwump
system=$(readlink -ef /tmp/mugwump)
ssh mugwump sudo nix-env -p /nix/var/nix/profiles/system --set $system
ssh mugwump sudo $system/bin/switch-to-configuration switch
rm /tmp/mugwump
'')
(writeShellScriptBin "rebuild-roswell" ''
set -eo pipefail
cd ~/code/depot
nix build -f . users.aspen.system.system.roswellSystem -o /tmp/roswell
nix copy -f . users.aspen.system.system.roswellSystem \
--to ssh://roswell
system=$(readlink -ef /tmp/roswell)
ssh roswell sudo nix-env -p /nix/var/nix/profiles/system --set $system
ssh roswell sudo $system/bin/switch-to-configuration switch
rm /tmp/roswell
'')
(writeShellScriptBin "rebuild-home" ''
set -eo pipefail
cd ~/code/depot
home=$(nix-build -A users.aspen.system.home.$(hostname)Home -o /tmp/home)
nix-env -p /nix/var/nix/per-user/aspen/home --set $home
$home/activate
'')
];
programs.ssh = { enable = true; };
programs.direnv = {
enable = true;
enableBashIntegration = true;
enableZshIntegration = true;
};
}
|