From c4219c5b62d67f00ae4d1ba00aa57eb7855dc231 Mon Sep 17 00:00:00 2001 From: aleidk Date: Sat, 8 Jul 2023 11:26:12 -0400 Subject: [PATCH] add basic config for nixos --- .gitignore | 1 + nixos/configuration.nix | 174 ++++++++++++++++++++++++++++++++++++++++ setup.sh | 8 +- setup/hyprland | 4 - 4 files changed, 180 insertions(+), 7 deletions(-) create mode 100644 nixos/configuration.nix delete mode 100644 setup/hyprland diff --git a/.gitignore b/.gitignore index 959ddb5..0cb4115 100644 --- a/.gitignore +++ b/.gitignore @@ -9,3 +9,4 @@ config/mpv/shaders # locks **/*-lock.json config/spicetify/Backup +nixos/hardware-configuration.nix diff --git a/nixos/configuration.nix b/nixos/configuration.nix new file mode 100644 index 0000000..0dfe14c --- /dev/null +++ b/nixos/configuration.nix @@ -0,0 +1,174 @@ +# 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, pkgs, ... }: + +{ + imports = + [ # Include the results of the hardware scan. + ./hardware-configuration.nix + ]; + + # Bootloader. + boot.loader.systemd-boot.enable = true; + boot.loader.efi.canTouchEfiVariables = true; + + networking.hostName = "nixos"; # Define your hostname. + # networking.wireless.enable = true; # Enables wireless support via wpa_supplicant. + + # Configure network proxy if necessary + # networking.proxy.default = "http://user:password@proxy:port/"; + # networking.proxy.noProxy = "127.0.0.1,localhost,internal.domain"; + + # Enable networking + networking.networkmanager.enable = true; + + # Set your time zone. + time.timeZone = "America/Santiago"; + + # Select internationalisation properties. + i18n.defaultLocale = "en_US.UTF-8"; + + i18n.extraLocaleSettings = { + LC_ADDRESS = "es_CL.UTF-8"; + LC_IDENTIFICATION = "es_CL.UTF-8"; + LC_MEASUREMENT = "es_CL.UTF-8"; + LC_MONETARY = "es_CL.UTF-8"; + LC_NAME = "es_CL.UTF-8"; + LC_NUMERIC = "es_CL.UTF-8"; + LC_PAPER = "es_CL.UTF-8"; + LC_TELEPHONE = "es_CL.UTF-8"; + LC_TIME = "es_CL.UTF-8"; + }; + + # Enable the X11 windowing system. + services.xserver.enable = true; + + # Enable the GNOME Desktop Environment. + services.xserver.displayManager.gdm.enable = true; + services.xserver.desktopManager.gnome.enable = true; + + # Configure keymap in X11 + services.xserver = { + layout = "latam"; + xkbVariant = ""; + }; + + # Configure console keymap + console.keyMap = "la-latin1"; + + # Enable CUPS to print documents. + services.printing.enable = true; + + # Enable sound with pipewire. + sound.enable = true; + hardware.pulseaudio.enable = false; + security.rtkit.enable = true; + services.pipewire = { + enable = true; + alsa.enable = true; + alsa.support32Bit = true; + pulse.enable = true; + # If you want to use JACK applications, uncomment this + #jack.enable = true; + + # use the example session manager (no others are packaged yet so this is enabled by default, + # no need to redefine it in your config for now) + #media-session.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.aleidk = { + isNormalUser = true; + description = "aleidk"; + extraGroups = [ "networkmanager" "wheel" ]; + packages = with pkgs; [ + firefox + # thunderbird + ]; + }; + + # Allow unfree packages + nixpkgs.config.allowUnfree = true; + + # List packages installed in system profile. To search, run: + # $ nix search wget + environment.systemPackages = with pkgs; [ + alacritty + bat + cargo + duf + exa + fd + flatpak + fzf + jq + gcc + git + gnome.gnome-software + gnome.gnome-tweaks + gnomeExtensions.hibernate-status-button + hyprland + hyprpaper + lazygit + luajitPackages.luarocks + neovim + nerdfonts + nodejs + ripgrep + rustc + sd + starship + tealdeer + tmux + tree-sitter + wget + zellij + zsh + ]; + + # 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; + + # This value determines the NixOS release from which the default + # settings for stateful data, like file locations and database versions + # on your system were taken. It‘s perfectly fine and recommended to leave + # this value at the release version of the first install of this system. + # Before changing this value read the documentation for this option + # (e.g. man configuration.nix or on https://nixos.org/nixos/options.html). + system.stateVersion = "23.05"; # Did you read the comment? + services.flatpak.enable = true; + +nix.gc = { + automatic = true; + dates = "weekly"; + options = "--delete-older-than 7d"; + }; +system.autoUpgrade.enable = true; + + +programs.zsh.enable = true; + +users.defaultUserShell = pkgs.zsh; +environment.shells = with pkgs; [ zsh ]; +} diff --git a/setup.sh b/setup.sh index 5dc3a0d..846b036 100755 --- a/setup.sh +++ b/setup.sh @@ -83,11 +83,13 @@ setup() { main() { setup source "$DOTS/config/zsh/config/colors.zsh" && define_colors + source "$DOTS/setup/config" + source "$DOTS/setup/zsh" - for file in ./setup/*; do + # for file in ./setup/*; do # shellcheck disable=all - source "$file" - done + # source "$file" +# done } check_dependencies diff --git a/setup/hyprland b/setup/hyprland deleted file mode 100644 index 0ec745e..0000000 --- a/setup/hyprland +++ /dev/null @@ -1,4 +0,0 @@ -#!/usr/bin/env bash - -# dependency to install SWWW -sudo dnf install libxkbcommon-devel.x86_64