refactor(sterni/edwin): move generic settings into module
These settings would also be applied to a machine that'd replace edwin, so it's useful to have them outside edwin's default.nix. Change-Id: I4e8f464118a103645e53909a87c6ee4446022fa3 Reviewed-on: https://cl.tvl.fyi/c/depot/+/10125 Reviewed-by: sterni <sternenseemann@systemli.org> Autosubmit: sterni <sternenseemann@systemli.org> Tested-by: BuildkiteCI
This commit is contained in:
parent
5161c3c072
commit
897ee4ad26
2 changed files with 81 additions and 64 deletions
|
@ -4,6 +4,8 @@
|
||||||
imports = [
|
imports = [
|
||||||
# Third party modules we use
|
# Third party modules we use
|
||||||
"${depot.third_party.agenix.src}/modules/age.nix"
|
"${depot.third_party.agenix.src}/modules/age.nix"
|
||||||
|
# Basic settings
|
||||||
|
../../modules/common.nix
|
||||||
# These modules touch things related to booting (filesystems, initrd network…)
|
# These modules touch things related to booting (filesystems, initrd network…)
|
||||||
./hardware.nix
|
./hardware.nix
|
||||||
./network.nix
|
./network.nix
|
||||||
|
@ -18,70 +20,6 @@
|
||||||
];
|
];
|
||||||
|
|
||||||
config = {
|
config = {
|
||||||
time.timeZone = "Europe/Berlin";
|
|
||||||
|
|
||||||
nix = {
|
|
||||||
package = pkgs.nix_2_3;
|
|
||||||
settings = {
|
|
||||||
trusted-public-keys = lib.mkAfter [
|
|
||||||
"headcounter.org:/7YANMvnQnyvcVB6rgFTdb8p5LG1OTXaO+21CaOSBzg="
|
|
||||||
];
|
|
||||||
substituters = lib.mkAfter [
|
|
||||||
"https://hydra.build"
|
|
||||||
];
|
|
||||||
};
|
|
||||||
};
|
|
||||||
tvl.cache.enable = true;
|
|
||||||
|
|
||||||
services = {
|
|
||||||
journald.extraConfig = ''
|
|
||||||
SystemMaxUse=1024M
|
|
||||||
'';
|
|
||||||
|
|
||||||
openssh.enable = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
security.acme = {
|
|
||||||
defaults.email = builtins.getAttr "email" (
|
|
||||||
builtins.head (
|
|
||||||
builtins.filter (attrs: attrs.username == "sterni") depot.ops.users
|
|
||||||
)
|
|
||||||
);
|
|
||||||
acceptTerms = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
programs = {
|
|
||||||
fish.enable = true;
|
|
||||||
mosh.enable = true;
|
|
||||||
tmux.enable = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
environment.systemPackages = [
|
|
||||||
pkgs.weechat
|
|
||||||
pkgs.wget
|
|
||||||
pkgs.git
|
|
||||||
pkgs.stow
|
|
||||||
pkgs.htop
|
|
||||||
pkgs.foot.terminfo
|
|
||||||
pkgs.vim
|
|
||||||
];
|
|
||||||
|
|
||||||
users = {
|
|
||||||
users = {
|
|
||||||
root.openssh.authorizedKeys.keys = depot.users.sterni.keys.all;
|
|
||||||
lukas = {
|
|
||||||
isNormalUser = true;
|
|
||||||
extraGroups = [ "wheel" "http" "git" ];
|
|
||||||
openssh.authorizedKeys.keys = depot.users.sterni.keys.all;
|
|
||||||
shell = "${pkgs.fish}/bin/fish";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
nix.settings.trusted-users = [
|
|
||||||
"lukas"
|
|
||||||
];
|
|
||||||
|
|
||||||
system.stateVersion = "20.09";
|
system.stateVersion = "20.09";
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
79
users/sterni/modules/common.nix
Normal file
79
users/sterni/modules/common.nix
Normal file
|
@ -0,0 +1,79 @@
|
||||||
|
# This module is common in the weakest sense, i.e. contains common settings to
|
||||||
|
# all my machines contained in depot—as opposed to common to all my potential
|
||||||
|
# machines. Consequently, this module is currently very server-centric.
|
||||||
|
{ pkgs, lib, depot, config, ... }:
|
||||||
|
|
||||||
|
let
|
||||||
|
me = "lukas";
|
||||||
|
in
|
||||||
|
|
||||||
|
{
|
||||||
|
config = {
|
||||||
|
|
||||||
|
# More common
|
||||||
|
|
||||||
|
time.timeZone = "Europe/Berlin";
|
||||||
|
|
||||||
|
nix = {
|
||||||
|
package = pkgs.nix_2_3;
|
||||||
|
settings = {
|
||||||
|
trusted-public-keys = lib.mkAfter [
|
||||||
|
"headcounter.org:/7YANMvnQnyvcVB6rgFTdb8p5LG1OTXaO+21CaOSBzg="
|
||||||
|
];
|
||||||
|
substituters = lib.mkAfter [
|
||||||
|
"https://hydra.build"
|
||||||
|
];
|
||||||
|
trusted-users = [ me ];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
tvl.cache.enable = true;
|
||||||
|
|
||||||
|
programs.fish.enable = true;
|
||||||
|
|
||||||
|
users = {
|
||||||
|
users = {
|
||||||
|
root.openssh.authorizedKeys.keys = depot.users.sterni.keys.all;
|
||||||
|
${me} = {
|
||||||
|
isNormalUser = true;
|
||||||
|
extraGroups = [ "wheel" "http" "git" ];
|
||||||
|
openssh.authorizedKeys.keys = depot.users.sterni.keys.all;
|
||||||
|
shell = pkgs.fish;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
# Less common
|
||||||
|
|
||||||
|
services = {
|
||||||
|
journald.extraConfig = ''
|
||||||
|
SystemMaxUse=1024M
|
||||||
|
'';
|
||||||
|
|
||||||
|
openssh.enable = true;
|
||||||
|
};
|
||||||
|
|
||||||
|
programs = {
|
||||||
|
mosh.enable = true;
|
||||||
|
tmux.enable = true;
|
||||||
|
};
|
||||||
|
|
||||||
|
environment.systemPackages = [
|
||||||
|
pkgs.weechat
|
||||||
|
pkgs.wget
|
||||||
|
pkgs.git
|
||||||
|
pkgs.stow
|
||||||
|
pkgs.htop
|
||||||
|
pkgs.foot.terminfo
|
||||||
|
pkgs.vim
|
||||||
|
];
|
||||||
|
|
||||||
|
security.acme = {
|
||||||
|
defaults.email = builtins.getAttr "email" (
|
||||||
|
builtins.head (
|
||||||
|
builtins.filter (attrs: attrs.username == "sterni") depot.ops.users
|
||||||
|
)
|
||||||
|
);
|
||||||
|
acceptTerms = true;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
Loading…
Reference in a new issue