Compare commits
7 commits
0451c75fa1
...
f04eb7b0ae
Author | SHA1 | Date | |
---|---|---|---|
Dmitry Voronin | f04eb7b0ae | ||
Dmitry Voronin | 8c31e4b05f | ||
Dmitry Voronin | a191472955 | ||
Dmitry Voronin | 4de25671a2 | ||
Dmitry Voronin | 9adc056f6a | ||
Dmitry Voronin | 56e3f9ec6c | ||
Dmitry Voronin | 66882a8820 |
46
flake.nix
46
flake.nix
|
@ -100,7 +100,7 @@
|
||||||
|
|
||||||
outputs = { self, nixpkgs, nix-on-droid, home-manager, stylix, ... } @inputs: {
|
outputs = { self, nixpkgs, nix-on-droid, home-manager, stylix, ... } @inputs: {
|
||||||
# Constant values.
|
# Constant values.
|
||||||
nixosModules.const = {
|
const = {
|
||||||
droidStateVersion = "22.11";
|
droidStateVersion = "22.11";
|
||||||
stateVersion = "23.11";
|
stateVersion = "23.11";
|
||||||
timeZone = "Europe/Moscow";
|
timeZone = "Europe/Moscow";
|
||||||
|
@ -108,35 +108,17 @@
|
||||||
};
|
};
|
||||||
|
|
||||||
# Common modules used across all hosts.
|
# Common modules used across all hosts.
|
||||||
nixosModules.common.imports = [
|
nixosModules.common = let
|
||||||
./module/common/AutoUpdateSigned.nix
|
ls = path: map (f: "${path}/${f}") (
|
||||||
./module/common/Bash.nix
|
builtins.filter (i: builtins.readFileType "${path}/${i}" == "regular") (
|
||||||
./module/common/Bootloader.nix
|
builtins.attrNames (builtins.readDir path)
|
||||||
./module/common/Crypto.nix
|
)
|
||||||
./module/common/Distrobox.nix
|
);
|
||||||
./module/common/Dotfiles.nix
|
in {
|
||||||
./module/common/Filesystem.nix
|
imports = (ls ./module/common) ++ [
|
||||||
./module/common/Firefox.nix
|
|
||||||
./module/common/Firewall.nix
|
|
||||||
./module/common/Font.nix
|
|
||||||
./module/common/Git.nix
|
|
||||||
./module/common/KbdInterception.nix
|
|
||||||
./module/common/Kernel.nix
|
|
||||||
./module/common/Ld.nix
|
|
||||||
./module/common/Locale.nix
|
|
||||||
./module/common/Network.nix
|
|
||||||
./module/common/Nix.nix
|
|
||||||
./module/common/Nvim.nix
|
|
||||||
./module/common/Package.nix
|
|
||||||
./module/common/Ssh.nix
|
|
||||||
./module/common/Sshd.nix
|
|
||||||
./module/common/Stylix.nix
|
|
||||||
./module/common/Swap.nix
|
|
||||||
./module/common/Tmux.nix
|
|
||||||
./module/common/Users.nix
|
|
||||||
./module/common/YtDlp.nix
|
|
||||||
./user/Root.nix
|
./user/Root.nix
|
||||||
];
|
];
|
||||||
|
};
|
||||||
|
|
||||||
# Function to create a host.
|
# Function to create a host.
|
||||||
mkHost = { system, hostname, modules } @args: nixpkgs.lib.nixosSystem {
|
mkHost = { system, hostname, modules } @args: nixpkgs.lib.nixosSystem {
|
||||||
|
@ -145,7 +127,7 @@
|
||||||
modules = [
|
modules = [
|
||||||
./host/${hostname}/Configuration.nix
|
./host/${hostname}/Configuration.nix
|
||||||
{ networking.hostName = hostname; }
|
{ networking.hostName = hostname; }
|
||||||
{ system.stateVersion = self.nixosModules.const.stateVersion; }
|
{ system.stateVersion = self.const.stateVersion; }
|
||||||
inputs.self.nixosModules.common
|
inputs.self.nixosModules.common
|
||||||
home-manager.nixosModules.home-manager
|
home-manager.nixosModules.home-manager
|
||||||
stylix.nixosModules.stylix
|
stylix.nixosModules.stylix
|
||||||
|
@ -155,7 +137,7 @@
|
||||||
pkgs = nixpkgs.legacyPackages.${system}.pkgs;
|
pkgs = nixpkgs.legacyPackages.${system}.pkgs;
|
||||||
config = self.nixosConfigurations.${hostname}.config;
|
config = self.nixosConfigurations.${hostname}.config;
|
||||||
in {
|
in {
|
||||||
const = self.nixosModules.const;
|
const = self.const;
|
||||||
flake = self;
|
flake = self;
|
||||||
inputs = inputs;
|
inputs = inputs;
|
||||||
key = import ./part/Key.nix {};
|
key = import ./part/Key.nix {};
|
||||||
|
@ -277,14 +259,14 @@
|
||||||
# Android.
|
# Android.
|
||||||
nixOnDroidConfigurations.default = nix-on-droid.lib.nixOnDroidConfiguration {
|
nixOnDroidConfigurations.default = nix-on-droid.lib.nixOnDroidConfiguration {
|
||||||
modules = [
|
modules = [
|
||||||
{ system.stateVersion = inputs.self.nixosModules.const.droidStateVersion; }
|
{ system.stateVersion = inputs.self.const.droidStateVersion; }
|
||||||
./module/NixOnDroid.nix
|
./module/NixOnDroid.nix
|
||||||
];
|
];
|
||||||
|
|
||||||
extraSpecialArgs = let
|
extraSpecialArgs = let
|
||||||
pkgs = nixpkgs.legacyPackages."aarch64-linux".pkgs;
|
pkgs = nixpkgs.legacyPackages."aarch64-linux".pkgs;
|
||||||
in {
|
in {
|
||||||
const = self.nixosModules.const;
|
const = self.const;
|
||||||
flake = self;
|
flake = self;
|
||||||
inputs = inputs;
|
inputs = inputs;
|
||||||
key = import ./part/Key.nix {};
|
key = import ./part/Key.nix {};
|
||||||
|
|
|
@ -1,10 +1,10 @@
|
||||||
{ pkgs, inputs, const, style, util, key, setting, ... } @args: let
|
{ pkgs, inputs, const, style, util, key, setting, secret, ... } @args: let
|
||||||
homePath = "/data/data/com.termux.nix/files/home";
|
homePath = "/data/data/com.termux.nix/files/home";
|
||||||
tmux = import ./common/tmux/Init.nix args;
|
tmux = import ./common/tmux args;
|
||||||
tmuxScript = pkgs.writeShellScriptBin "tmux_script" tmux.script;
|
tmuxScript = pkgs.writeShellScriptBin "tmux_script" tmux.script;
|
||||||
bash = import ./common/bash/Init.nix args;
|
bash = import ./common/bash args;
|
||||||
nvim = import ./common/nvim/Init.nix args;
|
nvim = import ./common/nvim args;
|
||||||
ssh = import ./common/ssh/Init.nix args;
|
ssh = import ./common/ssh args;
|
||||||
font = pkgs.runCommandNoCC "font" {} ''
|
font = pkgs.runCommandNoCC "font" {} ''
|
||||||
cp ${pkgs.nerdfonts.override { fonts = [ "Terminus" ]; }}/share/fonts/truetype/NerdFonts/TerminessNerdFontMono-Regular.ttf $out
|
cp ${pkgs.nerdfonts.override { fonts = [ "Terminus" ]; }}/share/fonts/truetype/NerdFonts/TerminessNerdFontMono-Regular.ttf $out
|
||||||
'';
|
'';
|
||||||
|
@ -13,7 +13,74 @@
|
||||||
foreground=#${style.color.fg.light}
|
foreground=#${style.color.fg.light}
|
||||||
'';
|
'';
|
||||||
in {
|
in {
|
||||||
# NOTE: Split into modules?
|
time.timeZone = const.timeZone;
|
||||||
|
nix.extraOptions = ''
|
||||||
|
experimental-features = nix-command flakes
|
||||||
|
'';
|
||||||
|
|
||||||
|
home-manager.config = {
|
||||||
|
home = {
|
||||||
|
stateVersion = const.droidStateVersion;
|
||||||
|
file = {
|
||||||
|
".dotfiles".source = inputs.self;
|
||||||
|
".ssh/config".text = ssh.config;
|
||||||
|
".termux/_font.ttf".source = font;
|
||||||
|
".termux/_colors.properties".text = colors;
|
||||||
|
};
|
||||||
|
sessionVariables = {
|
||||||
|
EDITOR = "nvim";
|
||||||
|
MANPAGER = "nvim +Man!";
|
||||||
|
NIXPKGS_ALLOW_UNFREE = "1";
|
||||||
|
NIX_CURRENT_SYSTEM = "${pkgs.stdenv.system}";
|
||||||
|
TERM = "xterm-256color";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
programs = {
|
||||||
|
bash = {
|
||||||
|
enable = true;
|
||||||
|
bashrcExtra = bash.config + ''
|
||||||
|
[[ -f ~/.termux/font.ttf ]] || {
|
||||||
|
cp ~/.termux/_font.ttf ~/.termux/font.ttf
|
||||||
|
cp ~/.termux/_colors.properties ~/.termux/colors.properties
|
||||||
|
_warn "Termux config installed, please restart."
|
||||||
|
};
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
tmux = {
|
||||||
|
enable = true;
|
||||||
|
extraConfig = tmux.config;
|
||||||
|
};
|
||||||
|
|
||||||
|
git = {
|
||||||
|
enable = true;
|
||||||
|
extraConfig = {
|
||||||
|
credential.helper = "store";
|
||||||
|
init.defaultBranch = "main";
|
||||||
|
pull.rebase = true;
|
||||||
|
push.autoSetupRemote = true;
|
||||||
|
rebase.autoStash = true;
|
||||||
|
user.signingkey = builtins.readFile secret.crypto.sign.key;
|
||||||
|
gpg.ssh.allowedSignersFile = toString(secret.crypto.sign.allowed);
|
||||||
|
gpg.format = secret.crypto.sign.format;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
neovim = {
|
||||||
|
enable = true;
|
||||||
|
viAlias = true;
|
||||||
|
vimAlias = true;
|
||||||
|
extraConfig = nvim.config;
|
||||||
|
};
|
||||||
|
|
||||||
|
gpg = {
|
||||||
|
enable = true;
|
||||||
|
publicKeys = secret.crypto.publicKeys;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
environment.packages = with pkgs; [
|
environment.packages = with pkgs; [
|
||||||
android-tools
|
android-tools
|
||||||
binwalk
|
binwalk
|
||||||
|
@ -31,13 +98,12 @@ in {
|
||||||
gnumake
|
gnumake
|
||||||
gnused
|
gnused
|
||||||
gnutar
|
gnutar
|
||||||
gzip
|
gzip xz
|
||||||
hostname
|
hostname
|
||||||
imagemagick
|
imagemagick
|
||||||
jq
|
jq
|
||||||
lsof
|
lsof
|
||||||
man
|
man
|
||||||
neofetch
|
|
||||||
nmap
|
nmap
|
||||||
openssh
|
openssh
|
||||||
parallel
|
parallel
|
||||||
|
@ -49,60 +115,7 @@ in {
|
||||||
tree
|
tree
|
||||||
utillinux
|
utillinux
|
||||||
wget
|
wget
|
||||||
xz
|
|
||||||
yt-dlp
|
yt-dlp
|
||||||
zip unzip
|
zip unzip
|
||||||
];
|
];
|
||||||
|
|
||||||
time.timeZone = const.timeZone;
|
|
||||||
nix.extraOptions = ''
|
|
||||||
experimental-features = nix-command flakes
|
|
||||||
'';
|
|
||||||
|
|
||||||
home-manager.config = {
|
|
||||||
home.stateVersion = const.droidStateVersion;
|
|
||||||
home.file = {
|
|
||||||
".dotfiles".source = inputs.self;
|
|
||||||
".ssh/config".text = ssh.config;
|
|
||||||
".termux/_font.ttf".source = font;
|
|
||||||
".termux/_colors.properties".text = colors;
|
|
||||||
};
|
|
||||||
home.sessionVariables = {
|
|
||||||
EDITOR = "nvim";
|
|
||||||
MANPAGER = "nvim +Man!";
|
|
||||||
NIXPKGS_ALLOW_UNFREE = "1";
|
|
||||||
NIX_CURRENT_SYSTEM = "${pkgs.stdenv.system}";
|
|
||||||
TERM = "xterm-256color";
|
|
||||||
};
|
|
||||||
programs.bash = {
|
|
||||||
enable = true;
|
|
||||||
bashrcExtra = bash.config + ''
|
|
||||||
[[ -f ~/.termux/font.ttf ]] || {
|
|
||||||
cp ~/.termux/_font.ttf ~/.termux/font.ttf
|
|
||||||
cp ~/.termux/_colors.properties ~/.termux/colors.properties
|
|
||||||
_warn "Termux config installed, please restart."
|
|
||||||
};
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
programs.tmux = {
|
|
||||||
enable = true;
|
|
||||||
extraConfig = tmux.config;
|
|
||||||
};
|
|
||||||
programs.git = {
|
|
||||||
enable = true;
|
|
||||||
extraConfig = {
|
|
||||||
credential.helper = "store";
|
|
||||||
init.defaultBranch = "main";
|
|
||||||
pull.rebase = true;
|
|
||||||
push.autoSetupRemote = true;
|
|
||||||
rebase.autoStash = true;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
programs.neovim = {
|
|
||||||
enable = true;
|
|
||||||
viAlias = true;
|
|
||||||
vimAlias = true;
|
|
||||||
extraConfig = nvim.config;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,9 +0,0 @@
|
||||||
{ ... }: {
|
|
||||||
packages.direnv = {
|
|
||||||
enable = true;
|
|
||||||
silent = true;
|
|
||||||
direnvrcExtra = ''
|
|
||||||
export NIX_SHELL="direnv"
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,6 +1,9 @@
|
||||||
{ pkgs, lib, ... }: {
|
{ const, util, style, pkgs, lib, setting, key, secret, ... } @args: {
|
||||||
imports = [
|
imports = [
|
||||||
./home/Dasha.nix
|
(import ./common (args // {
|
||||||
|
username = "dasha";
|
||||||
|
homeDir = "/home/dasha";
|
||||||
|
}))
|
||||||
];
|
];
|
||||||
users.users.dasha = {
|
users.users.dasha = {
|
||||||
createHome = true;
|
createHome = true;
|
||||||
|
|
|
@ -1,7 +1,11 @@
|
||||||
{ secret, ... }: {
|
{ const, util, style, pkgs, setting, key, secret, ... } @args: {
|
||||||
imports = [
|
imports = [
|
||||||
./home/Root.nix
|
(import ./common (args // {
|
||||||
|
username = "root";
|
||||||
|
homeDir = "/root";
|
||||||
|
}))
|
||||||
];
|
];
|
||||||
|
|
||||||
users.users.root.hashedPassword = secret.hashedPassword;
|
users.users.root.hashedPassword = secret.hashedPassword;
|
||||||
security.sudo = {
|
security.sudo = {
|
||||||
enable = false;
|
enable = false;
|
||||||
|
|
|
@ -1,6 +1,9 @@
|
||||||
{ pkgs, lib, secret, ... }: {
|
{ const, util, style, pkgs, lib, setting, key, secret, ... } @args: {
|
||||||
imports = [
|
imports = [
|
||||||
./home/Voronind.nix
|
(import ./common (args // {
|
||||||
|
username = "voronind";
|
||||||
|
homeDir = "/home/voronind";
|
||||||
|
}))
|
||||||
];
|
];
|
||||||
|
|
||||||
users.users.voronind = {
|
users.users.voronind = {
|
||||||
|
|
53
user/common/default.nix
Normal file
53
user/common/default.nix
Normal file
|
@ -0,0 +1,53 @@
|
||||||
|
{ const, username, homeDir, util, style, pkgs, setting, key, secret, ... } @args: let
|
||||||
|
foot = import ./foot args;
|
||||||
|
mako = import ./mako args;
|
||||||
|
editorconfig = import ./editorconfig args;
|
||||||
|
btop = import ./top/btop args;
|
||||||
|
htop = import ./top/htop args;
|
||||||
|
in {
|
||||||
|
home-manager = {
|
||||||
|
backupFileExtension = "old";
|
||||||
|
|
||||||
|
users.${username} = {
|
||||||
|
home = {
|
||||||
|
username = username;
|
||||||
|
homeDirectory = homeDir;
|
||||||
|
stateVersion = const.stateVersion;
|
||||||
|
file = {
|
||||||
|
".config/btop/btop.conf".text = btop.config;
|
||||||
|
".config/htop/htoprc".text = htop.config;
|
||||||
|
".config/mako/config".text = mako.config;
|
||||||
|
".config/foot/foot.ini".text = foot.config;
|
||||||
|
".editorconfig".text = editorconfig.config;
|
||||||
|
".parallel/will-cite".text = "";
|
||||||
|
"media/template".source = ./template;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
xdg.userDirs = {
|
||||||
|
enable = true;
|
||||||
|
createDirectories = true;
|
||||||
|
desktop = "${homeDir}/";
|
||||||
|
documents = "${homeDir}/document/";
|
||||||
|
download = "${homeDir}/download/";
|
||||||
|
music = "${homeDir}/media/music/";
|
||||||
|
pictures = "${homeDir}/media/picture/";
|
||||||
|
publicShare = "${homeDir}/media/share/";
|
||||||
|
templates = "${homeDir}/media/template/";
|
||||||
|
videos = "${homeDir}/media/video/";
|
||||||
|
extraConfig = {
|
||||||
|
XDG_TMP_DIR = "${homeDir}/tmp/";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
programs = {
|
||||||
|
home-manager.enable = true;
|
||||||
|
gpg = {
|
||||||
|
enable = true;
|
||||||
|
publicKeys = secret.crypto.publicKeys;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
|
@ -1,8 +0,0 @@
|
||||||
{ const, util, style, pkgs, setting, key, secret, ... } @args: {
|
|
||||||
imports = [
|
|
||||||
(import ./common (args // {
|
|
||||||
username = "dasha";
|
|
||||||
homeDir = "/home/dasha";
|
|
||||||
}))
|
|
||||||
];
|
|
||||||
}
|
|
|
@ -1,8 +0,0 @@
|
||||||
{ const, util, style, pkgs, setting, key, secret, ... } @args: {
|
|
||||||
imports = [
|
|
||||||
(import ./common (args // {
|
|
||||||
username = "root";
|
|
||||||
homeDir = "/root";
|
|
||||||
}))
|
|
||||||
];
|
|
||||||
}
|
|
|
@ -1,8 +0,0 @@
|
||||||
{ const, util, style, pkgs, setting, key, secret, ... } @args: {
|
|
||||||
imports = [
|
|
||||||
(import ./common (args // {
|
|
||||||
username = "voronind";
|
|
||||||
homeDir = "/home/voronind";
|
|
||||||
}))
|
|
||||||
];
|
|
||||||
}
|
|
|
@ -1,50 +0,0 @@
|
||||||
{ const, username, homeDir, util, style, pkgs, setting, key, secret, ... } @args: let
|
|
||||||
foot = import ./foot args;
|
|
||||||
mako = import ./mako args;
|
|
||||||
editorconfig = import ./editorconfig args;
|
|
||||||
btop = import ./top/btop args;
|
|
||||||
htop = import ./top/htop args;
|
|
||||||
in {
|
|
||||||
home-manager.backupFileExtension = "old";
|
|
||||||
|
|
||||||
home-manager.users.${username} = {
|
|
||||||
programs.home-manager.enable = true;
|
|
||||||
home.username = username;
|
|
||||||
home.homeDirectory = homeDir;
|
|
||||||
home.stateVersion = const.stateVersion;
|
|
||||||
|
|
||||||
home.file = {
|
|
||||||
".config/btop/btop.conf".text = btop.config;
|
|
||||||
".config/htop/htoprc".text = htop.config;
|
|
||||||
".config/mako/config".text = mako.config;
|
|
||||||
".config/foot/foot.ini".text = foot.config;
|
|
||||||
".editorconfig".text = editorconfig.config;
|
|
||||||
".parallel/will-cite".text = "";
|
|
||||||
"media/template".source = ./template;
|
|
||||||
};
|
|
||||||
|
|
||||||
# Directories.
|
|
||||||
xdg.userDirs = {
|
|
||||||
enable = true;
|
|
||||||
createDirectories = true;
|
|
||||||
desktop = "${homeDir}/";
|
|
||||||
documents = "${homeDir}/document/";
|
|
||||||
download = "${homeDir}/download/";
|
|
||||||
music = "${homeDir}/media/music/";
|
|
||||||
pictures = "${homeDir}/media/picture/";
|
|
||||||
publicShare = "${homeDir}/media/share/";
|
|
||||||
templates = "${homeDir}/media/template/";
|
|
||||||
videos = "${homeDir}/media/video/";
|
|
||||||
extraConfig = {
|
|
||||||
XDG_TMP_DIR = "${homeDir}/tmp/";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
# GPG.
|
|
||||||
programs.gpg = {
|
|
||||||
enable = true;
|
|
||||||
publicKeys = secret.crypto.publicKeys;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
Loading…
Reference in a new issue