init commit
This commit is contained in:
commit
5ab224ef8f
1
.gitignore
vendored
Normal file
1
.gitignore
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
secret.nix
|
3
.gitmodules
vendored
Normal file
3
.gitmodules
vendored
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
[submodule "imports/github/rycee/home-manager"]
|
||||||
|
path = imports/github/rycee/home-manager
|
||||||
|
url = https://github.com/rycee/home-manager.git
|
10
README.md
Normal file
10
README.md
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
NixOS Configurations
|
||||||
|
=======================
|
||||||
|
|
||||||
|
NixOS is an advanced GNU/Linux distribution featuring declarative configuration and atomic upgrades. You can learn more on [nixos.org](https://nixos.org/nixos/about.html).
|
||||||
|
|
||||||
|
In this repository are the configurations of my NixOS machines.
|
||||||
|
|
||||||
|
You can find the configurations from other people in the [nixos.wiki](https://nixos.wiki/wiki/Configuration_Collection).
|
||||||
|
|
||||||
|
Big Thanks for original config: [balsoft](https://github.com/balsoft/nixos-config)!
|
26
default.nix
Normal file
26
default.nix
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
# This is balsoft's configuration file.
|
||||||
|
#
|
||||||
|
# https://github.com/balsoft/nixos-config
|
||||||
|
#
|
||||||
|
# This is main nixos configuration
|
||||||
|
# To use this configuration:
|
||||||
|
# 1. Add your own secret.nix to this folder
|
||||||
|
# 2. Replace /etc/nixos/configuration.nix with the following:
|
||||||
|
# import /path/to/this/nixos-config "Vendor-Type"
|
||||||
|
# 3. Log in to application and services where neccesary
|
||||||
|
|
||||||
|
|
||||||
|
device: # This is the device we're on now
|
||||||
|
{ config, pkgs, lib, ... }:
|
||||||
|
{
|
||||||
|
imports =
|
||||||
|
[
|
||||||
|
/etc/nixos/hardware-configuration.nix
|
||||||
|
./imports/github/rycee/home-manager/nixos
|
||||||
|
./modules
|
||||||
|
];
|
||||||
|
|
||||||
|
inherit device;
|
||||||
|
|
||||||
|
system.stateVersion = "19.03";
|
||||||
|
}
|
1
imports/github/rycee/home-manager
Submodule
1
imports/github/rycee/home-manager
Submodule
@ -0,0 +1 @@
|
|||||||
|
Subproject commit 13fa61744c0c8242446a349cc1e9d6279446db35
|
103
modules/applications.nix
Normal file
103
modules/applications.nix
Normal file
@ -0,0 +1,103 @@
|
|||||||
|
{ pkgs, config, lib, ... }:
|
||||||
|
with import ../support.nix { inherit lib config; }; {
|
||||||
|
options.defaultApplications = lib.mkOption {
|
||||||
|
type = lib.types.attrs;
|
||||||
|
description = "Preferred applications";
|
||||||
|
};
|
||||||
|
config = rec {
|
||||||
|
defaultApplications = {
|
||||||
|
term = {
|
||||||
|
cmd = "${pkgs.xst}/bin/st";
|
||||||
|
desktop = "xst";
|
||||||
|
};
|
||||||
|
editor = {
|
||||||
|
cmd = "${pkgs.codium}/bin/codium";
|
||||||
|
desktop = "codium";
|
||||||
|
};
|
||||||
|
browser = {
|
||||||
|
cmd = "${pkgs.vivaldi}/bin/vivaldi";
|
||||||
|
desktop = "vivaldi";
|
||||||
|
};
|
||||||
|
# fm = {
|
||||||
|
# cmd = "${pkgs.dolphin}/bin/dolphin";
|
||||||
|
# desktop = "dolphin";
|
||||||
|
# };
|
||||||
|
monitor = {
|
||||||
|
cmd = "${pkgs.xfce4-14.xfce4-taskmanager}/bin/xfce4-taskmanager";
|
||||||
|
desktop = "taskmanager";
|
||||||
|
};
|
||||||
|
# monitor = {
|
||||||
|
# cmd = "${pkgs.ksysguard}/bin/ksysguard";
|
||||||
|
# desktop = "ksysguard";
|
||||||
|
# };
|
||||||
|
torrent = {
|
||||||
|
cmd = "${pkgs.qbittorrent}/bin/qbittorrent";
|
||||||
|
desktop = "qbittorrent";
|
||||||
|
};
|
||||||
|
archive = {
|
||||||
|
cmd = "${pkgs.xarchiver}/bin/xarchiver";
|
||||||
|
desktop = "xarchiver";
|
||||||
|
};
|
||||||
|
# archive = {
|
||||||
|
# cmd = "${pkgs.ark}/bin/ark";
|
||||||
|
# desktop = "org.kde.ark";
|
||||||
|
# };
|
||||||
|
# mail = {
|
||||||
|
# cmd = "${pkgs.trojita}/bin/trojita";
|
||||||
|
# desktop = "trojita";
|
||||||
|
# };
|
||||||
|
# text_processor = {
|
||||||
|
# cmd = "${pkgs.abiword}/bin/abiword";
|
||||||
|
# desktop = "abiword";
|
||||||
|
# };
|
||||||
|
# spreadsheet = {
|
||||||
|
# cmd = "${pkgs.gnumeric}/bin/gnumeric";
|
||||||
|
# desktop = "gnumeric";
|
||||||
|
# };
|
||||||
|
};
|
||||||
|
home-manager.users.balsoft.xdg.configFile."mimeapps.list.home".text =
|
||||||
|
with config.defaultApplications;
|
||||||
|
let
|
||||||
|
apps = builtins.mapAttrs (name: value: "${value.desktop}.desktop;") {
|
||||||
|
"text/html" = browser;
|
||||||
|
"image/*" = { desktop = "org.kde.gwenview"; };
|
||||||
|
"application/x-bittorrent" = torrent;
|
||||||
|
"application/zip" = archive;
|
||||||
|
"application/rar" = archive;
|
||||||
|
"application/7z" = archive;
|
||||||
|
"application/*tar" = archive;
|
||||||
|
"application/x-kdenlive" = archive;
|
||||||
|
"x-scheme-handler/http" = browser;
|
||||||
|
"x-scheme-handler/https" = browser;
|
||||||
|
"x-scheme-handler/about" = browser;
|
||||||
|
"x-scheme-handler/unknown" = browser;
|
||||||
|
# "x-scheme-handler/mailto" = mail;
|
||||||
|
# "application/pdf" = { desktop = "org.kde.okular"; };
|
||||||
|
# "application/vnd.openxmlformats-officedocument.wordprocessingml.document" =
|
||||||
|
# text_processor;
|
||||||
|
# "application/msword" = text_processor;
|
||||||
|
# "application/vnd.oasis.opendocument.text" = text_processor;
|
||||||
|
# "text/csv" = spreadsheet;
|
||||||
|
# "application/vnd.oasis.opendocument.spreadsheet" = spreadsheet;
|
||||||
|
# This actually makes Emacs an editor for everything... XDG is wierd
|
||||||
|
"text/plain" = editor;
|
||||||
|
};
|
||||||
|
in genIni {
|
||||||
|
"Default Applications" = apps;
|
||||||
|
"Added Associations" = apps;
|
||||||
|
};
|
||||||
|
home-manager.users.alukard.xdg.configFile."filetypesrc".text = genIni {
|
||||||
|
EmbedSettings = {
|
||||||
|
"embed-application/*" = false;
|
||||||
|
"embed-text/*" = false;
|
||||||
|
"embed-text/plain" = false;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
home-manager.users.alukard.home.activation.mimeapps = {
|
||||||
|
before = [];
|
||||||
|
after = ["linkGeneration"];
|
||||||
|
data =
|
||||||
|
"$DRY_RUN_CMD cp ~/.config/mimeapps.list.home ~/.config/mimeapps.list";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
44
modules/default.nix
Normal file
44
modules/default.nix
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
{ ... }: {
|
||||||
|
imports = [
|
||||||
|
# ./applications/packages.nix
|
||||||
|
# ./applications/kate.nix
|
||||||
|
# ./applications/emacs
|
||||||
|
# ./applications/xst.nix
|
||||||
|
# ./applications/trojita.nix
|
||||||
|
# ./applications/firefox.nix
|
||||||
|
# ./applications/okular.nix
|
||||||
|
# ./applications/weechat.nix
|
||||||
|
# ./applications/spectral.nix
|
||||||
|
# ./workspace/i3blocks
|
||||||
|
# ./workspace/i3
|
||||||
|
# ./workspace/zsh.nix
|
||||||
|
# ./workspace/gtk.nix
|
||||||
|
# ./workspace/compton.nix
|
||||||
|
# ./workspace/misc.nix
|
||||||
|
# ./workspace/dunst.nix
|
||||||
|
# ./workspace/kde
|
||||||
|
# ./workspace/synergy.nix
|
||||||
|
# ./workspace/ssh.nix
|
||||||
|
# ./workspace/locale.nix
|
||||||
|
# ./workspace/fonts.nix
|
||||||
|
# ./workspace/light.nix
|
||||||
|
# ./workspace/autorandr.nix
|
||||||
|
# ./workspace/gcalcli.nix
|
||||||
|
# ./workspace/rclone.nix
|
||||||
|
# ./workspace/xresources.nix
|
||||||
|
./themes.nix
|
||||||
|
./applications.nix
|
||||||
|
./secrets.nix
|
||||||
|
./devices.nix
|
||||||
|
# ./packages.nix
|
||||||
|
./nix.nix
|
||||||
|
./users.nix
|
||||||
|
./hardware.nix
|
||||||
|
./services.nix
|
||||||
|
./power.nix
|
||||||
|
./xserver.nix
|
||||||
|
./network.nix
|
||||||
|
./wireguard.nix
|
||||||
|
./filesystems.nix
|
||||||
|
];
|
||||||
|
}
|
74
modules/devices.nix
Normal file
74
modules/devices.nix
Normal file
@ -0,0 +1,74 @@
|
|||||||
|
{ pkgs, lib, config, ... }:
|
||||||
|
with lib;
|
||||||
|
with types; {
|
||||||
|
options = {
|
||||||
|
device = mkOption { type = strMatching "[A-z]*-[A-z]*"; };
|
||||||
|
devices = mkOption { type = attrs; };
|
||||||
|
deviceSpecific = mkOption { type = attrs; };
|
||||||
|
};
|
||||||
|
config = {
|
||||||
|
deviceSpecific = let
|
||||||
|
device = config.device;
|
||||||
|
devInfo = config.devices.${config.device};
|
||||||
|
in rec {
|
||||||
|
isLaptop = (!isNull (builtins.match ".*Laptop" device));
|
||||||
|
# smallScreen = (device == "Prestigio-Laptop");
|
||||||
|
isShared = devInfo.isShared;
|
||||||
|
cpu = devInfo.cpu.vendor;
|
||||||
|
isSSD = devInfo.drive.type == "ssd";
|
||||||
|
hostName = if !isNull devInfo.hostName then
|
||||||
|
devInfo.hostName
|
||||||
|
else
|
||||||
|
device;
|
||||||
|
# goodMachine = devInfo.cpu.clock * devInfo.cpu.cores >= 4000
|
||||||
|
# && devInfo.drive.size >= 100 && devInfo.ram
|
||||||
|
# >= 8; # Whether machine is powerful enough for heavy stuff
|
||||||
|
isHost = (device == "AMD-Workstation");
|
||||||
|
};
|
||||||
|
|
||||||
|
devices = {
|
||||||
|
AMD-Workstation = {
|
||||||
|
cpu = {
|
||||||
|
vendor = "amd";
|
||||||
|
clock = 3800;
|
||||||
|
cores = 6;
|
||||||
|
};
|
||||||
|
drive = {
|
||||||
|
type = "ssd";
|
||||||
|
size = 250;
|
||||||
|
};
|
||||||
|
ram = 16;
|
||||||
|
isShared = false;
|
||||||
|
hostName = "ataraxia-pc";
|
||||||
|
};
|
||||||
|
PackardBell-Laptop = {
|
||||||
|
cpu = {
|
||||||
|
vendor = "intel";
|
||||||
|
clock = 2500;
|
||||||
|
cores = 2;
|
||||||
|
};
|
||||||
|
drive = {
|
||||||
|
type = "hdd";
|
||||||
|
size = 500;
|
||||||
|
};
|
||||||
|
ram = 6;
|
||||||
|
isShared = true;
|
||||||
|
hostName = null;
|
||||||
|
};
|
||||||
|
NixOS-VM = {
|
||||||
|
cpu = {
|
||||||
|
vendor = "amd";
|
||||||
|
clock = 3600;
|
||||||
|
cores = 2;
|
||||||
|
};
|
||||||
|
drive = {
|
||||||
|
type = "ssd";
|
||||||
|
size = 12;
|
||||||
|
};
|
||||||
|
ram = 4;
|
||||||
|
isShared = false;
|
||||||
|
hostName = null;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
17
modules/filesystems.nix
Normal file
17
modules/filesystems.nix
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
{ pkgs, lib, config, ... }: {
|
||||||
|
fileSystems = {
|
||||||
|
"/" = {
|
||||||
|
options = [ "subvol=nixos" "discard" "ssd" "noatime" "compress=zstd" ];
|
||||||
|
};
|
||||||
|
"/shared" = {
|
||||||
|
fsType = "vboxsf";
|
||||||
|
device = "shared";
|
||||||
|
options = [ "rw" "nodev" "relatime" "iocharset=utf8" "uid=1000" "gid=100" "dmode=0770" "fmode=0770" "nofail" ];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
# mount swap
|
||||||
|
swapDevices = [
|
||||||
|
{ label = "swap"; }
|
||||||
|
];
|
||||||
|
}
|
36
modules/hardware.nix
Normal file
36
modules/hardware.nix
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
{ pkgs, config, lib, ... }:
|
||||||
|
with rec {
|
||||||
|
inherit (config) device devices deviceSpecific;
|
||||||
|
};
|
||||||
|
with deviceSpecific; {
|
||||||
|
|
||||||
|
hardware.cpu.${devices.${device}.cpu.vendor}.updateMicrocode = true; # Update microcode
|
||||||
|
# hardware.enableRedistributableFirmware = true; # For some unfree drivers
|
||||||
|
|
||||||
|
hardware.opengl.enable = true;
|
||||||
|
hardware.opengl.driSupport = true;
|
||||||
|
hardware.opengl.driSupport32Bit = true; # For steam
|
||||||
|
|
||||||
|
hardware.bluetooth.enable = isLaptop;
|
||||||
|
|
||||||
|
boot = {
|
||||||
|
loader = {
|
||||||
|
systemd-boot.enable = true;
|
||||||
|
efi.canTouchEfiVariables = true;
|
||||||
|
};
|
||||||
|
kernelPackages = if config.virtualisation.virtualbox.guest.enable == false then
|
||||||
|
pkgs.linuxPackages_latest
|
||||||
|
else
|
||||||
|
pkgs.linuxPackages;
|
||||||
|
supportedFilesystems = [ "ntfs" ];
|
||||||
|
extraModulePackages = [ config.boot.kernelPackages.exfat-nofuse ];
|
||||||
|
};
|
||||||
|
|
||||||
|
sound.enable = true;
|
||||||
|
hardware.pulseaudio = {
|
||||||
|
enable = true;
|
||||||
|
# package = pkgs.pulseaudioFull;
|
||||||
|
support32Bit = true;
|
||||||
|
# systemWide = true;
|
||||||
|
};
|
||||||
|
}
|
24
modules/network.nix
Normal file
24
modules/network.nix
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
{ pkgs, lib, config, ... }: {
|
||||||
|
networking = {
|
||||||
|
networkmanager.enable = false;
|
||||||
|
wireless = {
|
||||||
|
enable = config.device != "AMD-Workstation";
|
||||||
|
# driver = "wext";
|
||||||
|
networks.Alukard_5GHz = {
|
||||||
|
pskRaw = "feee27000fb0d7118d498d4d867416d04d1d9a1a7b5dbdbd888060bbde816fe4";
|
||||||
|
priority = 1;
|
||||||
|
};
|
||||||
|
networks.Alukard.pskRaw =
|
||||||
|
"5ef5fe07c1f062e4653fce9fe138cc952c20e284ae1ca50babf9089b5cba3a5a";
|
||||||
|
networks.SladkiySon.pskRaw =
|
||||||
|
"86b1c8c60d3e99145bfe90e0af9bf552540d34606bb0d00b314f5b5960e46496";
|
||||||
|
# interfaces = ["wlan0"];
|
||||||
|
userControlled.enable = true;
|
||||||
|
};
|
||||||
|
firewall.enable = false;
|
||||||
|
# usePredictableInterfaceNames = false;
|
||||||
|
hostName = config.deviceSpecific.hostName;
|
||||||
|
};
|
||||||
|
# systemd.services.dhcpcd.serviceConfig.Type = lib.mkForce
|
||||||
|
# "simple"; # TODO Make a PR with this change; forking is not acceptable for dhcpcd.
|
||||||
|
}
|
14
modules/nix.nix
Normal file
14
modules/nix.nix
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
{ config, lib, pkgs, ... }: {
|
||||||
|
|
||||||
|
nixpkgs.config = {
|
||||||
|
allowUnfree = true;
|
||||||
|
};
|
||||||
|
nix = {
|
||||||
|
useSandbox = true;
|
||||||
|
autoOptimiseStore = config.deviceSpecific.isSSD;
|
||||||
|
optimise.automatic = true;
|
||||||
|
};
|
||||||
|
environment.systemPackages = with pkgs; [
|
||||||
|
xfce4-14.xfce4-taskmanager
|
||||||
|
];
|
||||||
|
}
|
103
modules/packages.nix
Normal file
103
modules/packages.nix
Normal file
@ -0,0 +1,103 @@
|
|||||||
|
{ pkgs, config, lib, ... }: {
|
||||||
|
nixpkgs.overlays = [
|
||||||
|
(self: old:
|
||||||
|
{
|
||||||
|
termNote =
|
||||||
|
self.callPackage ../imports/github/terodom/termNote/termNote.nix { };
|
||||||
|
|
||||||
|
nixfmt = self.callPackage ../imports/github/serokell/nixfmt { };
|
||||||
|
|
||||||
|
lambda-launcher = (import ../imports/github/balsoft/lambda-launcher {
|
||||||
|
pkgs = old;
|
||||||
|
}).lambda-launcher;
|
||||||
|
|
||||||
|
tdesktop = old.tdesktop.overrideAttrs (oldAttrs: {
|
||||||
|
patches = [
|
||||||
|
../imports/github/msva/mva-overlay/net-im/telegram-desktop/files/patches/0/conditional/wide-baloons/0001_baloons-follows-text-width-on-adaptive-layout.patch
|
||||||
|
] ++ oldAttrs.patches;
|
||||||
|
});
|
||||||
|
|
||||||
|
all-hies = import ../imports/github/Infinisil/all-hies { };
|
||||||
|
|
||||||
|
mtxclient = old.mtxclient.overrideAttrs (_: rec {
|
||||||
|
name = "${pname}-${version}";
|
||||||
|
pname = "mtxclient";
|
||||||
|
version = "0.3.0";
|
||||||
|
src = ../imports/github/nheko-reborn/mtxclient;
|
||||||
|
});
|
||||||
|
nheko = old.nheko.overrideAttrs (_: rec {
|
||||||
|
name = "${pname}-${version}";
|
||||||
|
pname = "nheko";
|
||||||
|
version = "0.7.0";
|
||||||
|
src = ../imports/github/nheko-reborn/nheko;
|
||||||
|
});
|
||||||
|
|
||||||
|
nerdfonts = old.stdenv.mkDerivation rec {
|
||||||
|
name = "RobotoMonoNerd";
|
||||||
|
src = old.fetchzip {
|
||||||
|
url =
|
||||||
|
"https://github.com/ryanoasis/nerd-fonts/releases/download/v2.0.0/RobotoMono.zip";
|
||||||
|
sha256 =
|
||||||
|
"sha256:1i78fn62x0337p2974dn1nga1pbdi7mqg203h81yi9b79pyxv9bh";
|
||||||
|
stripRoot = false;
|
||||||
|
};
|
||||||
|
installPhase = "mkdir -p $out/share/fonts; cp $src/* $out/share/fonts";
|
||||||
|
};
|
||||||
|
|
||||||
|
pythonPackages = old.pythonPackages.override {
|
||||||
|
overrides = (self: super: {
|
||||||
|
backports_functools_lru_cache =
|
||||||
|
super.backports_functools_lru_cache.overrideAttrs
|
||||||
|
(oldAttrs: oldAttrs // { meta.priority = 1000; });
|
||||||
|
});
|
||||||
|
};
|
||||||
|
} // (if config.device == "Prestigio-Laptop" then {
|
||||||
|
grub2 = old.pkgsi686Linux.grub2;
|
||||||
|
} else
|
||||||
|
{ }))
|
||||||
|
];
|
||||||
|
nixpkgs.pkgs = import ../imports/github/nixos/nixpkgs {
|
||||||
|
config.allowUnfree = true;
|
||||||
|
config.android_sdk.accept_license = true;
|
||||||
|
config.firefox.enablePlasmaBrowserIntegration = true;
|
||||||
|
} // config.nixpkgs.config;
|
||||||
|
|
||||||
|
systemd.services.setup_root = {
|
||||||
|
serviceConfig.User = "root";
|
||||||
|
script = ''
|
||||||
|
cat << EOF > /root/id_rsa
|
||||||
|
${config.secrets.id_rsa}
|
||||||
|
EOF
|
||||||
|
chmod 100 /root/id_rsa
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
environment.etc.nixpkgs.source = ../imports/github/nixos/nixpkgs;
|
||||||
|
nix = rec {
|
||||||
|
nixPath = lib.mkForce [
|
||||||
|
"nixpkgs=/etc/nixpkgs"
|
||||||
|
"nixos-config=/etc/nixos/configuration.nix"
|
||||||
|
];
|
||||||
|
binaryCaches = [
|
||||||
|
"https://cache.nixos.org"
|
||||||
|
"http://hydra.typeable.io:5000"
|
||||||
|
"https://nixcache.reflex-frp.org"
|
||||||
|
"https://all-hies.cachix.org"
|
||||||
|
"https://balsoft.ru:5000"
|
||||||
|
];
|
||||||
|
|
||||||
|
trustedBinaryCaches =
|
||||||
|
(builtins.map (x: "http://${x}:5000") (builtins.attrNames config.devices))
|
||||||
|
++ binaryCaches;
|
||||||
|
|
||||||
|
trustedUsers = [ "root" "balsoft" "@wheel" ];
|
||||||
|
|
||||||
|
optimise.automatic = true;
|
||||||
|
|
||||||
|
binaryCachePublicKeys = [
|
||||||
|
"cache.nixos.org-1:6NCHdD59X431o0gWypbMrAURkbJ16ZPMQFGspcDShjY="
|
||||||
|
"hydra.example.org-1:3cfw8jj8xtoKkQ2mAQxMFcEv2/fQATA/mjoUUIFxSgo="
|
||||||
|
"ryantrinkle.com-1:JJiAKaRv9mWgpVAz8dwewnZe0AzzEAzPkagE9SP5NWI="
|
||||||
|
"all-hies.cachix.org-1:JjrzAOEUsD9ZMt8fdFbzo3jNAyEWlPAwdVuHw4RD43k="
|
||||||
|
];
|
||||||
|
};
|
||||||
|
}
|
55
modules/power.nix
Normal file
55
modules/power.nix
Normal file
@ -0,0 +1,55 @@
|
|||||||
|
{ config, pkgs, lib, ... }:
|
||||||
|
|
||||||
|
with rec {
|
||||||
|
inherit (config) device devices deviceSpecific;
|
||||||
|
};
|
||||||
|
with deviceSpecific; {
|
||||||
|
services.udev.extraRules = if isLaptop then
|
||||||
|
''
|
||||||
|
ACTION=="add|change", KERNEL=="sd*[!0-9]|sr*", ATTR{queue/scheduler}="bfq"
|
||||||
|
ACTION=="change", SUBSYSTEM=="power_supply", ATTR{online}=="0", RUN+="${
|
||||||
|
pkgs.systemd
|
||||||
|
}/bin/systemctl start battery"
|
||||||
|
ACTION=="change", SUBSYSTEM=="power_supply", ATTR{online}=="1", RUN+="${
|
||||||
|
pkgs.systemd
|
||||||
|
}/bin/systemctl start ac"
|
||||||
|
ACTION=="add|change", SUBSYSTEM=="backlight", MODE:="0777"
|
||||||
|
'' + (if device == "ASUS-Laptop" then ''
|
||||||
|
ACTION=="add|change", SUBSYSTEM=="net", KERNEL=="wlan*" RUN+="${
|
||||||
|
pkgs.iw
|
||||||
|
}/bin/iw dev %k set power_save off"
|
||||||
|
'' else
|
||||||
|
"")
|
||||||
|
else
|
||||||
|
"";
|
||||||
|
systemd.services.battery = {
|
||||||
|
enable = isLaptop;
|
||||||
|
description = "Executes commands needed on battery power";
|
||||||
|
script = ''
|
||||||
|
${
|
||||||
|
pkgs.linuxPackages_latest.cpupower
|
||||||
|
}/bin/cpupower frequency-set -g powersave
|
||||||
|
${pkgs.hdparm}/bin/hdparm -B 1 /dev/sda
|
||||||
|
echo "500" > /sys/class/backlight/*/brightness
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
systemd.services.ac = {
|
||||||
|
enable = isLaptop;
|
||||||
|
description = "Executes commands needed on ac power";
|
||||||
|
script = ''
|
||||||
|
${
|
||||||
|
pkgs.linuxPackages_latest.cpupower
|
||||||
|
}/bin/cpupower frequency-set -g performance
|
||||||
|
${pkgs.hdparm}/bin/hdparm -B 255 /dev/sda
|
||||||
|
echo "900" > /sys/class/backlight/*/brightness
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
systemd.services.leds_setup = {
|
||||||
|
enable = (device == "ASUS-Laptop");
|
||||||
|
description = "Set up leds triggers";
|
||||||
|
wantedBy = ["multi-user.target"];
|
||||||
|
script = ''
|
||||||
|
echo "phy0rx" > /sys/class/leds/asus-wireless\:\:airplane/trigger
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
}
|
86
modules/secrets.nix
Normal file
86
modules/secrets.nix
Normal file
@ -0,0 +1,86 @@
|
|||||||
|
{ pkgs, config, lib, ... }:
|
||||||
|
with lib;
|
||||||
|
with types;
|
||||||
|
let
|
||||||
|
mkCredOption = service: extra:
|
||||||
|
mkOption {
|
||||||
|
description = "Credentials for ${service}";
|
||||||
|
type = nullOr (submodule {
|
||||||
|
options = {
|
||||||
|
user = mkOption {
|
||||||
|
type = string;
|
||||||
|
description = "Username for ${service}";
|
||||||
|
};
|
||||||
|
password = mkOption {
|
||||||
|
type = string;
|
||||||
|
description = "Password for ${service}";
|
||||||
|
};
|
||||||
|
} // extra;
|
||||||
|
});
|
||||||
|
};
|
||||||
|
in rec {
|
||||||
|
options.secrets = {
|
||||||
|
wireguard = mkOption {
|
||||||
|
type = attrs;
|
||||||
|
description = "Wireguard conf";
|
||||||
|
};
|
||||||
|
# owm-key = mkOption {
|
||||||
|
# type = nullOr string;
|
||||||
|
# description = "OpenWeatherMap key";
|
||||||
|
# };
|
||||||
|
# irc = mkCredOption "IRC (konversation)" { };
|
||||||
|
# slack-term = mkOption { type = string; };
|
||||||
|
# gcal = {
|
||||||
|
# email = mkOption { type = lib.types.string; };
|
||||||
|
# client-id = mkOption { type = lib.types.string; };
|
||||||
|
# client-secret = mkOption { type = lib.types.string; };
|
||||||
|
# refresh-token = mkOption { type = lib.types.string; };
|
||||||
|
# };
|
||||||
|
# gmail = mkCredOption "gmail (trojita)" { };
|
||||||
|
# gpmusic = mkCredOption "Google Play Music (mopidy)" {
|
||||||
|
# deviceid = mkOption {
|
||||||
|
# type = string;
|
||||||
|
# description = "Android device ID";
|
||||||
|
# };
|
||||||
|
# };
|
||||||
|
# openvpn = mkCredOption "openvpn" {};
|
||||||
|
# rclone = mkOption {
|
||||||
|
# type = nullOr string;
|
||||||
|
# description = "Rclone config";
|
||||||
|
# };
|
||||||
|
# id_rsa = mkOption {
|
||||||
|
# type = nullOr string;
|
||||||
|
# description = "SSH RSA private key";
|
||||||
|
# };
|
||||||
|
# matrix = rec {
|
||||||
|
# shared_secret = mkOption {
|
||||||
|
# type = nullOr string;
|
||||||
|
# description = "A shared secret for matrix instance";
|
||||||
|
# };
|
||||||
|
# cert = mkOption {
|
||||||
|
# type = nullOr string;
|
||||||
|
# description = "SSL certificate";
|
||||||
|
# };
|
||||||
|
# priv = mkOption {
|
||||||
|
# type = nullOr string;
|
||||||
|
# description = "SSL RSA private key";
|
||||||
|
# };
|
||||||
|
# mautrix-whatsapp = {
|
||||||
|
# config = mkOption {
|
||||||
|
# type = attrs;
|
||||||
|
# };
|
||||||
|
# registration = mkOption {
|
||||||
|
# type = attrs;
|
||||||
|
# };
|
||||||
|
# };
|
||||||
|
# mautrix-telegram = mautrix-whatsapp;
|
||||||
|
# };
|
||||||
|
};
|
||||||
|
config = let
|
||||||
|
secretnix = import ../secret.nix;
|
||||||
|
secrets = if isNull secretnix then
|
||||||
|
mapAttrs (n: v: null) options.secrets
|
||||||
|
else
|
||||||
|
secretnix;
|
||||||
|
in { inherit secrets; };
|
||||||
|
}
|
47
modules/services.nix
Normal file
47
modules/services.nix
Normal file
@ -0,0 +1,47 @@
|
|||||||
|
{ config, lib, pkgs, ... }: {
|
||||||
|
|
||||||
|
# services.acpid.enable = true;
|
||||||
|
|
||||||
|
# services.mopidy = {
|
||||||
|
# enable = true;
|
||||||
|
|
||||||
|
# extensionPackages = with pkgs; [ mopidy-gmusic ];
|
||||||
|
# configuration = (if (!isNull config.secrets.gpmusic) then ''
|
||||||
|
# [gmusic]
|
||||||
|
# username = ${config.secrets.gpmusic.user}
|
||||||
|
# password = ${config.secrets.gpmusic.password}
|
||||||
|
# deviceid = ${config.secrets.gpmusic.deviceid}
|
||||||
|
# bitrate = 128
|
||||||
|
# '' else
|
||||||
|
# "") + ''
|
||||||
|
# [mpd]
|
||||||
|
# hostname = 0.0.0.0
|
||||||
|
# '';
|
||||||
|
# };
|
||||||
|
services.earlyoom = {
|
||||||
|
enable = config.devices.${config.device}.ram < 12;
|
||||||
|
freeMemThreshold = 5;
|
||||||
|
freeSwapThreshold = 100;
|
||||||
|
};
|
||||||
|
|
||||||
|
services.printing = {
|
||||||
|
enable = true;
|
||||||
|
drivers = [ pkgs.gutenprint ];
|
||||||
|
};
|
||||||
|
programs.dconf.enable = true;
|
||||||
|
|
||||||
|
services.accounts-daemon.enable = true;
|
||||||
|
services.avahi.enable = true;
|
||||||
|
|
||||||
|
systemd.services.systemd-udev-settle.enable = false;
|
||||||
|
|
||||||
|
services.upower.enable = true;
|
||||||
|
|
||||||
|
virtualisation.docker.enable = config.deviceSpecific.isHost;
|
||||||
|
virtualisation.virtualbox.host = lib.mkIf config.deviceSpecific.isHost {
|
||||||
|
enable = true;
|
||||||
|
# enableHardening = false;
|
||||||
|
enableExtensionPack = true;
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
69
modules/themes.nix
Normal file
69
modules/themes.nix
Normal file
@ -0,0 +1,69 @@
|
|||||||
|
{ config, lib, pkgs, ... }:
|
||||||
|
with lib;
|
||||||
|
let
|
||||||
|
colorType = types.str;
|
||||||
|
color = (name:
|
||||||
|
(mkOption {
|
||||||
|
description = "${name} color of palette";
|
||||||
|
type = colorType;
|
||||||
|
}));
|
||||||
|
fromBase16 = { base00, base01, base02, base03, base04, base05, base06, base07
|
||||||
|
, base08, base09, base0A, base0B, base0C, base0D, base0E, base0F, ... }:
|
||||||
|
builtins.mapAttrs (_: v: "#" + v) {
|
||||||
|
bg = base00;
|
||||||
|
fg = base07;
|
||||||
|
|
||||||
|
gray = base03;
|
||||||
|
alt = base02;
|
||||||
|
dark = base01;
|
||||||
|
|
||||||
|
red = base08;
|
||||||
|
orange = base09;
|
||||||
|
yellow = base0A;
|
||||||
|
green = base0B;
|
||||||
|
cyan = base0C;
|
||||||
|
blue = base0D;
|
||||||
|
purple = base0E;
|
||||||
|
};
|
||||||
|
|
||||||
|
fromYAML = yaml:
|
||||||
|
builtins.fromJSON (
|
||||||
|
builtins.readFile (
|
||||||
|
pkgs.stdenv.mkDerivation {
|
||||||
|
name = "fromYAML";
|
||||||
|
phases = ["buildPhase"];
|
||||||
|
buildPhase = ''echo '${yaml}' | ${pkgs.yaml2json}/bin/yaml2json > $out'';
|
||||||
|
}
|
||||||
|
)
|
||||||
|
);
|
||||||
|
in {
|
||||||
|
options = {
|
||||||
|
themes = {
|
||||||
|
colors = mkOption {
|
||||||
|
description =
|
||||||
|
"Set of colors from which the themes for various applications will be generated";
|
||||||
|
type = with types;
|
||||||
|
submodule {
|
||||||
|
options = {
|
||||||
|
bg = color "background";
|
||||||
|
fg = color "foreground";
|
||||||
|
gray = color "gray";
|
||||||
|
alt = color "alternative";
|
||||||
|
dark = color "darker";
|
||||||
|
blue = color "blue";
|
||||||
|
green = color "green";
|
||||||
|
red = color "red";
|
||||||
|
orange = color "orange";
|
||||||
|
yellow = color "yellow";
|
||||||
|
cyan = color "cyan";
|
||||||
|
purple = color "purple";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
config = {
|
||||||
|
themes.colors = fromBase16 (fromYAML (builtins.readFile
|
||||||
|
../imports/github/dawikur/base16-gruvbox-scheme/gruvbox-dark-hard.yaml));
|
||||||
|
};
|
||||||
|
}
|
39
modules/users.nix
Normal file
39
modules/users.nix
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
{ config, pkgs, lib, ... }: {
|
||||||
|
# users.defaultUser = "alukard";
|
||||||
|
|
||||||
|
security.apparmor.enable = true;
|
||||||
|
programs.firejail.enable = true;
|
||||||
|
users.mutableUsers = false;
|
||||||
|
users.users.alukard = {
|
||||||
|
isNormalUser = true;
|
||||||
|
extraGroups = [
|
||||||
|
"sudo"
|
||||||
|
"wheel"
|
||||||
|
"networkmanager"
|
||||||
|
"disk"
|
||||||
|
"dbus"
|
||||||
|
"audio"
|
||||||
|
"docker"
|
||||||
|
"sound"
|
||||||
|
"pulse"
|
||||||
|
# "adbusers"
|
||||||
|
"input"
|
||||||
|
# "libvirtd"
|
||||||
|
"vboxusers"
|
||||||
|
# "wireshark"
|
||||||
|
];
|
||||||
|
description = "Дмитрий Холкин";
|
||||||
|
uid = 1000;
|
||||||
|
hashedPassword = "$6$kDBGyd99tto$9LjQwixa7NYB9Kaey002MD94zHob1MmNbVz9kx3yX6Q4AmVgsFMGUyNuHozXprxyuXHIbOlTcf8nd4rK8MWfI/";
|
||||||
|
shell = pkgs.zsh;
|
||||||
|
};
|
||||||
|
# security.sudo = {
|
||||||
|
# enable = true;
|
||||||
|
# extraConfig = ''
|
||||||
|
# balsoft ALL = (root) NOPASSWD: /run/current-system/sw/bin/nixos-rebuild switch
|
||||||
|
# '';
|
||||||
|
# };
|
||||||
|
# nix.requireSignedBinaryCaches = false;
|
||||||
|
|
||||||
|
home-manager.useUserPackages = true;
|
||||||
|
}
|
53
modules/wireguard.nix
Normal file
53
modules/wireguard.nix
Normal file
@ -0,0 +1,53 @@
|
|||||||
|
{ config, pkgs, lib, ... }:
|
||||||
|
let
|
||||||
|
cfg = config.secrets.wireguard.${config.device};
|
||||||
|
in {
|
||||||
|
# Enable wireguard
|
||||||
|
networking.wg-quick.interfaces = lib.mkIf cfg.enable {
|
||||||
|
wg0 = {
|
||||||
|
address = [ cfg.address ];
|
||||||
|
dns = [ "10.192.122.1" ];
|
||||||
|
# TODO change to privateKeyFile
|
||||||
|
privateKey = cfg.privateKey;
|
||||||
|
peers = [
|
||||||
|
{
|
||||||
|
allowedIPs = [ "0.0.0.0/0" ];
|
||||||
|
publicKey = "AgtgtS3InfOv4UQ+2MNAEMKFqZGhYXNOFmfMdKXIpng=";
|
||||||
|
endpoint = "51.38.98.116:51820";
|
||||||
|
}
|
||||||
|
];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
# Enable killswitch
|
||||||
|
networking.nftables = lib.mkIf cfg.enable {
|
||||||
|
enable = true;
|
||||||
|
ruleset = ''
|
||||||
|
flush ruleset
|
||||||
|
table inet firewall {
|
||||||
|
chain input {
|
||||||
|
type filter hook input priority 0; policy drop;
|
||||||
|
iif "lo" accept
|
||||||
|
ct state { established, related } accept
|
||||||
|
ct state invalid drop
|
||||||
|
ip protocol icmp icmp type echo-request accept
|
||||||
|
ip daddr 192.168.0.1/24 accept
|
||||||
|
reject
|
||||||
|
}
|
||||||
|
chain forward {
|
||||||
|
type filter hook forward priority 0; policy drop;
|
||||||
|
}
|
||||||
|
chain output {
|
||||||
|
type filter hook output priority 0; policy drop;
|
||||||
|
oifname "lo" accept
|
||||||
|
oifname "wg0" accept
|
||||||
|
oifname "docker0" accept
|
||||||
|
oifname "vboxnet0" accept
|
||||||
|
oifname "vboxnet1" accept
|
||||||
|
udp dport domain drop
|
||||||
|
ip daddr 192.168.0.1/24 accept
|
||||||
|
udp dport 51820 accept
|
||||||
|
}
|
||||||
|
}
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
}
|
51
modules/xserver.nix
Normal file
51
modules/xserver.nix
Normal file
@ -0,0 +1,51 @@
|
|||||||
|
{ pkgs, lib, config, ... }:
|
||||||
|
let
|
||||||
|
cpu = config.deviceSpecific.cpu;
|
||||||
|
isShared = config.deviceSpecific.isShared;
|
||||||
|
defaultUser = config.user.defaultUser;
|
||||||
|
in {
|
||||||
|
services.xserver = {
|
||||||
|
enable = true;
|
||||||
|
# enableTCP = true;
|
||||||
|
|
||||||
|
libinput = {
|
||||||
|
enable = true;
|
||||||
|
sendEventsMode = "disabled-on-external-mouse";
|
||||||
|
middleEmulation = false;
|
||||||
|
# naturalScrolling = true;
|
||||||
|
};
|
||||||
|
|
||||||
|
videoDrivers = if cpu == "amd" then
|
||||||
|
["amdgpu"]
|
||||||
|
else if cpu == "intel" then
|
||||||
|
["intel"]
|
||||||
|
else
|
||||||
|
[ ];
|
||||||
|
|
||||||
|
displayManager.lightdm = {
|
||||||
|
enable = true;
|
||||||
|
greeter.enable = isShared;
|
||||||
|
autoLogin.enable = !isShared;
|
||||||
|
autoLogin.user = "alukard";
|
||||||
|
# autoLogin.user = defaultUser;
|
||||||
|
};
|
||||||
|
|
||||||
|
# desktopManager.plasma5.enable = true;
|
||||||
|
desktopManager.default = "none";
|
||||||
|
desktopManager.xterm.enable = false;
|
||||||
|
|
||||||
|
windowManager.i3 = {
|
||||||
|
enable = true;
|
||||||
|
package = pkgs.i3-gaps;
|
||||||
|
};
|
||||||
|
windowManager.default = "i3";
|
||||||
|
|
||||||
|
layout = "us,ru";
|
||||||
|
xkbOptions = "grp:win_space_toggle";
|
||||||
|
};
|
||||||
|
|
||||||
|
environment.systemPackages = if cpu == "amd" then
|
||||||
|
[ (pkgs.mesa.override { enableRadv = true; }) ]
|
||||||
|
else
|
||||||
|
[ ];
|
||||||
|
}
|
50
support.nix
Normal file
50
support.nix
Normal file
@ -0,0 +1,50 @@
|
|||||||
|
{ lib, config, ... }: rec {
|
||||||
|
genIni = lib.generators.toINI {
|
||||||
|
mkKeyValue = key: value:
|
||||||
|
let
|
||||||
|
mvalue = if builtins.isBool value then
|
||||||
|
(if value then "true" else "false")
|
||||||
|
else if (builtins.isString value && key != "include-file") then
|
||||||
|
value
|
||||||
|
else
|
||||||
|
builtins.toString value;
|
||||||
|
in "${key}=${mvalue}";
|
||||||
|
};
|
||||||
|
thm = config.themes.colors;
|
||||||
|
splitHex = hexStr:
|
||||||
|
map (x: builtins.elemAt x 0) (builtins.filter (a: a != "" && a != [ ])
|
||||||
|
(builtins.split "(.{2})" (builtins.substring 1 6 hexStr)));
|
||||||
|
hex2decDigits = rec {
|
||||||
|
"0" = 0;
|
||||||
|
"1" = 1;
|
||||||
|
"2" = 2;
|
||||||
|
"3" = 3;
|
||||||
|
"4" = 4;
|
||||||
|
"5" = 5;
|
||||||
|
"6" = 6;
|
||||||
|
"7" = 7;
|
||||||
|
"8" = 8;
|
||||||
|
"9" = 9;
|
||||||
|
"a" = 10;
|
||||||
|
"b" = 11;
|
||||||
|
"c" = 12;
|
||||||
|
"d" = 13;
|
||||||
|
"e" = 14;
|
||||||
|
"f" = 15;
|
||||||
|
A = a;
|
||||||
|
B = b;
|
||||||
|
C = c;
|
||||||
|
D = d;
|
||||||
|
E = e;
|
||||||
|
F = f;
|
||||||
|
};
|
||||||
|
|
||||||
|
doubleDigitHexToDec = hex:
|
||||||
|
16 * hex2decDigits."${builtins.substring 0 1 hex}"
|
||||||
|
+ hex2decDigits."${builtins.substring 1 2 hex}";
|
||||||
|
thmDec = builtins.mapAttrs (name: color: colorHex2Dec color) thm;
|
||||||
|
colorHex2Dec = color:
|
||||||
|
builtins.concatStringsSep ","
|
||||||
|
(map (x: toString (doubleDigitHexToDec x)) (splitHex color));
|
||||||
|
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user