Compare commits

...

11 Commits

Author SHA1 Message Date
Nina Chlóe Kassandra Reiß
579cd749a9 Remove home-manager from nixos configuration 2026-04-20 12:00:08 +02:00
Nina Chlóe Kassandra Reiß
36585f4206 First attempts on using distrobox 2026-04-08 21:55:18 +02:00
Nina Chlóe Kassandra Reiß
e474979699 Add lua to neovim/editor configuration 2026-03-28 11:05:08 +01:00
Nina Chlóe Kassandra Reiß
1130a847a6 Add ctags support for neovim 2026-03-28 07:31:47 +01:00
Nina Chlóe Kassandra Reiß
b474cabc0e Add speed dreams file (no-app-image) 2026-03-26 10:49:23 +01:00
Nina Chlóe Kassandra Reiß
810138e9d4 Add automount 2026-03-18 17:31:24 +01:00
Nina Chlóe Kassandra Reiß
5984cd8b3a Add ipsec vpn 2026-03-18 13:30:49 +01:00
Nina Chlóe Kassandra Reiß
1b1b8111ba Update network configuration 2026-03-18 13:17:08 +01:00
Nina Chlóe Kassandra Reiß
7834f74b01 Remove networkmanager and wireguard common packages 2026-03-18 13:10:10 +01:00
Nina Chloé Kassandra Reiß
a8347ee783 Add wireguard support 2026-03-18 13:06:28 +01:00
Nina Chloé Kassandra Reiß
6bc88ba514 Adjust name 2026-03-18 13:03:16 +01:00
12 changed files with 149 additions and 163 deletions

View File

@@ -1,9 +0,0 @@
{ config, pkgs, lib, ... }:
let
profile = import ./profile.nix;
in
{
environment.systemPackages = with pkgs; [
openmodelica.combined
];
}

View File

