restructure
This commit is contained in:
parent
4922f8f7cb
commit
ffe40ca5e7
25 changed files with 84 additions and 66 deletions
|
|
@ -1,9 +1,12 @@
|
||||||
{ var, ... }:
|
{ var, ... }:
|
||||||
{
|
{
|
||||||
imports = [
|
imports = [
|
||||||
|
../mod
|
||||||
|
../desktop
|
||||||
./boot.nix
|
./boot.nix
|
||||||
./locale.nix
|
./locale.nix
|
||||||
./nix.nix
|
./nix.nix
|
||||||
|
./security.nix
|
||||||
./shell.nix
|
./shell.nix
|
||||||
./users.nix
|
./users.nix
|
||||||
];
|
];
|
||||||
22
common/security.nix
Normal file
22
common/security.nix
Normal file
|
|
@ -0,0 +1,22 @@
|
||||||
|
{
|
||||||
|
config,
|
||||||
|
lib,
|
||||||
|
pkgs,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
{
|
||||||
|
security = {
|
||||||
|
protectKernelImage = true;
|
||||||
|
sudo.enable = false;
|
||||||
|
doas = {
|
||||||
|
enable = true;
|
||||||
|
extraRules = [
|
||||||
|
{
|
||||||
|
groups = [ "wheel" ];
|
||||||
|
persist = true;
|
||||||
|
keepEnv = true;
|
||||||
|
}
|
||||||
|
];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
@ -6,18 +6,13 @@
|
||||||
];
|
];
|
||||||
|
|
||||||
environment.systemPackages = with pkgs; [
|
environment.systemPackages = with pkgs; [
|
||||||
bc
|
|
||||||
docker-compose
|
docker-compose
|
||||||
fd
|
fd
|
||||||
gh
|
|
||||||
htop
|
htop
|
||||||
killall
|
killall
|
||||||
ripgrep
|
ripgrep
|
||||||
starship
|
|
||||||
stow
|
|
||||||
unzip
|
unzip
|
||||||
wget
|
wget
|
||||||
wl-clipboard
|
|
||||||
colmena
|
colmena
|
||||||
unison
|
unison
|
||||||
dnsutils
|
dnsutils
|
||||||
|
|
@ -25,7 +20,6 @@
|
||||||
|
|
||||||
programs = {
|
programs = {
|
||||||
fish.enable = true;
|
fish.enable = true;
|
||||||
git.enable = true;
|
|
||||||
tmux = {
|
tmux = {
|
||||||
enable = true;
|
enable = true;
|
||||||
clock24 = true;
|
clock24 = true;
|
||||||
|
|
@ -5,11 +5,11 @@
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
let
|
let
|
||||||
cfg = config.desktop.audio;
|
cfg = config.hd.desktop.audio;
|
||||||
inherit (lib) mkEnableOption mkIf;
|
inherit (lib) mkEnableOption mkIf;
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
options.desktop.audio.enable = mkEnableOption "Audio";
|
options.hd.desktop.audio.enable = mkEnableOption "Audio";
|
||||||
|
|
||||||
config = mkIf cfg.enable {
|
config = mkIf cfg.enable {
|
||||||
environment.systemPackages = with pkgs; [
|
environment.systemPackages = with pkgs; [
|
||||||
|
|
@ -6,7 +6,7 @@
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
let
|
let
|
||||||
cfg = config.desktop;
|
cfg = config.hd.desktop;
|
||||||
inherit (lib) mkEnableOption mkIf;
|
inherit (lib) mkEnableOption mkIf;
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
|
|
@ -23,7 +23,7 @@ in
|
||||||
];
|
];
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
desktop.enable = mkEnableOption "Desktop Configuration";
|
hd.desktop.enable = mkEnableOption "Desktop Configuration";
|
||||||
home = lib.mkOption {
|
home = lib.mkOption {
|
||||||
type = lib.types.attrsOf lib.types.str;
|
type = lib.types.attrsOf lib.types.str;
|
||||||
default = { };
|
default = { };
|
||||||
|
|
@ -32,7 +32,7 @@ in
|
||||||
};
|
};
|
||||||
|
|
||||||
config = mkIf cfg.enable {
|
config = mkIf cfg.enable {
|
||||||
desktop = {
|
hd.desktop = {
|
||||||
audio.enable = true;
|
audio.enable = true;
|
||||||
fonts.enable = true;
|
fonts.enable = true;
|
||||||
gpg.enable = true;
|
gpg.enable = true;
|
||||||
|
|
@ -5,11 +5,11 @@
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
let
|
let
|
||||||
cfg = config.desktop.fonts;
|
cfg = config.hd.desktop.fonts;
|
||||||
inherit (lib) mkEnableOption mkIf;
|
inherit (lib) mkEnableOption mkIf;
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
options.desktop.fonts.enable = mkEnableOption "Fonts";
|
options.hd.desktop.fonts.enable = mkEnableOption "Fonts";
|
||||||
config = mkIf cfg.enable {
|
config = mkIf cfg.enable {
|
||||||
fonts = {
|
fonts = {
|
||||||
packages = with pkgs; [
|
packages = with pkgs; [
|
||||||
|
|
@ -5,11 +5,11 @@
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
let
|
let
|
||||||
cfg = config.desktop.gpg;
|
cfg = config.hd.desktop.gpg;
|
||||||
inherit (lib) mkEnableOption mkIf;
|
inherit (lib) mkEnableOption mkIf;
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
options.desktop.gpg.enable = mkEnableOption "GPG";
|
options.hd.desktop.gpg.enable = mkEnableOption "GPG";
|
||||||
config = mkIf cfg.enable {
|
config = mkIf cfg.enable {
|
||||||
home = {
|
home = {
|
||||||
home.packages = with pkgs; [
|
home.packages = with pkgs; [
|
||||||
|
|
@ -6,11 +6,11 @@
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
let
|
let
|
||||||
cfg = config.desktop.network;
|
cfg = config.hd.desktop.network;
|
||||||
inherit (lib) mkEnableOption mkIf;
|
inherit (lib) mkEnableOption mkIf;
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
options.desktop.network = {
|
options.hd.desktop.network = {
|
||||||
enable = mkEnableOption "All Network Options";
|
enable = mkEnableOption "All Network Options";
|
||||||
};
|
};
|
||||||
|
|
||||||
18
desktop/security.nix
Normal file
18
desktop/security.nix
Normal file
|
|
@ -0,0 +1,18 @@
|
||||||
|
{
|
||||||
|
config,
|
||||||
|
lib,
|
||||||
|
pkgs,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
let
|
||||||
|
cfg = config.hd.desktop.security;
|
||||||
|
inherit (lib) mkEnableOption mkIf;
|
||||||
|
in
|
||||||
|
{
|
||||||
|
options.hd.desktop.security.enable = mkEnableOption "Security";
|
||||||
|
config = mkIf cfg.enable {
|
||||||
|
security = {
|
||||||
|
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
@ -5,11 +5,11 @@
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
let
|
let
|
||||||
cfg = config.desktop.services;
|
cfg = config.hd.desktop.services;
|
||||||
inherit (lib) mkEnableOption mkIf;
|
inherit (lib) mkEnableOption mkIf;
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
options.desktop.services.enable = mkEnableOption "Services";
|
options.hd.desktop.services.enable = mkEnableOption "Services";
|
||||||
|
|
||||||
config = mkIf cfg.enable {
|
config = mkIf cfg.enable {
|
||||||
services = {
|
services = {
|
||||||
|
|
@ -5,31 +5,35 @@
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
let
|
let
|
||||||
cfg = config.desktop.software;
|
cfg = config.hd.desktop.software;
|
||||||
inherit (lib) mkEnableOption mkIf;
|
inherit (lib) mkEnableOption mkIf;
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
imports = [ ./development.nix ];
|
imports = [ ./development.nix ];
|
||||||
|
|
||||||
options.desktop.software.enable = mkEnableOption "Software";
|
options.hd.desktop.software.enable = mkEnableOption "Software";
|
||||||
|
|
||||||
config = mkIf cfg.enable {
|
config = mkIf cfg.enable {
|
||||||
desktop.software.development.enable = true;
|
hd.desktop.software.development.enable = true;
|
||||||
|
|
||||||
environment.systemPackages = with pkgs; [
|
environment.systemPackages = with pkgs; [
|
||||||
# vesktop
|
# vesktop
|
||||||
bitwarden
|
bitwarden
|
||||||
calibre
|
calibre
|
||||||
element-desktop
|
element-desktop
|
||||||
|
gh
|
||||||
kitty
|
kitty
|
||||||
nil
|
nil
|
||||||
obsidian
|
obsidian
|
||||||
rclone
|
rclone
|
||||||
signal-desktop
|
signal-desktop
|
||||||
spotify
|
spotify
|
||||||
|
starship
|
||||||
|
stow
|
||||||
tor-browser
|
tor-browser
|
||||||
vlc
|
vlc
|
||||||
wireguard-tools
|
wireguard-tools
|
||||||
|
wl-clipboard
|
||||||
zotero
|
zotero
|
||||||
zulip
|
zulip
|
||||||
];
|
];
|
||||||
|
|
@ -40,6 +44,7 @@ in
|
||||||
|
|
||||||
programs = {
|
programs = {
|
||||||
firefox.enable = true;
|
firefox.enable = true;
|
||||||
|
git.enable = true;
|
||||||
kdeconnect.enable = true;
|
kdeconnect.enable = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
@ -5,11 +5,11 @@
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
let
|
let
|
||||||
cfg = config.desktop.software.development;
|
cfg = config.hd.desktop.software.development;
|
||||||
inherit (lib) mkEnableOption mkIf;
|
inherit (lib) mkEnableOption mkIf;
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
options.desktop.software.development.enable = mkEnableOption "Dev Software";
|
options.hd.desktop.software.development.enable = mkEnableOption "Dev Software";
|
||||||
|
|
||||||
config = mkIf cfg.enable {
|
config = mkIf cfg.enable {
|
||||||
documentation.dev.enable = true;
|
documentation.dev.enable = true;
|
||||||
|
|
@ -5,11 +5,11 @@
|
||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
let
|
let
|
||||||
cfg = config.desktop.wm;
|
cfg = config.hd.desktop.wm;
|
||||||
inherit (lib) mkEnableOption mkIf;
|
inherit (lib) mkEnableOption mkIf;
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
options.desktop.wm.enable = mkEnableOption "Window Manager";
|
options.hd.desktop.wm.enable = mkEnableOption "Window Manager";
|
||||||
|
|
||||||
config = mkIf cfg.enable {
|
config = mkIf cfg.enable {
|
||||||
# Enable the KDE Plasma Desktop Environment.
|
# Enable the KDE Plasma Desktop Environment.
|
||||||
13
flake.nix
13
flake.nix
|
|
@ -45,9 +45,8 @@
|
||||||
};
|
};
|
||||||
modules = [
|
modules = [
|
||||||
./host/solo
|
./host/solo
|
||||||
./host
|
./home
|
||||||
./mod
|
./common
|
||||||
./mod-hm
|
|
||||||
overlays
|
overlays
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
|
|
@ -59,9 +58,8 @@
|
||||||
};
|
};
|
||||||
modules = [
|
modules = [
|
||||||
./host/c2
|
./host/c2
|
||||||
./host
|
./home
|
||||||
./mod
|
./common
|
||||||
./mod-hm
|
|
||||||
overlays
|
overlays
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
|
|
@ -81,8 +79,7 @@
|
||||||
};
|
};
|
||||||
imports = [
|
imports = [
|
||||||
./host/roam
|
./host/roam
|
||||||
./host
|
./common
|
||||||
./mod
|
|
||||||
overlays
|
overlays
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
|
|
|
||||||
|
|
@ -11,7 +11,7 @@
|
||||||
inputs.home-manager.nixosModules.home-manager
|
inputs.home-manager.nixosModules.home-manager
|
||||||
];
|
];
|
||||||
|
|
||||||
config = lib.mkIf config.desktop.enable {
|
config = lib.mkIf config.hd.desktop.enable {
|
||||||
home-manager.users."hd" = lib.mkAliasDefinitions options.home;
|
home-manager.users."hd" = lib.mkAliasDefinitions options.home;
|
||||||
# install to /etc/profiles, not ~/.nix-profile
|
# install to /etc/profiles, not ~/.nix-profile
|
||||||
home-manager.useUserPackages = true;
|
home-manager.useUserPackages = true;
|
||||||
|
|
@ -17,7 +17,7 @@
|
||||||
cpuFreqGovernor = "ondemand";
|
cpuFreqGovernor = "ondemand";
|
||||||
};
|
};
|
||||||
|
|
||||||
desktop.enable = true;
|
hd.desktop.enable = true;
|
||||||
|
|
||||||
nix = {
|
nix = {
|
||||||
buildMachines = [
|
buildMachines = [
|
||||||
|
|
@ -43,6 +43,10 @@
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
|
networking.firewall = {
|
||||||
|
enable = true;
|
||||||
|
};
|
||||||
|
|
||||||
# ====== DON'T CHANGE ======
|
# ====== DON'T CHANGE ======
|
||||||
system.stateVersion = "25.05";
|
system.stateVersion = "25.05";
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -13,11 +13,15 @@
|
||||||
cpuFreqGovernor = "performance";
|
cpuFreqGovernor = "performance";
|
||||||
};
|
};
|
||||||
|
|
||||||
desktop.enable = true;
|
hd.desktop.enable = true;
|
||||||
|
|
||||||
networking.useDHCP = false;
|
networking.useDHCP = false;
|
||||||
networking.interfaces.enp4s0.useDHCP = true;
|
networking.interfaces.enp4s0.useDHCP = true;
|
||||||
|
|
||||||
|
networking.firewall = {
|
||||||
|
enable = true;
|
||||||
|
};
|
||||||
|
|
||||||
# ====== DON'T CHANGE ======
|
# ====== DON'T CHANGE ======
|
||||||
system.stateVersion = "25.05";
|
system.stateVersion = "25.05";
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,5 @@
|
||||||
{
|
{
|
||||||
imports = [
|
imports = [
|
||||||
./nginx.nix
|
./nginx.nix
|
||||||
./desktop
|
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,28 +0,0 @@
|
||||||
{
|
|
||||||
config,
|
|
||||||
lib,
|
|
||||||
pkgs,
|
|
||||||
...
|
|
||||||
}:
|
|
||||||
let
|
|
||||||
cfg = config.desktop.security;
|
|
||||||
inherit (lib) mkEnableOption mkIf;
|
|
||||||
in
|
|
||||||
{
|
|
||||||
options.desktop.security.enable = mkEnableOption "Security";
|
|
||||||
config = mkIf cfg.enable {
|
|
||||||
security.protectKernelImage = true;
|
|
||||||
|
|
||||||
security.sudo.enable = false;
|
|
||||||
security.doas = {
|
|
||||||
enable = true;
|
|
||||||
extraRules = [
|
|
||||||
{
|
|
||||||
groups = [ "wheel" ];
|
|
||||||
persist = true;
|
|
||||||
keepEnv = true;
|
|
||||||
}
|
|
||||||
];
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue