Compare commits

..

11 commits

Author SHA1 Message Date
busti
8d654cb086 install vlc, sox and ffmpeg 2021-10-25 13:56:01 +02:00
busti
70bfccd5f6 install pavucontrol and dosbox 2021-10-25 13:56:01 +02:00
7a0544f69a
tmpfsOnTmpfs true on bemmer 2021-10-25 00:12:51 +02:00
51a691efbf
fix deprecation warning
use settings attribute
2021-10-24 23:38:49 +02:00
349bc436a4
fix alias 2021-10-24 23:21:31 +02:00
106b0cec8a
Merge https://git.neulandlabor.de/busti/c3h-nixfiles into HEAD 2021-10-24 23:19:59 +02:00
3e8b76b643
simplify bemmer config some more 2021-10-24 22:56:43 +02:00
8ac7010414
move around users definition 2021-10-24 22:43:11 +02:00
3c80614ee4
update bemmer config 2021-10-24 20:55:28 +02:00
c7dce3b8c0
add nfs client 2021-10-24 20:55:12 +02:00
035b623b42
update deploy script 2021-10-24 20:54:29 +02:00
9 changed files with 58 additions and 53 deletions

View file

@ -1,7 +1,7 @@
{ lib, pkgs, ... }: { lib, pkgs, ... }:
{ {
boot.kernelPackages = lib.mkDefault pkgs.linuxPackages_latest; boot.kernelPackages = lib.mkOverride 2000 pkgs.linuxPackages_latest;
boot.kernelParams = [ "quiet" ]; boot.kernelParams = [ "quiet" ];
services.openssh.enable = true; services.openssh.enable = true;
@ -38,6 +38,11 @@
vim vim
wget wget
jq jq
pavucontrol
dosbox
vlc
ffmpeg-full
sox
]; ];
programs.bash.shellAliases = { programs.bash.shellAliases = {
@ -49,6 +54,13 @@
ll = "exa -l"; ll = "exa -l";
la = "exa -la"; la = "exa -la";
tree = "exa -T"; tree = "exa -T";
apt = "echo 'please use nix-env -iA <packagename> instead to install packages.'"; apt = "echo 'please use nix-env -iA nixos.<packagename> instead to install packages.'";
};
users.mutableUsers = false;
users.users.c3h = {
isNormalUser = true;
password = "c3h";
extraGroups = [ "wheel" ];
}; };
} }

View file

@ -12,15 +12,25 @@ fi
mode="${1:-switch}" mode="${1:-switch}"
host="${2:-nuc}" host="${2:-nuc}"
target="${3:-$host.c3h}" target="${3:-c3h@$host.c3h}"
if ! [ -d "hosts/$host" ]
then
echo "Host $host does not exist. Choose from:"
ls hosts
exit
fi
echo "deploying $host to $target" echo "deploying $host to $target"
sleep 1 sleep 1
sources=$(nix-build nix/sources-dir.nix --no-out-link) tmp=$(mktemp -d)
trap 'rm -rf "$tmp"' EXIT
sources="$tmp/sources"
cp -r $(nix-build nix/sources-dir.nix --no-out-link) $tmp/sources
set -x set -x
system_drv=$(nix-instantiate "<nixpkgs/nixos>" -I $sources -I "nixos-config=$PWD/hosts/$host/configuration.nix" | head -n1) system_drv=$(nix-instantiate "<nixpkgs/nixos>" -A config.system.build.toplevel -I $sources -I "nixos-config=$PWD/hosts/$host/configuration.nix")
nix-copy-closure --to $target $system_drv nix-copy-closure --to $target $system_drv
system=$(ssh $target "nix-store --realise $system_drv") system=$(ssh $target "nix-store --realise $system_drv")
ssh $target "sudo nix-env -p /nix/var/nix/profiles/system -i $system && sudo /nix/var/nix/profiles/system/bin/switch-to-configuration $mode" ssh $target "sudo nix-env -p /nix/var/nix/profiles/system -i $system && sudo /nix/var/nix/profiles/system/bin/switch-to-configuration $mode"

View file