@@ -4,41 +4,47 @@
{ config, pkgs, ... }:
let
profile = import ./profile.nix;
profile = import ./profile.nix;
in
{
imports =
[ # Include the results of the hardware scan.
./hardware-configuration.nix
./cron-schedule.nix
./home-manager.nix
];
imports = [
# Include the results of the hardware scan.
./hardware-configuration.nix
./cron-schedule.nix
./home-manager.nix
];
# Bootloader.
boot.loader.systemd-boot.enable = true;
boot.loader.efi.canTouchEfiVariables = true;
boot.extraModulePackages = with config.boot.kernelPackages; [
v4l2loopback
];
boot.kernelModules = [ "v4l2loopback" ];
boot.extraModprobeConfig = ''
options v4l2loopback video_nr=10 card_label=snapcam exclusive_caps=1
'';
boot.extraModulePackages = with config.boot.kernelPackages; [
v4l2loopback
];
boot.kernelModules = [ "v4l2loopback" ];
boot.extraModprobeConfig = ''
options v4l2loopback video_nr=10 card_label=snapcam exclusive_caps=1
'';
networking.hostName = profile.hostname; # Define your hostname.
# networking.wireless.enable = true; # Enables wireless support via wpa_supplicant.
# Enable networking
networking.networkmanager.enable = true;
networking.networkmanager = {
enable = true;
plugins = with pkgs; [
networkmanager-ssh
networkmanager-openvpn
networkmanager-strongswan
];
};
# Set your time zone.
time.timeZone = "Europe/Berlin";
# Select internationalisation properties.
# Select internationalization properties.
i18n.defaultLocale = "de_DE.UTF-8";
i18n.extraLocaleSettings = {
@@ -77,33 +83,32 @@ boot.extraModprobeConfig = ''
console.keyMap = "de-latin1";
environment.systemPackages = with pkgs; [
wget
networkmanager
epiphany
nodejs_24
dive
podman-tui
podman-compose
gmp
gmp.dev
pkg-config
wget
strongswan
nodejs_24
dive
podman-tui
podman-compose
gmp
gmp.dev
pkg-config
];
programs.nix-ld = {
enable = true;
libraries = with pkgs; [
stdenv.cc.cc
zlib
gmp
openssl
curl
glib
gtk3
libGL
xorg.libX11
appimage-run
libgcrypt
libxcrypt
stdenv.cc.cc
zlib
gmp
openssl
curl
glib
gtk3
libGL
xorg.libX11
appimage-run
libgcrypt
libxcrypt
];
};
@@ -132,7 +137,10 @@ boot.extraModprobeConfig = ''
# Enable the OpenSSH daemon.
services.openssh.enable = true;
nix.settings.experimental-features = [ "nix-command" "flakes" ];
nix.settings.experimental-features = [
"nix-command"
"flakes"
];
nixpkgs.config.allowUnfree = true;
# This value determines the NixOS release from which the default
# settings for stateful data, like file locations and database versions

View File

@@ -8,7 +8,7 @@ in
./browser.nix
./planner.nix
./window-manager.nix
../applications/matrix-element.nix
../applications/matrix.nix
];
environment.systemPackages = with pkgs; [

View File

@@ -45,18 +45,4 @@ in
programs.waybar = {
enable = true;
};
home-manager.users.${profile.username} = { ... }: {
home.file.".config/hypr" = {
source = dotfiles_hypr;
recursive = true;
};
home.file.".config/waybar" = {
source = dotfiles_waybar;
recursive = true;
};
};
}

View File

@@ -7,7 +7,6 @@ in
{
imports = [
<home-manager/nixos>
./desktop-environment/config.nix
./terminal-environment/config.nix
./system-environment/config.nix
@@ -16,51 +15,10 @@ in
users.users.${profile.username} = {
isNormalUser = true;
description = "Nina Chlóe Kassandra";
extraGroups = [ "networkmanager" "wheel" "docker" "scanner" "lp" "uucp" "dialout"];
extraGroups = ["disks" "storage" "networkmanager" "wheel" "docker" "scanner" "lp" "uucp" "dialout"];
packages = with pkgs; [];
shell = pkgs.zsh;
hashedPassword = profile.hashed-password;
};
home-manager.backupFileExtension = "bck.lck";
home-manager.users.${profile.username} = { pkgs, ... }: {
home.stateVersion = "25.11";
programs.git = {
enable = true;
settings = {
user = {
name = "Nina Chloé Kassandra Reiß";
email = "nina.reiss@nickr.eu";
};
push = {
autoSetupRemote = true;
};
};
};
programs.ssh = {
enable = true;
extraConfig = ''
Host git.nickr.eu
HostName git.nickr.eu
Port 22
Host nickr.eu
HostName nickr.eu
Port 222
Host nichkara.eu
HostName nichkara.eu
Port 222
Host git.nichkara.eu
HostName git.nichkara.eu
Port 22
'';
};
hashedPassword = profile.hashed-password;
};
systemd.services.generate-ssh-key = {

View File

@@ -1,6 +1,9 @@
{ pkgs, ... }:
{
services.udisks2.enable = true;
services.gvfs.enable = true;
environment.systemPackages = with pkgs; [
nextcloud-client
unzip

View File

@@ -13,6 +13,7 @@ in
astyle
hyfetch
fzf-zsh
distrobox
];
programs.tmux = {
@@ -63,58 +64,4 @@ in
theme = "sonicradish";
};
};
home-manager.users.${profile.username} = { ... }: {
programs.zsh = {
enable = true;
enableCompletion = true;
autocd = true;
autosuggestion = {
enable = true;
};
syntaxHighlighting = {
enable = true;
};
history = {
size = 4096;
ignoreSpace = true;
ignorePatterns = [ ];
saveNoDups = true;
ignoreAllDups = true;
};
oh-my-zsh = {
enable = true;
theme = "sonicradish";
plugins = [
"git"
"z"
"dotenv"
"battery"
"emoji"
"emoji-clock"
"fzf"
"kitty"
"themes"
"tmux"
"vi-mode"
];
};
setOptions = [
"HIST_IGNORE_ALL_DUPS"
];
shellAliases = {
ll = "ls -lh";
nix-check = "nixos-rebuild build";
nix-update = "sudo nixos-rebuild switch";
sirc = "ssh -t nichkara.eu tmux new-session -A -s weechat weechat";
};
};
};
}

View File

@@ -9,6 +9,8 @@ in
fzf
ripgrep
ripgrep-all
ctags
lua54Packages.luarocks-nix
];
programs.neovim = {
@@ -17,5 +19,7 @@ in
withPython3 = true;
withRuby = true;
withNodeJs = true;
viAlias = true;
vimAlias = true;
};
}

View File

@@ -0,0 +1,67 @@
{ pkgs, lib, ... }:
let
genv = pkgs.writeShellScriptBin "genv" ''
#!/usr/bin/env bash
set -e
DISTRO="$1"
PRESET="$2"
if [ -z "$DISTRO" ] || [ -z "$PRESET" ]; then
echo "Usage: genv <distro> <preset>"
exit 1
fi
PROJECT=$(basename "$PWD")
BOX="genv-$PROJECT"
# distro mapping
case "$DISTRO" in
ubuntu) IMAGE="docker.io/library/ubuntu:24.04" ;;
arch) IMAGE="docker.io/library/archlinux:latest" ;;
alpine) IMAGE="docker.io/library/alpine:latest" ;;
*) IMAGE="$DISTRO" ;;
esac
echo "[genv] image: $IMAGE"
# container nur erstellen wenn nötig
if ! distrobox list | grep -q "$BOX"; then
distrobox create --name "$BOX" --image "$IMAGE"
fi
mkdir -p .genv
# preset kopieren
cp ${./presets}/$PRESET.sh .genv/setup.sh
chmod +x .genv/setup.sh
# envrc generieren
cat > .envrc <<EOF
export GENV_BOX="$BOX"
# container starten
distrobox start "$GENV_BOX" >/dev/null 2>&1 || true
# setup einmalig
if [ ! -f .genv/.init ]; then
echo "[genv] setup läuft"
distrobox enter "$GENV_BOX" -- bash .genv/setup.sh
touch .genv/.init
fi
# tmux workflow
if [ -z "$TMUX" ]; then
tmux new-session -A -s "$GENV_BOX" \
\; new-window -n editor "nvim" \
\; new-window -n dev "distrobox enter $GENV_BOX"
fi
EOF
echo "[genv] fertig direnv allow"
'';
in
{
home.packages = [ genv ];
}

View File

@@ -0,0 +1,11 @@
#!/usr/bin/env bash
set -e
if command -v apt >/dev/null; then
sudo apt update
sudo apt install -y build-essential cmake
elif command -v pacman >/dev/null; then
sudo pacman -Sy --noconfirm base-devel cmake
elif command -v apk >/dev/null; then
sudo apk add build-base cmake
fi

View File

@@ -0,0 +1,11 @@
#!/usr/bin/env bash
set -e
if command -v apt >/dev/null; then
sudo apt update
sudo apt install -y python3
elif command -v pacman >/dev/null; then
sudo pacman -Sy --noconfirm base-devel python3
elif command -v apk >/dev/null; then
sudo apk add build-base python3
fi