123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124 |
- { config, pkgs, ... }:
- {
- imports =
- [
- ./hardware-configuration.nix
- ];
-
- boot.loader.timeout = 1;
- boot.loader.systemd-boot.enable = true;
-
- networking.hostName = "{% if 'bootstrap' not in group_names %}{{ inventory_hostname }}{% else %}nixos-kodi{% endif %}";
-
- time.timeZone = "America/Los_Angeles";
-
- networking.interfaces.{{ ansible_default_ipv4.interface }}.useDHCP = true;
- networking.enableIPv6 = false;
- networking.firewall.allowedTCPPorts = [
- 8080
- 5377
- ];
- networking.firewall.allowedUDPPorts = [
- 8080
- 5377
- ];
-
- services.xserver.enable = true;
- services.xserver.desktopManager.kodi.enable = true;
- services.xserver.desktopManager.kodi.package = pkgs.kodi.withPackages (p: with p; [ kodi pvr-hts ]);
- services.xserver.displayManager.autoLogin.enable = true;
- services.xserver.displayManager.autoLogin.user = "kodi";
- services.xserver.displayManager.job.preStart = "/run/current-system/sw/bin/systemctl start network-online.target";
- users.users.kodi.isNormalUser = true;
-
- services.logind.extraConfig = "HandlePowerKey=ignore";
- services.xserver.displayManager.sessionCommands = ''
- xset dpms 0 0 0
- xset s off -dpms
- '';
-
-
- sound.enable = true;
- hardware.pulseaudio.enable = true;
- boot.kernelPackages = pkgs.linuxPackages_latest;
-
- environment.systemPackages = with pkgs; [
- python3
- vim
- nano
- htop
- glances
- nethogs
- tmux
- inxi
- ];
-
- services.openssh.enable = true;
- users.users.root.openssh.authorizedKeys.keys = [
- {% for pubkey in ssh_root_keys %}
- "{{ pubkey }}"
- {% endfor %}
- ];
-
- nix.gc.automatic = true;
- nix.gc.dates = "monthly";
- system.autoUpgrade.enable = true;
- system.autoUpgrade.allowReboot = true;
- system.autoUpgrade.dates = "weekly";
- services.samba-wsdd.enable = true;
- services.samba = {
- enable = true;
- openFirewall = true;
- securityType = "user";
- extraConfig = ''
- workgroup = WORKGROUP
- server string = smb{{ inventory_hostname }}
- netbios name = smb{{ inventory_hostname }}
- security = user
- guest account = kodi
- map to guest = bad user
- '';
- shares = {
- kodi = {
- path = "/home/kodi";
- browseable = "yes";
- "read only" = "no";
- "guest ok" = "yes";
- "force user" = "kodi";
- "force group" = "users";
- "create mask" = "0644";
- "directory mask" = "0755";
- };
- };
- };
-
-
-
-
-
-
- system.stateVersion = "21.11";
- }
|