@ -8,7 +8,7 @@
# services # services
../../shared-services/pulseaudio.nix ../../shared-services/pulseaudio.nix
#../../shared-services/nfs-server.nix ../../shared-services/nfs-client.nix
../../shared-services/mpd.nix ../../shared-services/mpd.nix
../../shared-services/ympd.nix ../../shared-services/ympd.nix
../../shared-services/spotifyd.nix ../../shared-services/spotifyd.nix
@ -16,28 +16,21 @@
../../shared-services/vnc.nix ../../shared-services/vnc.nix
../../shared-services/webserver.nix ../../shared-services/webserver.nix
]; ];
users.users.c3h = {
isNormalUser = true; # We import sd-image-aarch64.nix so we can build a config.system.build.sdImage
password = "c3h"; # But it imports some modules we don't want, so disable them
extraGroups = [ "wheel" ]; disabledModules = [
packages = with pkgs; [ chromium firefox mpv youtube-dl ]; "profiles/base.nix"
}; "profiles/all-hardware.nix"
];
networking.hostName = "bemmer"; networking.hostName = "bemmer";
networking.domain = "c3h"; networking.domain = "c3h";
networking.useDHCP = true; networking.useDHCP = true;
nixpkgs.system = "aarch64-linux"; nixpkgs.system = "aarch64-linux";
boot.initrd.availableKernelModules = lib.mkForce [ "vc4" "i2c_bcm2835" ]; hardware.raspberry-pi."4".fkms-3d.enable = true;
boot.supportedFilesystems = lib.mkForce [ "ext4" "vfat" ]; boot.tmpOnTmpfs = true; # building stuff on sd-card is slow
boot.kernelPackages = pkgs.linuxPackages_rpi4;
documentation.enable = false;
hardware.raspberry-pi."4" = {
fkms-3d.enable = true;
#audio.enable = true;
};
system.stateVersion = "21.05"; system.stateVersion = "21.05";
} }

View file

@ -8,7 +8,7 @@
# services # services
../../shared-services/pulseaudio.nix ../../shared-services/pulseaudio.nix
../../shared-services/nfs-server.nix ../../shared-services/nfs-client.nix
../../shared-services/mpd.nix ../../shared-services/mpd.nix
../../shared-services/ympd.nix ../../shared-services/ympd.nix
../../shared-services/spotifyd.nix ../../shared-services/spotifyd.nix

View file

@ -23,7 +23,7 @@
fsType = "vfat"; fsType = "vfat";
}; };
fileSystems."/mnt" = fileSystems."/mnt/hdd" =
{ device = "/dev/disk/by-uuid/ff18a6f9-ee3b-452c-8671-38b74508a74c"; { device = "/dev/disk/by-uuid/ff18a6f9-ee3b-452c-8671-38b74508a74c";
fsType = "btrfs"; fsType = "btrfs";
}; };

View file

@ -1,13 +1,7 @@
{ pkgs, ... }: { pkgs, ... }:
{ {
users.mutableUsers = false; users.users.c3h.packages = with pkgs; [ chromium firefox mpv youtube-dl ];
users.users.c3h = {
isNormalUser = true;
password = "c3h";
extraGroups = [ "wheel" ];
packages = with pkgs; [ chromium firefox mpv youtube-dl ];
};
services.xserver = { services.xserver = {
enable = true; enable = true;

View file

@ -0,0 +1,15 @@
{ ... }:
{
boot.supportedFilesystems = [ "nfs" ];
fileSystems."/mnt/Music" = {
device = "10.23.42.126:/music";
fsType = "nfs";
options = [
"nfsvers=4.1"
"noauto"
"x-systemd.automount"
"x-systemd.idle-timeout=600"
];
};
}

View file

@ -1,17 +0,0 @@
{ ... }:
{
services.nfs.server = {
enable = true;
exports = ''
/mnt 10.23.42.0/24(rw,fsid=0,insecure,no_subtree_check)
'';
statdPort = 4000;
lockdPort = 4001;
mountdPort = 4002;
};
networking.firewall.interfaces.enp3s0.allowedTCPPorts = [ 2049 4000 4001 4002 111 ];
networking.firewall.interfaces.enp3s0.allowedUDPPorts = [ 2049 4000 4001 4002 111 ];
}

View file

@ -1,12 +1,10 @@
{ ... }: { config, ... }:
{ {
services.spotifyd = { services.spotifyd = {
enable = true; enable = true;
config = '' settings.zeroconf_port = 18572;
zeroconf_port = 18572
'';
}; };
networking.firewall.allowedTCPPorts = [ 18572 ]; networking.firewall.allowedTCPPorts = [ config.services.spotifyd.settings.zeroconf_port ];
} }