diff --git a/configuration.nix b/configuration.nix deleted file mode 100644 index 008016b..0000000 --- a/configuration.nix +++ /dev/null @@ -1,118 +0,0 @@ -# Edit this configuration file to define what should be installed on -# your system. Help is available in the configuration.nix(5) man page, on -# https://search.nixos.org/options and in the NixOS manual (`nixos-help`). - -{ config, lib, pkgs, ... }: - -{ - imports = - [ # Include the results of the hardware scan. - ./hardware-configuration.nix - ]; - - # Use the extlinux boot loader. (NixOS wants to enable GRUB by default) - boot.loader.grub.enable = false; - # Enables the generation of /boot/extlinux/extlinux.conf - boot.loader.generic-extlinux-compatible.enable = true; - - # networking.hostName = "nixos"; # Define your hostname. - # Pick only one of the below networking options. - # networking.wireless.enable = true; # Enables wireless support via wpa_supplicant. - # networking.networkmanager.enable = true; # Easiest to use and most distros use this by default. - - # Set your time zone. - # time.timeZone = "Europe/Amsterdam"; - - # Configure network proxy if necessary - # networking.proxy.default = "http://user:password@proxy:port/"; - # networking.proxy.noProxy = "127.0.0.1,localhost,internal.domain"; - - # Select internationalisation properties. - # i18n.defaultLocale = "en_US.UTF-8"; - # console = { - # font = "Lat2-Terminus16"; - # keyMap = "us"; - # useXkbConfig = true; # use xkb.options in tty. - # }; - - # Enable the X11 windowing system. - # services.xserver.enable = true; - - - - - # Configure keymap in X11 - # services.xserver.xkb.layout = "us"; - # services.xserver.xkb.options = "eurosign:e,caps:escape"; - - # Enable CUPS to print documents. - # services.printing.enable = true; - - # Enable sound. - # sound.enable = true; - # hardware.pulseaudio.enable = true; - - # Enable touchpad support (enabled default in most desktopManager). - # services.xserver.libinput.enable = true; - - # Define a user account. Don't forget to set a password with ‘passwd’. - # users.users.alice = { - # isNormalUser = true; - # extraGroups = [ "wheel" ]; # Enable ‘sudo’ for the user. - # packages = with pkgs; [ - # firefox - # tree - # ]; - # }; - - # List packages installed in system profile. To search, run: - # $ nix search wget - # environment.systemPackages = with pkgs; [ - # vim # Do not forget to add an editor to edit configuration.nix! The Nano editor is also installed by default. - # wget - # ]; - - # 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 = false; - - # Copy the NixOS configuration file and link it from the resulting system - # (/run/current-system/configuration.nix). This is useful in case you - # accidentally delete configuration.nix. - # system.copySystemConfiguration = true; - - # This option defines the first version of NixOS you have installed on this particular machine, - # and is used to maintain compatibility with application data (e.g. databases) created on older NixOS versions. - # - # Most users should NEVER change this value after the initial install, for any reason, - # even if you've upgraded your system to a new NixOS release. - # - # This value does NOT affect the Nixpkgs version your packages and OS are pulled from, - # so changing it will NOT upgrade your system. - # - # This value being lower than the current NixOS release does NOT mean your system is - # out of date, out of support, or vulnerable. - # - # Do NOT change this value unless you have manually inspected all the changes it would make to your configuration, - # and migrated your data accordingly. - # - # For more information, see `man configuration.nix` or https://nixos.org/manual/nixos/stable/options#opt-system.stateVersion . - system.stateVersion = "23.11"; # Did you read the comment? - -} - diff --git a/default.nix b/default.nix index 061d727..3c75ae2 100644 --- a/default.nix +++ b/default.nix @@ -50,7 +50,59 @@ system.stateVersion = "23.11"; # Did you read the comment? + fileSystems."/mnt/Public" = { + device = "//192.168.1.109/Public"; + fsType = "cifs"; + # options = ["uid=0,gid=1000"]; + options = ["guest" "uid=1000"]; + }; + +systemd.services.setleds = { + script = '' + echo "Setting Odroid LEDs" + echo none > /sys/class/leds/blue\:heartbeat/trigger + cat /sys/class/leds/blue\:heartbeat/trigger + ''; + wantedBy = [ "multi-user.target" ]; +}; +virtualisation.docker.enable = true; +services.nomad = { + package = pkgs.nomad_1_6; + dropPrivileges = false; + enableDocker = true; + enable = true; + settings = { +client = { + enabled = true; + node_class = ""; + no_host_uuid = false; + servers = ["192.168.1.221:4647" "192.168.1.225:4647" "192.168.1.226:4647" "192.168.1.227:4647" "192.168.1.222:4647" "192.168.1.223:4647" "192.168.1.224:4647"]; + max_kill_timeout = "30s"; + network_speed = 0; + cpu_total_compute = 0; + gc_interval = "1m"; + gc_disk_usage_threshold = 80; + gc_inode_usage_threshold = 70; + gc_parallel_destroys = 2; + reserved = { + cpu = 0; + memory = 200; + disk = 0; + }; + options = { + "docker.caps.whitelist" = "SYS_ADMIN,NET_ADMIN,chown,dac_override,fsetid,fowner,mknod,net_raw,setgid,setuid,setfcap,setpcap,net_bind_service,sys_chroot,kill,audit_write,sys_module"; + "driver.raw_exec.enable" = "1"; + "docker.volumes.enabled" = "True"; + "docker.privileged.enabled" = "true"; + "docker.auth.config" = "/root/.docker/config.json"; + }; + }; +}; + + + +}; services.openssh = { enable = true; settings.PermitRootLogin = "yes"; diff --git a/treefmt.toml b/treefmt.toml deleted file mode 100644 index 0cc49b1..0000000 --- a/treefmt.toml +++ /dev/null @@ -1,11 +0,0 @@ -# One CLI to format the code tree - https://github.com/numtide/treefmt - -[formatter.mylanguage] -# Formatter to run -command = "command-to-run" -# Command-line arguments for the command -options = [] -# Glob pattern of files to include -includes = [ "*." ] -# Glob patterns of files to exclude -excludes = []