Compare commits

...

6 commits

53 changed files with 86 additions and 313 deletions

View file

@ -11,33 +11,8 @@
./hardware-configuration.nix
../../common.nix
../../modules
#inputs.mms.module
];
#nixpkgs = {
#overlays = [
#(self: super: {
#linux_zen_xeniafied = pkgs.linuxPackagesFor (pkgs.linuxKernel.kernels.linux_zen.override {
#structuredExtraConfig = with lib.kernel; {
##"FB" = yes;
##"FRAMEBUFFER_CONSOLE" = yes;
##"VGA_CONSOLE" = yes;
##"VIDEO_SELECT" = yes;
#LOGO = lib.mkForce yes;
#LOGO_LINUX_CLUT224 = yes;
#};
#ignoreConfigErrors = true;
#});
#})
#];
#};
#boot.kernelPatches = [
#{
#name = "fomx";
#patch = ../other/0001-fomx.patch;
#}
#];
boot.binfmt.emulatedSystems = ["aarch64-linux"];
jade = {
@ -59,7 +34,6 @@
"/".options = ["compress=zstd:3"];
"/home".options = ["compress=zstd:3"];
"/nix".options = ["compress=zstd:3" "noatime"];
#"/swap".options = [ "noatime" ];
};
boot.loader.systemd-boot.enable = true;
@ -71,27 +45,8 @@
networking.hostName = "potatobook-g";
services.autorandr = {
enable = true;
profiles = {
"default" = {
config = {
"eDP-1" = {
enable = true;
mode = "1920x1200";
};
};
};
};
};
# hardware.keyboard.uhk.enable = true;
hardware.enableRedistributableFirmware = true;
environment.systemPackages = with pkgs; [
android-tools
];
environment.pathsToLink = [
"/share/nix-direnv"
];
@ -106,43 +61,6 @@
systemd.services."NetworkManager-wait-online".enable = false;
# services.pixiecore =
# let
# nixpkgs = builtins.getFlake "nixpkgs/nixos-unstable";
# sys = nixpkgs.lib.nixosSystem {
# system = "x86_64-linux";
# modules = [
# ({config, pkgs, lib, modulesPath, ...}: {
# imports = [
# (modulesPath + "/installer/netboot/netboot-base.nix")
# ];
# services.getty.autologinUser = lib.mkForce "root";
# console.keyMap = "de";
# system.stateVersion = config.system.nixos.release;
# environment.systemPackages = with pkgs; [
# helix nil git neofetch
# ];
# programs = {
# zsh = {
# enable = true;
# enableCompletion = true;
# };
# };
# })
# ];
# };
# build = sys.config.system.build;
# in {
# enable = true;
# openFirewall = true;
# kernel = "${build.kernel}/bzImage";
# initrd = "${build.netbootRamdisk}/initrd";
# cmdLine = "init=${build.toplevel}/init loglevel=4";
# };
systemd.services = {
create-swapfile = {
serviceConfig.Type = "oneshot";

View file

@ -3,12 +3,11 @@
./audio.nix
./eduroam.nix
./home
./media
./dm.nix
./tlp.nix
./locale.nix
./printing.nix
./stylix.nix
./themeing.nix
];
services.flatpak.enable = true;
security.polkit.enable = true;

View file

@ -14,6 +14,7 @@
foreground = "#ebdbb2";
frame_color = "#504945";
frame_width = 2;
font = "Atkinson Hyperlegible";
};
};
};

View file

@ -38,5 +38,17 @@
dunst.enable = false;
wofi.enable = false;
};
gtk = {
enable = true;
cursorTheme = {
package = pkgs.phinger-cursors;
name = "phinger-cursors";
size = 30;
};
iconTheme = {
package = pkgs.gruvbox-dark-icons-gtk;
name = "gruvbox-dark-icons";
};
};
};
}

View file

@ -3,9 +3,10 @@
./shell
./desktop
./hardware
./firewall.nix
./desktop-environment
./de
./net
./input
./media
./graphics.nix
];
}

View file

