232 lines
5.7 KiB
Nix
232 lines
5.7 KiB
Nix
|
# Edit this configuration file to define what should be installed on
|
|||
|
# your system. Help is available in the configuration.nix(5) man page
|
|||
|
# and in the NixOS manual (accessible by running ‘nixos-help’).
|
|||
|
|
|||
|
{ config, lib, pkgs, ... }:
|
|||
|
|
|||
|
{
|
|||
|
imports =
|
|||
|
[ # Include the results of the hardware scan.
|
|||
|
./hardware-configuration.nix
|
|||
|
./tahoe.nix
|
|||
|
./gnunet-module.nix
|
|||
|
./wack.nix
|
|||
|
./ai.nix
|
|||
|
];
|
|||
|
|
|||
|
# programs.adb.enable = true;
|
|||
|
|
|||
|
systemd.enableEmergencyMode = false;
|
|||
|
|
|||
|
networking.hostName = "soryu";
|
|||
|
networking.extraHosts = ''
|
|||
|
127.0.0.1 modules-cdn.eac-prod.on.epicgames.com #Star Citizen EAC workaround
|
|||
|
'';
|
|||
|
|
|||
|
# Star Citizen resource limits
|
|||
|
boot.kernel.sysctl = {
|
|||
|
"vm.max_map_count" = 16777216;
|
|||
|
"fs.file-max" = 524288;
|
|||
|
};
|
|||
|
|
|||
|
|
|||
|
disabledModules = [
|
|||
|
"services/network-filesystems/tahoe.nix"
|
|||
|
"services/networking/gnunet.nix"
|
|||
|
];
|
|||
|
|
|||
|
services.resolved.enable = true;
|
|||
|
services.resolved.dnssec = "false";
|
|||
|
|
|||
|
services.gnome.gnome-keyring.enable = true;
|
|||
|
|
|||
|
# services.tahoe.nodes.pvv-danio-desktop = {
|
|||
|
# settings = {
|
|||
|
# storage.enabled = true;
|
|||
|
# storage.storage_dir = "/mnt/human/tahoe-lafs/pvv";
|
|||
|
# client."shares.total" = 10;
|
|||
|
# client."shares.needed" = 4;
|
|||
|
# client."shares.happy" = 1;
|
|||
|
# };
|
|||
|
# };
|
|||
|
|
|||
|
|
|||
|
# services.gnunet = {
|
|||
|
# enable = true;
|
|||
|
# package = pkgs.callPackage ./gnunet.nix { };
|
|||
|
# settings = {
|
|||
|
# hostlist = {
|
|||
|
# OPTIONS = "-b -e";
|
|||
|
# SERVERS = "http://v15.gnunet.org/hostlist https://gnunet.io/hostlist";
|
|||
|
# };
|
|||
|
## nat = {
|
|||
|
## BEHIND_NAT = "YES";
|
|||
|
## ENABLE_UPNP = "NO";
|
|||
|
## DISABLEV6 = "YES";
|
|||
|
## };
|
|||
|
# ats = {
|
|||
|
# WAN_QUOTA_IN = "unlimited";
|
|||
|
# WAN_QUOTA_OUT = "unlimited";
|
|||
|
# };
|
|||
|
# };
|
|||
|
# };
|
|||
|
|
|||
|
ids.gids.gnunetdns = 327;
|
|||
|
|
|||
|
|
|||
|
# services.gnunet = {
|
|||
|
# enable = true;
|
|||
|
# extraOptions = ''
|
|||
|
# [hostlist]
|
|||
|
# OPTIONS = -b -e
|
|||
|
# SERVERS = http://v11.gnunet.org:58080/
|
|||
|
# HTTPPORT = 8080
|
|||
|
# HOSTLISTFILE = $SERVICEHOME/hostlists.file
|
|||
|
# [arm]
|
|||
|
# START_SYSTEM_SERVICES = YES
|
|||
|
# START_USER_SERVICES = NO
|
|||
|
# '';
|
|||
|
# };
|
|||
|
|
|||
|
|
|||
|
services.murmur = {
|
|||
|
enable = true;
|
|||
|
# registerName = "DODSORFAS";
|
|||
|
welcometext = "Dans PC at singsaker smh backup mumble server";
|
|||
|
};
|
|||
|
|
|||
|
# Use the systemd-boot EFI boot loader.
|
|||
|
boot.loader.systemd-boot.enable = true;
|
|||
|
boot.loader.efi.canTouchEfiVariables = true;
|
|||
|
|
|||
|
#boot.kernelParams = ["radeon.cik_support=0" "amdgpu.cik_support=1"];
|
|||
|
boot.extraModulePackages = with config.boot.kernelPackages; [ v4l2loopback ];
|
|||
|
boot.kernelPackages = pkgs.linuxPackages_latest;
|
|||
|
boot.kernelModules = [ "kvm-intel" ];
|
|||
|
|
|||
|
|
|||
|
programs.steam = {
|
|||
|
enable = true;
|
|||
|
remotePlay.openFirewall = false; # Open ports in the firewall for Steam Remote Play
|
|||
|
dedicatedServer.openFirewall = false; # Open ports in the firewall for Source Dedicated Server
|
|||
|
};
|
|||
|
|
|||
|
nixpkgs.config = {
|
|||
|
allowUnfree = true;
|
|||
|
};
|
|||
|
|
|||
|
services.tailscale.enable = true;
|
|||
|
|
|||
|
networking.firewall.interfaces."tailscale0" = let
|
|||
|
all = { from = 0; to = 65535; };
|
|||
|
in {
|
|||
|
allowedUDPPortRanges = [ all ];
|
|||
|
allowedTCPPortRanges = [ all ];
|
|||
|
};
|
|||
|
|
|||
|
# Select internationalisation properties.
|
|||
|
console.keyMap = "no-latin1";
|
|||
|
|
|||
|
time.timeZone = "Europe/Oslo";
|
|||
|
|
|||
|
# List packages installed in system profile. To search, run:
|
|||
|
# $ nix search wget
|
|||
|
environment.systemPackages = with pkgs; [
|
|||
|
wget vim git
|
|||
|
];
|
|||
|
|
|||
|
# Some programs need SUID wrappers, can be configured further or are
|
|||
|
# started in user sessions.
|
|||
|
# programs.mtr.enable = true;
|
|||
|
# programs.gnupg.agent = { enable = true; enableSSHSupport = true; };
|
|||
|
|
|||
|
# List services that you want to enable:
|
|||
|
|
|||
|
# 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 = true;
|
|||
|
networking.firewall.allowedTCPPorts = [ 8000 6007 5001 config.services.murmur.port ];
|
|||
|
networking.firewall.allowedUDPPorts = [ 5001 21977 config.services.murmur.port ];
|
|||
|
|
|||
|
|
|||
|
|
|||
|
# Enable CUPS to print documents.
|
|||
|
# services.printing.enable = true;
|
|||
|
|
|||
|
|
|||
|
security.rtkit.enable = true;
|
|||
|
services.pipewire = {
|
|||
|
enable = true;
|
|||
|
alsa.enable = true;
|
|||
|
alsa.support32Bit = true;
|
|||
|
pulse.enable = true;
|
|||
|
jack.enable = true;
|
|||
|
};
|
|||
|
|
|||
|
|
|||
|
|
|||
|
# systemd.tmpfiles.rules = [
|
|||
|
# "L+ /opt/rocm/hip - - - - ${pkgs.hip}"
|
|||
|
# ];
|
|||
|
|
|||
|
|
|||
|
hardware.opengl.driSupport = true;
|
|||
|
hardware.opengl.driSupport32Bit = true;
|
|||
|
hardware.opengl.extraPackages = with pkgs; [
|
|||
|
libva
|
|||
|
rocmPackages.clr.icd
|
|||
|
];
|
|||
|
|
|||
|
# Enable the X11 windowing system.
|
|||
|
services.xserver.enable = true;
|
|||
|
services.xserver.layout = "no";
|
|||
|
# services.xserver.xkbOptions = "eurosign:e";
|
|||
|
|
|||
|
services.xserver.displayManager.lightdm.enable = true;
|
|||
|
services.xserver.videoDrivers = ["amdgpu"];
|
|||
|
|
|||
|
|
|||
|
|
|||
|
programs.zsh.enable = true;
|
|||
|
|
|||
|
virtualisation.docker.enable = true;
|
|||
|
virtualisation.libvirtd.enable = true;
|
|||
|
|
|||
|
|
|||
|
# networking.nameservers = lib.mkForce [ "192.168.0.25" ];
|
|||
|
|
|||
|
|
|||
|
|
|||
|
# services.ipfs.enable = true;
|
|||
|
# services.ipfs.gatewayAddress = "/ip4/127.0.0.1/tcp/5002";
|
|||
|
|
|||
|
nix.trustedUsers = [ "dan" ];
|
|||
|
nix.extraOptions = ''
|
|||
|
experimental-features = nix-command flakes
|
|||
|
'';
|
|||
|
|
|||
|
users.users.dan = {
|
|||
|
isNormalUser = true;
|
|||
|
uid = 1001;
|
|||
|
shell = pkgs.zsh;
|
|||
|
extraGroups = [ "wheel" "networkmanager" "docker" "video" "gnunet" "libvirtd" ];
|
|||
|
initialPassword = "Abc123";
|
|||
|
};
|
|||
|
|
|||
|
programs.dconf.enable = true;
|
|||
|
services.dbus.packages = with pkgs; [ dconf ];
|
|||
|
|
|||
|
# This value determines the NixOS release with which your system is to be
|
|||
|
# compatible, in order to avoid breaking some software such as database
|
|||
|
# servers. You should change this only after NixOS release notes say you
|
|||
|
# should.
|
|||
|
system.stateVersion = "19.03"; # Did you read the comment?
|
|||
|
|
|||
|
}
|
|||
|
|