mirror of
https://github.com/ellmau/nixos.git
synced 2025-12-19 09:29:36 +01:00
NIX added type to distinguish between server and graphical systems
Signed-off-by: Stefan Ellmauthaler <stefan.ellmauthaler@tu-dresden.de>
This commit is contained in:
parent
1187caf13c
commit
749594165e
@ -1,113 +1,62 @@
|
|||||||
# Edit this configuration file to define what should be installed on
|
{ pkgs, name, type, flakes, flakeOutputs, ...}:
|
||||||
# your system. Help is available in the configuration.nix(5) man page
|
{ config, pkgs, lib, ...}:
|
||||||
# and in the NixOS manual (accessible by running ‘nixos-help’).
|
|
||||||
|
|
||||||
{ pkgs, name, flakes, flakeOutputs, ... }:
|
|
||||||
{ config, pkgs, ...}:
|
|
||||||
{
|
{
|
||||||
imports =
|
imports =
|
||||||
[ # Include the results of the hardware scan.
|
[ # hardware-configuration result
|
||||||
((./machine + "/${name}") + /hardware-configuration.nix)
|
((./machine + "/${name}") + /hardware-configuration.nix)
|
||||||
|
# machine-specific configuration
|
||||||
(./machine + "/${name}")
|
(./machine + "/${name}")
|
||||||
|
# additional programs
|
||||||
./programs/emacs
|
./programs/emacs
|
||||||
./programs/aspell.nix
|
./programs/aspell.nix
|
||||||
|
# home-manager entry-point
|
||||||
./users
|
./users
|
||||||
];
|
] ++ type;
|
||||||
|
|
||||||
# Use the systemd-boot EFI boot loader.
|
|
||||||
boot.loader.systemd-boot.enable = true;
|
|
||||||
boot.loader.efi.canTouchEfiVariables = true;
|
|
||||||
boot.kernelPackages = pkgs.linuxPackages_latest;
|
|
||||||
|
|
||||||
# networking.hostName = "nucturne"; # Define your hostname. - done in machine/current/default.nix
|
|
||||||
#networking.wireless.enable = true; # Enables wireless support via wpa_supplicant.
|
|
||||||
networking.networkmanager.enable = true;
|
|
||||||
#networking.networkmanager.unmanaged = [ "enp0s20f0u4u1u3" ];
|
|
||||||
|
|
||||||
# Set your time zone.
|
|
||||||
time.timeZone = "Europe/Berlin";
|
time.timeZone = "Europe/Berlin";
|
||||||
|
|
||||||
# The global useDHCP flag is deprecated, therefore explicitly set to false here.
|
|
||||||
# Per-interface useDHCP will be mandatory in the future, so this generated config
|
|
||||||
# replicates the default behaviour.
|
|
||||||
networking.useDHCP = false;
|
|
||||||
# networking.interfaces.eno1.useDHCP = true;
|
|
||||||
# networking.interfaces.enp0s20f0u4u1u3.useDHCP = true;
|
|
||||||
# networking.interfaces.wlp0s20f3.useDHCP = true;
|
|
||||||
|
|
||||||
# Configure network proxy if necessary
|
|
||||||
# networking.proxy.default = "http://user:password@proxy:port/";
|
|
||||||
# networking.proxy.noProxy = "127.0.0.1,localhost,internal.domain";
|
|
||||||
|
|
||||||
# Select internationalisation properties.
|
|
||||||
i18n.defaultLocale = "en_GB.UTF-8";
|
i18n.defaultLocale = "en_GB.UTF-8";
|
||||||
# console = {
|
|
||||||
# font = "Lat2-Terminus16";
|
|
||||||
# keyMap = "us";
|
|
||||||
# };
|
|
||||||
|
|
||||||
# updates and upkeep
|
boot = {
|
||||||
nix.autoOptimiseStore = true;
|
loader = {
|
||||||
|
systemd-boot.enable = true;
|
||||||
|
efi.canTouchEfiVariables = true;
|
||||||
|
};
|
||||||
|
kernelPackages = pkgs.linuxPackages_latest;
|
||||||
|
};
|
||||||
|
|
||||||
# flake options
|
networking = {
|
||||||
nix.extraOptions = ''
|
useDHCP = false;
|
||||||
|
};
|
||||||
|
|
||||||
|
nix = {
|
||||||
|
autoOptimiseStore = true;
|
||||||
|
extraOptions = ''
|
||||||
experimental-features = nix-command flakes
|
experimental-features = nix-command flakes
|
||||||
'';
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
nixpkgs.overlays = [ flakes.emacs-overlay.overlay flakeOutputs.overlay ];
|
nixpkgs = {
|
||||||
|
overlays = [ flakes.emacs-overlay.overlay flakeOutputs.overlay ];
|
||||||
# Enable the X11 windowing system.
|
config.allowUnfreePredicate = pkg: builtins.elem (lib.getName pkg) [
|
||||||
services.xserver.enable = true;
|
"zoom"
|
||||||
|
"skypeforlinux"
|
||||||
|
|
||||||
# Enable i3
|
|
||||||
services.xserver.displayManager.lightdm.enable = true;
|
|
||||||
services.xserver.windowManager.i3 = {
|
|
||||||
enable = true;
|
|
||||||
extraPackages = with pkgs; [
|
|
||||||
rofi # launcher
|
|
||||||
polybarFull # bar
|
|
||||||
i3lock # lock screen
|
|
||||||
xss-lock
|
|
||||||
autorandr
|
|
||||||
];
|
];
|
||||||
extraSessionCommands = ''
|
|
||||||
${pkgs.autorandr}/bin/autorandr -c
|
|
||||||
'';
|
|
||||||
};
|
};
|
||||||
|
|
||||||
services.gnome.gnome-keyring.enable = true;
|
services = {
|
||||||
|
dbus = {
|
||||||
services.dbus = {
|
|
||||||
enable = true;
|
enable = true;
|
||||||
packages = with pkgs; [ gnome3.dconf ];
|
packages = with pkgs; [gnome3.dconf];
|
||||||
};
|
};
|
||||||
|
|
||||||
services.lorri.enable = true;
|
lorri.enable = true;
|
||||||
|
};
|
||||||
|
|
||||||
programs.dconf.enable = true;
|
users = {
|
||||||
|
mutableUsers = false;
|
||||||
hardware.bluetooth.enable = true;
|
users = {
|
||||||
services.blueman.enable = true;
|
ellmau = {
|
||||||
|
|
||||||
|
|
||||||
# Configure keymap in X11
|
|
||||||
services.xserver.layout = "us";
|
|
||||||
services.xserver.xkbOptions = "eurosign:e";
|
|
||||||
|
|
||||||
# Enable CUPS to print documents.
|
|
||||||
services.printing.enable = true;
|
|
||||||
|
|
||||||
# Enable sound.
|
|
||||||
sound.enable = true;
|
|
||||||
hardware.pulseaudio.enable = true;
|
|
||||||
|
|
||||||
# Enable touchpad support (enabled default in most desktopManager).
|
|
||||||
# services.xserver.libinput.enable = true;
|
|
||||||
|
|
||||||
# Define a user account. Don't forget to set a password with ‘passwd’.
|
|
||||||
users.mutableUsers = false;
|
|
||||||
users.users.ellmau = {
|
|
||||||
isNormalUser = true;
|
isNormalUser = true;
|
||||||
extraGroups = [ "wheel" "networkmanager" "audio"];
|
extraGroups = [ "wheel" "networkmanager" "audio"];
|
||||||
description = "Stefan Ellmauthaler";
|
description = "Stefan Ellmauthaler";
|
||||||
@ -115,40 +64,34 @@
|
|||||||
home = "/home/ellmau";
|
home = "/home/ellmau";
|
||||||
hashedPassword = "$6$JZPnaZYG$KL2c3e1it3j2avioovE1WveN/mpmq/tPsSAvHY1XRhtqKaE7TaSQkqRy69farkIR0Xs0.yTjltvKvv28kZtLO1";
|
hashedPassword = "$6$JZPnaZYG$KL2c3e1it3j2avioovE1WveN/mpmq/tPsSAvHY1XRhtqKaE7TaSQkqRy69farkIR0Xs0.yTjltvKvv28kZtLO1";
|
||||||
};
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
# List packages installed in system profile. To search, run:
|
environment = {
|
||||||
# $ nix search wget
|
shells = [ pkgs.zsh ];
|
||||||
environment.systemPackages = with pkgs; [
|
pathsToLink = [ "/share/zsh/" ];
|
||||||
# Do not forget to add an editor to edit configuration.nix! The Nano editor is also installed by default.
|
systemPackages = with pkgs; [
|
||||||
#emacs
|
|
||||||
#aspell
|
|
||||||
emacs-all-the-icons-fonts
|
emacs-all-the-icons-fonts
|
||||||
wget
|
wget
|
||||||
firefox
|
|
||||||
alacritty
|
|
||||||
git
|
git
|
||||||
thunderbird-91
|
tmux
|
||||||
okular
|
|
||||||
texlive.combined.scheme-full
|
|
||||||
rustup
|
|
||||||
rust-analyzer
|
|
||||||
usbutils
|
|
||||||
#gcc
|
|
||||||
clang
|
clang
|
||||||
keepassxc
|
|
||||||
gnome.libsecret
|
|
||||||
arandr
|
|
||||||
rnix-lsp
|
rnix-lsp
|
||||||
];
|
];
|
||||||
|
sessionVariables = rec {
|
||||||
|
XDG_CACHE_HOME = "\${HOME}/.cache";
|
||||||
|
XDG_CONFIG_HOME = "\${HOME}/.config";
|
||||||
|
XDG_BIN_HOME = "\${HOME}/.local/bin";
|
||||||
|
XDG_DATA_HOME = "\${HOME}/.local/share";
|
||||||
|
|
||||||
|
PATH = [
|
||||||
|
"\${XDG_BIN_HOME}"
|
||||||
|
];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
#services.emacs.enable = true;
|
programs = {
|
||||||
#services.emacs.defaultEditor = true;
|
zsh = {
|
||||||
|
|
||||||
environment.shells = [ pkgs.zsh ];
|
|
||||||
environment.pathsToLink = [ "/share/zsh" ];
|
|
||||||
|
|
||||||
programs.zsh = {
|
|
||||||
enable = true;
|
enable = true;
|
||||||
enableCompletion = true;
|
enableCompletion = true;
|
||||||
enableGlobalCompInit = true;
|
enableGlobalCompInit = true;
|
||||||
@ -161,34 +104,13 @@
|
|||||||
setOptions = [ "auto_pushd" "correct" "extendedglob" "nocaseglob" "rcexpandparam" "numericglobsort" "nobeep" "appendhistory" ];
|
setOptions = [ "auto_pushd" "correct" "extendedglob" "nocaseglob" "rcexpandparam" "numericglobsort" "nobeep" "appendhistory" ];
|
||||||
};
|
};
|
||||||
|
|
||||||
# Some programs need SUID wrappers, can be configured further or are
|
mtr.enable = true;
|
||||||
# started in user sessions.
|
gnupg.agent = {
|
||||||
programs.mtr.enable = true;
|
|
||||||
programs.gnupg.agent = {
|
|
||||||
enable = true;
|
enable = true;
|
||||||
enableSSHSupport = true;
|
enableSSHSupport = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
# List services that you want to enable:
|
dconf.enable = true;
|
||||||
|
|
||||||
# Enable the OpenSSH daemon.
|
|
||||||
# services.openssh.enable = true;
|
|
||||||
|
|
||||||
# Open ports in the firewall.
|
|
||||||
# networking.firewall.allowedTCPPorts = [ ... ];
|
|
||||||
# networking.firewall.allowedUDPPorts = [ ... ];
|
|
||||||
# Or disable the firewall altogether.
|
|
||||||
# networking.firewall.enable = false;
|
|
||||||
|
|
||||||
environment.sessionVariables = rec {
|
|
||||||
XDG_CACHE_HOME = "\${HOME}/.cache";
|
|
||||||
XDG_CONFIG_HOME = "\${HOME}/.config";
|
|
||||||
XDG_BIN_HOME = "\${HOME}/.local/bin";
|
|
||||||
XDG_DATA_HOME = "\${HOME}/.local/share";
|
|
||||||
|
|
||||||
PATH = [
|
|
||||||
"\${XDG_BIN_HOME}"
|
|
||||||
];
|
|
||||||
};
|
};
|
||||||
|
|
||||||
fonts = {
|
fonts = {
|
||||||
@ -221,7 +143,6 @@
|
|||||||
# };
|
# };
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
# This value determines the NixOS release from which the default
|
# This value determines the NixOS release from which the default
|
||||||
# settings for stateful data, like file locations and database versions
|
# settings for stateful data, like file locations and database versions
|
||||||
# on your system were taken. It‘s perfectly fine and recommended to leave
|
# on your system were taken. It‘s perfectly fine and recommended to leave
|
||||||
@ -229,6 +150,4 @@
|
|||||||
# Before changing this value read the documentation for this option
|
# Before changing this value read the documentation for this option
|
||||||
# (e.g. man configuration.nix or on https://nixos.org/nixos/options.html).
|
# (e.g. man configuration.nix or on https://nixos.org/nixos/options.html).
|
||||||
system.stateVersion = "21.05"; # Did you read the comment?
|
system.stateVersion = "21.05"; # Did you read the comment?
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -6,8 +6,9 @@
|
|||||||
system = if args ? system then args.system else "x86_64-linux";
|
system = if args ? system then args.system else "x86_64-linux";
|
||||||
extraModules = if args ? extraModules then args.extraModules else [ ];
|
extraModules = if args ? extraModules then args.extraModules else [ ];
|
||||||
extraOverlays = if args ? extraOverlays then args.extraOverlays else [ ];
|
extraOverlays = if args ? extraOverlays then args.extraOverlays else [ ];
|
||||||
|
type = if args ? type then args.type else [ ./layer/graphical.nix ];
|
||||||
pkgs = flakes.nixpkgs;
|
pkgs = flakes.nixpkgs;
|
||||||
configuration = if args ? configuration then args.configuration else import ./configuration.nix {inherit extraOverlays system pkgs name flakes flakeOutputs;} ;
|
configuration = if args ? configuration then args.configuration else import ./configuration.nix {inherit extraOverlays system pkgs name type flakes flakeOutputs;} ;
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
inherit name;
|
inherit name;
|
||||||
@ -31,4 +32,9 @@ flakes.nixpkgs.lib.listToAttrs (map mkMachine [
|
|||||||
name = "nucturne";
|
name = "nucturne";
|
||||||
extraModules = [ flakes.home-manager.nixosModules.home-manager ];
|
extraModules = [ flakes.home-manager.nixosModules.home-manager ];
|
||||||
}
|
}
|
||||||
|
{
|
||||||
|
name = "ellmauthaler.net";
|
||||||
|
extraModules = [ flakes.home-manager.nixosModules.home-manager ];
|
||||||
|
type = [ ./layer/server.nix ];
|
||||||
|
}
|
||||||
])
|
])
|
||||||
|
|||||||
12
flake.lock
generated
12
flake.lock
generated
@ -2,11 +2,11 @@
|
|||||||
"nodes": {
|
"nodes": {
|
||||||
"emacs-overlay": {
|
"emacs-overlay": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1636363962,
|
"lastModified": 1636450031,
|
||||||
"narHash": "sha256-DyF+NBIPF7f8IZ6zI0NKbTjnfAq7tTSr74k2zVolQsw=",
|
"narHash": "sha256-20fe+sqam5FHDmaxKm4ix55/FPgkWV64V8WdL8DcMQM=",
|
||||||
"owner": "nix-community",
|
"owner": "nix-community",
|
||||||
"repo": "emacs-overlay",
|
"repo": "emacs-overlay",
|
||||||
"rev": "086344663fbd821023dd4cce8cb5eecc502c2769",
|
"rev": "afd2e166179d8ba8c8eb6dc24e23fef8d10ce3ab",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
@ -54,11 +54,11 @@
|
|||||||
},
|
},
|
||||||
"nixpkgs": {
|
"nixpkgs": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1636196544,
|
"lastModified": 1636333654,
|
||||||
"narHash": "sha256-15s56Yu3vF8Na4yx4HkNc3997WZltOIB2CT1sOiCKKM=",
|
"narHash": "sha256-3wh9PtCzcaJQuZrgZ+ygKfhltkDNNqT6zOzGsRbjZEo=",
|
||||||
"owner": "NixOS",
|
"owner": "NixOS",
|
||||||
"repo": "nixpkgs",
|
"repo": "nixpkgs",
|
||||||
"rev": "ce48bcdde86eef5780a60bea55b9bc9dbd8248cd",
|
"rev": "e74894146a42ba552ebafa19ab2d1df7ccbc1738",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
|
|||||||
50
layer/graphical.nix
Normal file
50
layer/graphical.nix
Normal file
@ -0,0 +1,50 @@
|
|||||||
|
{ config, pkgs, ... }:
|
||||||
|
{
|
||||||
|
networking.networkmanager.enable = true;
|
||||||
|
|
||||||
|
services = {
|
||||||
|
xserver = {
|
||||||
|
enable = true;
|
||||||
|
displayManager.lightdm.enable = true;
|
||||||
|
windowManager.i3 = {
|
||||||
|
enable = true;
|
||||||
|
extraPackages = with pkgs; [
|
||||||
|
rofi # launcher
|
||||||
|
polybarFull # bar
|
||||||
|
i3lock # lock screen
|
||||||
|
xss-lock
|
||||||
|
autorandr
|
||||||
|
];
|
||||||
|
extraSessionCommands = ''
|
||||||
|
${pkgs.autorandr}/bin/autorandr -c
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
layout = "us";
|
||||||
|
xkbOptions = "eurosign:e";
|
||||||
|
};
|
||||||
|
gnome.gnome-keyring.enable = true;
|
||||||
|
|
||||||
|
printing.enable = true;
|
||||||
|
};
|
||||||
|
|
||||||
|
sound.enable = true;
|
||||||
|
|
||||||
|
hardware = {
|
||||||
|
pulseaudio.enable = true;
|
||||||
|
bluetooth.enable = true;
|
||||||
|
};
|
||||||
|
|
||||||
|
services.blueman.enable = true;
|
||||||
|
|
||||||
|
environment.systemPackages = with pkgs; [
|
||||||
|
firefox
|
||||||
|
alacritty
|
||||||
|
thunderbird-91
|
||||||
|
okular
|
||||||
|
texlive.combined.scheme-full
|
||||||
|
usbutils
|
||||||
|
keepassxc
|
||||||
|
gnome.libsecret
|
||||||
|
arandr
|
||||||
|
];
|
||||||
|
}
|
||||||
3
layer/server.nix
Normal file
3
layer/server.nix
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
{ config, pkgs, ...}:
|
||||||
|
{
|
||||||
|
}
|
||||||
@ -7,9 +7,4 @@
|
|||||||
useGlobalPkgs = true;
|
useGlobalPkgs = true;
|
||||||
users.ellmau = (import ./ellmau/home.nix);
|
users.ellmau = (import ./ellmau/home.nix);
|
||||||
};
|
};
|
||||||
|
|
||||||
nixpkgs.config.allowUnfreePredicate = pkg: builtins.elem (lib.getName pkg) [
|
|
||||||
"zoom"
|
|
||||||
"skypeforlinux"
|
|
||||||
];
|
|
||||||
}
|
}
|
||||||
|
|||||||
@ -22,6 +22,8 @@
|
|||||||
pkgs.nixpkgs-fmt
|
pkgs.nixpkgs-fmt
|
||||||
pkgs.nix-prefetch-github
|
pkgs.nix-prefetch-github
|
||||||
|
|
||||||
|
pkgs.gh
|
||||||
|
|
||||||
pkgs.neofetch
|
pkgs.neofetch
|
||||||
|
|
||||||
pkgs.jitsi-meet-electron
|
pkgs.jitsi-meet-electron
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user