@ -7,11 +7,8 @@
with lib; {
imports = [
./gaming.nix
# TODO: more fine grained choices, not every setup needs fspy or rawtherapee
./syncthing.nix
./kdeconnect.nix
./themeing.nix
./networking.nix
./social.nix
];

View file

@ -1,69 +0,0 @@
{
config,
lib,
pkgs,
...
}: let
addNuShebang = path:
builtins.concatStringsSep "\n\n" [
"#!${pkgs.nushell}/bin/nu"
(builtins.readFile path)
];
in {
config = {
networking = {
networkmanager = {
wifi.backend = "wpa_supplicant";
dispatcherScripts = [
{
type = "basic";
source = pkgs.writeText "dispatcher" (addNuShebang ../../other/scripts/dispatcher.nu);
}
];
};
hosts = {
"127.0.0.1" = [
"www.tiktok.com"
"www.twitter.com"
"www.instagram.com"
"www.facebook.com"
"www.snapchat.com"
"tiktok.com"
"twitter.com"
"instagram.com"
"facebook.com"
"snapchat.com"
"google-analytics.com"
"stats.g.doubleclick.net"
"googleadservices.com"
"googletagmanager.com"
"googletagservices.com"
"googlesyndication.com"
];
};
};
environment.etc = with builtins; (
listToAttrs (
map (v: {
name = "networkhooks/${v}";
value = {
text = addNuShebang ../../other/scripts/networkhooks/${v};
mode = "0755";
};
})
(attrNames (readDir ../../other/scripts/networkhooks))
)
);
systemd.services."NetworkManager-wait-online".enable = false;
services.mullvad-vpn.enable = true;
home-manager.users.jade = {pkgs, ...}: {
home.packages = with pkgs; [
networkmanagerapplet
mullvad-vpn
macchanger
];
};
};
}

View file

@ -1,45 +0,0 @@
{
config,
lib,
pkgs,
...
}: {
config = {
# fonts.packages = with pkgs; [
# atkinson-hyperlegible
# ];
home-manager.users.jade = {pkgs, ...}: {
home.packages = with pkgs; [
# gtk-engine-murrine
# gruvbox-dark-gtk
gruvbox-dark-icons-gtk
];
gtk = {
# enable = true;
cursorTheme = {
package = pkgs.phinger-cursors;
name = "phinger-cursors";
size = 30;
};
# font = {
# package = pkgs.atkinson-hyperlegible;
# name = "Atkinson Hyperlegible";
# size = 11.5;
# };
iconTheme = {
package = pkgs.gruvbox-dark-icons-gtk;
name = "gruvbox-dark-icons";
};
};
# theme = {
# package = pkgs.gruvbox-dark-gtk;
# name = "gruvbox-dark";
# };
# };
# qt = {
# enable = true;
# platformTheme.name = "gtk";
# };
};
};
}

17
modules/net/default.nix Normal file
View file

@ -0,0 +1,17 @@
{...}: {
imports = [
./firewall.nix
./hosts.nix
./dispatchers
];
networking.networkmanager.wifi.backend = "wpa_supplicant";
systemd.services."NetworkManager-wait-online".enable = false;
services.mullvad-vpn.enable = true;
home-manager.users.jade = {pkgs, ...}: {
home.packages = with pkgs; [
networkmanagerapplet
mullvad-vpn
macchanger
];
};
}

View file

@ -0,0 +1,27 @@
{pkgs, ...}: let
addNuShebang = path:
builtins.concatStringsSep "\n\n" [
"#!${pkgs.nushell}/bin/nu"
(builtins.readFile path)
];
in {
networking.networkmanager.dispatcherScripts = [
{
type = "basic";
source = pkgs.writeText "dispatcher" (addNuShebang ./dispatcher.nu);
}
];
environment.etc = with builtins; (
listToAttrs (
map (v: {
name = "networkhooks/${v}";
value = {
text = addNuShebang ./hooks/${v};
mode = "0755";
};
})
(attrNames (readDir ./hooks))
)
);
}

24
modules/net/hosts.nix Normal file
View file

@ -0,0 +1,24 @@
{...}: {
networking.hosts = {
"127.0.0.1" = [
"www.tiktok.com"
"www.twitter.com"
"www.instagram.com"
"www.facebook.com"
"www.snapchat.com"
"tiktok.com"
"twitter.com"
"instagram.com"
"facebook.com"
"snapchat.com"
"google-analytics.com"
"stats.g.doubleclick.net"
"googleadservices.com"
"googletagmanager.com"
"googletagservices.com"
"googlesyndication.com"
];
};
}

View file

@ -1,10 +1,4 @@
{
pkgs,
config,
lib,
...
}: let
# generate shell command options for kmscon fom an attrset
{config, ...}: let
generateOptions = with builtins; (
opts:
toString (
@ -13,26 +7,6 @@
)
)
);
# generate a hexadecimal number lookup table to get integers from them
hexLookupTable = with lib; (listToAttrs (genList (i: {
name = let
r = toHexString i;
in (
# pad with 0 in front if only 1 digit
if (stringLength r) == 1
then "0${r}"
else r
);
value = toString i;
})
256));
# "parse" hex color strings and convert them to kmscon options
hexToOpt = with lib; (color:
concatStringsSep "," [
(getAttr (substring 1 2 (toUpper color)) hexLookupTable)
(getAttr (substring 3 2 (toUpper color)) hexLookupTable)
(getAttr (substring 5 2 (toUpper color)) hexLookupTable)
]);
in {
# TODO: global colorscheme vars for everything
console.colors = [
@ -56,37 +30,10 @@ in {
services.kmscon = {
enable = true;
# fonts = [
# {
# name = "Departure Mono Nerd Font";
# package = pkgs.nerd-fonts.departure-mono;
# }
# ];
extraConfig = "font-size=14";
# extraOptions = "--term xterm-256color";
extraOptions = generateOptions {
xkb-layout = config.services.xserver.xkb.layout;
xkb-variant = config.services.xserver.xkb.variant;
# palette = "custom";
# palette-foreground = hexToOpt "#ebdbb2";
# palette-background = hexToOpt "#282828";
# palette-black = hexToOpt "#282828";
# palette-red = hexToOpt "#cc241d";
# palette-green = hexToOpt "#98971a";
# palette-yellow = hexToOpt "#d79921";
# palette-blue = hexToOpt "#458588";
# palette-magenta = hexToOpt "#b16286";
# palette-cyan = hexToOpt "#689d6a";
# palette-light-grey = hexToOpt "#a89984";
# palette-dark-grey = hexToOpt "#928374";
# palette-light-red = hexToOpt "#fb4934";
# palette-light-green = hexToOpt "#b8bb26";
# palette-light-yellow = hexToOpt "#fabd2f";
# palette-light-blue = hexToOpt "#83a598";
# palette-light-magenta = hexToOpt "#d3869b";
# palette-light-cyan = hexToOpt "#8ec07c";
# palette-white = hexToOpt "#ebdbb2";
};
hwRender = true;
};

View file

@ -1,56 +0,0 @@
{
pkgs,
lib,
}: rec {
# taken from https://github.com/NixOS/nixpkgs/blob/3650808d85dccbfa3be3d785dfd3ce33a757bd2c/pkgs/build-support/trivial-builders/default.nix#L335
writeNuShellApplication = {
name,
text,
runtimeInputs ? [],
meta ? {},
checkPhase ? null,
}:
writeTextFile {
inherit name meta;
executable = true;
destination = "/bin/${name}";
allowSubstitutes = true;
preferLocalBuild = false;
text =
''
#!${pkgs.nushell}
''
+ lib.optionalString (runtimeInputs != []) ''
$env.PATH = ($env.PATH | split row (char esep) | prepend '${lib.makeBinPath runtimeInputs}');
''
+ ''
${text}
'';
checkPhase =
# GHC (=> shellcheck) isn't supported on some platforms (such as risc-v)
# but we still want to use writeShellApplication on those platforms
if checkPhase == null
then ''
runHook preCheck
nu -c "nu-check -d $target"
runHook postCheck
''
else checkPhase;
};
packageNushellApplication = {
name,
path,
runtimeInputs ? [],
meta ? {},
checkPhase ? null,
}:
writeNuShellApplication {
inherit name runtimeInputs meta checkPhase;
text = builtins.readFile path;
};
}