Bruno BELANYI
38440f67ab
home: add firefox
2021-05-08 17:14:13 +02:00
Bruno BELANYI
85f4220068
home: wm: i3: use udiskie service
2021-05-08 17:14:13 +02:00
Bruno BELANYI
43457ce41e
home: add udiskie
2021-05-08 17:14:13 +02:00
Bruno BELANYI
44cad6b52b
home: wm: i3: use flameshot service directly
...
Instead of starting `flameshot` with `i3`, use the provided service.
2021-05-08 17:14:13 +02:00
Bruno BELANYI
86b12dc8a8
home: add flameshot
2021-05-08 17:14:13 +02:00
Bruno BELANYI
61b36c5434
machines: aramis: home: enable zathura
2021-05-08 17:14:13 +02:00
Bruno BELANYI
bc6c50aff1
home: add zathura
2021-05-08 17:14:13 +02:00
Bruno BELANYI
3aa089db36
machines: aramis: home: enable termite
2021-05-08 17:14:13 +02:00
Bruno BELANYI
b7b1c77dc8
home: wm: i3: use 'my.home.terminal' explicitly
2021-05-08 17:14:13 +02:00
Bruno BELANYI
07b91de2f2
home: terminal: add termite
2021-05-08 17:14:13 +02:00
Bruno BELANYI
a4f3d67393
home: add terminal
...
This module abstracts away the color configuration.
2021-05-08 17:14:13 +02:00
Bruno BELANYI
b983136080
home: wm: i3: add configuration
2021-05-08 17:14:13 +02:00
Bruno BELANYI
f257c15071
home: wm: add rofi
2021-05-08 17:14:13 +02:00
Bruno BELANYI
82790ea5fa
home: wm: add i3bar
2021-05-08 17:14:13 +02:00
Bruno BELANYI
3d51af4f54
machines: aramis: home: enable X & i3
2021-05-08 17:14:13 +02:00
Bruno BELANYI
6af00fe351
machines: aramis: add home configuration
2021-05-08 17:14:13 +02:00
Bruno BELANYI
864e78bc61
modules: add home
...
This makes setting and referring to my home-manager options easier.
2021-05-08 17:14:13 +02:00
Bruno BELANYI
ca48df5674
home: wm: add i3
...
This is only the basic default configuration. The full configuration
will come later.
I am not a fan of `wm.windowManager`, I might rename that option at some
point.
2021-05-08 17:14:13 +02:00
Bruno BELANYI
ff4745e1e6
home: add X keyboard configuration
2021-05-08 17:14:13 +02:00
Bruno BELANYI
63791a98a4
machines: add aramis
2021-05-08 17:14:13 +02:00
Bruno BELANYI
9690b0b14b
lib: attrs: add renaming functions
2021-05-08 17:14:13 +02:00
Bruno BELANYI
af317ac156
lib: attrs: document functions
2021-05-08 17:14:13 +02:00
Bruno BELANYI
b30d574069
lib: attrs: add genAttrs' function
2021-05-08 17:14:13 +02:00
Bruno BELANYI
825e09f59e
flake: refactor handling of shared modules
2021-05-08 17:14:13 +02:00
Bruno BELANYI
817ca1e9df
machine: aramis: add installer script
...
This is the first time that I am setting up LVM-on-LUKS with NixOS, so a
VM came in handy to test it out.
2021-05-08 17:14:13 +02:00
Bruno BELANYI
5041fc7472
project: add bootstrap script
2021-05-08 17:14:13 +02:00
Bruno BELANYI
08c16bd27f
pkgs: diff-flake: add 'host' and 'shell' options
2021-05-08 17:14:13 +02:00
Bruno BELANYI
25823f4ee6
flake: bump inputs
2021-05-08 17:14:13 +02:00
Bruno BELANYI
2a1dda12d4
pkgs: diff-flake: use 'makeWrapper'
...
This makes it easier to test the script, as I just run it normally
without building it.
2021-05-08 17:14:13 +02:00
Bruno BELANYI
12475ff3a8
pkgs: diff-flake: do not default to verbose build
2021-05-08 17:14:13 +02:00
Bruno BELANYI
2fac46b606
pkgs: diff-flake: fix '--flake-output' handling
...
I'm surprised that `shellcheck` did not pick up this error, `INPUTS` was
leftover from the previous name of the variable before a refactor...
2021-05-08 17:14:13 +02:00
Bruno BELANYI
0ec56784e9
flake: use explicit input format
...
And reorder the inputs to be in alphabetical order, because that is
always neater :-).
2021-05-08 17:14:13 +02:00
Bruno BELANYI
f64454811e
pkgs: diff-flake: resolve given revs to commit ids
2021-05-08 17:14:13 +02:00
Bruno BELANYI
f817b278fe
pkgs: diff-flake: substitute 'mktemp'
2021-05-08 17:14:13 +02:00
Bruno BELANYI
37a134ebd2
flake: add 'diff-flake' to 'apps' and 'defaultApp'
...
That way I can just run `nix flake update`, commit, and `nix run` to get
a list of updates.
2021-05-08 17:14:13 +02:00
Bruno BELANYI
7d91351c8e
pkgs: add diff-flake
...
This is a nice helper to know what has changed after bumping a flake's
inputs.
2021-05-08 17:14:13 +02:00
Bruno BELANYI
9612258118
flake: do not throw on dirty tree
...
This is mostly inconvenient, I have enough discipline not to need it
anymore.
2021-04-25 12:39:17 +00:00
Bruno BELANYI
49232423ca
lib: ip: verify ip is valid in 'check'
2021-04-25 12:39:17 +00:00
Bruno BELANYI
0112dd87ac
lib: ip: add 'isValidIp4'
2021-04-25 12:39:17 +00:00
Bruno BELANYI
5a06ab74bb
lib: ip: add 'nth' utility to 'parseSubnet4'
2021-04-25 12:39:17 +00:00
Bruno BELANYI
1968285d0a
lib: ip: add 'nthInRange4'
...
And use it to refactor 'rangeIp4'
2021-04-25 12:39:17 +00:00
Bruno BELANYI
509332270e
services: wireguard: refactor DNS configuration
2021-04-25 12:39:17 +00:00
Bruno BELANYI
05c9a46cde
services: wireguard: add internal-only option
2021-04-25 12:39:17 +00:00
Bruno BELANYI
196f9a3e34
services: wireguard: fix server routing
...
I had made a mistake, hard-coding the server as being `1` for its client
number, instead of using the one configured from its peer configuration.
2021-04-25 12:39:17 +00:00
Bruno BELANYI
26eac86de0
services: wireguard: clean up logic
...
This module has a complicated logic, and I found the code quite ugly.
making use of `mkMerge` makes it easier to read and think through.
2021-04-25 12:39:17 +00:00
Bruno BELANYI
84b61b25b3
services: wireguard: allow disabling service
...
Only the server *needs* to have wireguard up at all times. However a
laptop or desktop probably doesn't need it up at all times.
2021-04-25 12:39:17 +00:00
Bruno BELANYI
f79fcd020b
services: wireguard: set up DNS server on clients
...
This makes use of my newly written adblocking DNS service, it does
assume that the server would have both wireguard and DNS enabled.
I would also like to move to using my ip-related library functions,
however it does not support IPv6 and is unlikely to be easily added...
But I am not sure that I *need* IPv6 support for my use-case.
Finally, I find this module a bit too heavy, it could be improved by
having specific 'server' and 'client' roles, instead of implicit roles
depending on whether an external IP exists.
2021-04-25 12:39:17 +00:00
Bruno BELANYI
3696471201
services: adblock: restrict to wireguard interface
2021-04-25 12:39:17 +00:00
Bruno BELANYI
a551ace6a6
machines: porthos: services: enable adblock
2021-04-25 12:39:17 +00:00
Bruno BELANYI
5b0d12ad40
services: add adblock
...
This is a self-hosted DNS server with hosts-based adblocking.
I should probably have it update the hosts file more often than I will
probably end up doing myself with a package... We'll see if it ends up
being necessary.
2021-04-25 12:39:17 +00:00