Go to file
Andreas Zweili 67c69fcb36 Merge branch 'master' of git.2li.ch:Nebucatnetzer/nixos 2023-08-27 13:35:10 +02:00
home-manager Merge branch 'master' of git.2li.ch:Nebucatnetzer/nixos 2023-08-27 13:35:10 +02:00
lib Begin restructering home-manager 2023-06-07 20:27:13 +02:00
modules Update TT-RSS 2023-08-21 14:29:42 +02:00
scripts Replace python shebang with nix-shell shebang 2023-07-22 14:29:02 +02:00
scrts Update secrets for staubfinger 2023-06-12 16:06:08 +02:00
systems Enable distrobox on work-vm 2023-08-23 17:06:11 +02:00
.envrc extend the development environment 2022-03-18 18:06:59 +01:00
.gitignore Update gitignore 2022-11-11 20:42:52 +01:00
.gitmodules Remove unused submodule 2022-11-11 20:42:12 +01:00
LICENSE Initial commit 2021-11-15 17:43:04 +01:00
README.md Update README 2023-07-22 14:33:00 +02:00
flake.lock Update flake 2023-08-21 14:27:13 +02:00
flake.nix First rewrite for the home-manager unstable overlay 2023-06-28 09:32:13 +02:00
shell.nix Remove unused packges 2023-07-22 14:27:04 +02:00

README.md

nixos

This repository contains my configuration for my Nixos systems. I don't provide any garantuees that it will work on other systems. In addition some of the scripts required for installation will destroy your data when used.

Raspberry Pi installation

  1. Add the new system to flake.nix.
  2. Build the image with scripts/build-raspi-image.sh SYSTEMNAME
  3. Flash the image to an SD card dd if=~/Downloads/SYSTEMNAME.img of=/dev/mmcblk0 bs=4M.
  4. After you've booted the Pi get the new SSH key with ssh-keyscan hostname.custom.domain and add it to scrts/secrets.nix.
  5. Then login into the new Pi and mount the FIRMWARE partition with sudo mkdir -p /mnt && sudo mount /dev/disk/by-label/FIRMWARE /mnt and make sure that your config.txt looks like ./systems/raspi4/config.txt
  6. Change the password

x86 installation

  1. curl https://git.2li.ch/Nebucatnetzer/nixos/archive/master.tar.gz | tar xz
  2. cd nixos && nix-shell
  3. sudo ./scripts/format-disk.py
  4. sudo nixos-install --no-root-passwd --root /mnt --impure --flake .#SYSTEMNAME

Update remote systems

Simply run the script scripts/remote_switch.sh and it will iterate over all defined systems. With the option -r the systems will reboot as well.

Non-Nixos System

  1. scripts/install-home-manager.sh

Development

Options template

{ config, lib, pkgs, ... }:
let
  cfg = config.programs.NAME;
in
{
  options = {
    programs.NAME.enable = lib.mkEnableOption "DESCRIPTION";
  };

  config = lib.mkIf cfg.enable {
  };
}