feat: NixOS | set user initial password and format file

This commit is contained in:
2025-02-06 17:02:41 +05:00
parent 506df9a405
commit ba286b9033

View File

@@ -1,13 +1,16 @@
# Edit this configuration file to define what should be installed on # Edit this configuration file to define what should be installed on
# your system. Help is available in the configuration.nix(5) man page # your system. Help is available in the configuration.nix(5) man page
# and in the NixOS manual (accessible by running nixos-help). # and in the NixOS manual (accessible by running nixos-help).
{ config, lib, inputs, pkgs, hostname, ... }:
let
secretspath = builtins.toString inputs.nix-secrets;
in
{ {
config,
lib,
inputs,
pkgs,
hostname,
...
}: let
secretspath = builtins.toString inputs.nix-secrets;
in {
# Bootloader. # Bootloader.
boot = { boot = {
loader = { loader = {
@@ -54,7 +57,7 @@ in
nix.settings = { nix.settings = {
substituters = ["https://hyprland.cachix.org"]; substituters = ["https://hyprland.cachix.org"];
trusted-public-keys = ["hyprland.cachix.org-1:a7pgxzMz7+chwVL3/pzj6jIBMioiJM7ypFP8PwtkuGc="]; trusted-public-keys = ["hyprland.cachix.org-1:a7pgxzMz7+chwVL3/pzj6jIBMioiJM7ypFP8PwtkuGc="];
experimental-features = [ "nix-command" "flakes" ]; experimental-features = ["nix-command" "flakes"];
}; };
# Enable greetd and tuigreet # Enable greetd and tuigreet
@@ -105,7 +108,7 @@ in
graphics = { graphics = {
enable = true; enable = true;
extraPackages = with pkgs; [ amdvlk ]; extraPackages = with pkgs; [amdvlk];
}; };
}; };
@@ -125,7 +128,8 @@ in
isNormalUser = true; isNormalUser = true;
description = "Shahab Dogar"; description = "Shahab Dogar";
extraGroups = [ "networkmanager" "wheel" "input" "libvirtd" ]; extraGroups = ["networkmanager" "wheel" "input" "libvirtd"];
initialHashedPassword = "$y$j9T$jSC0CJxh6O.Q3TEOVZR8l.$7kFf9u4Lh.aIH6o/15wFLW7OKPzoUEpWVN5B9wHEaw4";
hashedPasswordFile = config.sops.secrets."user_passwords/shahab".path; hashedPasswordFile = config.sops.secrets."user_passwords/shahab".path;
}; };
@@ -183,7 +187,7 @@ in
enable = true; enable = true;
# Certain features, including CLI integration and system authentication support, # Certain features, including CLI integration and system authentication support,
# require enabling PolKit integration on some desktop environments (e.g. Plasma). # require enabling PolKit integration on some desktop environments (e.g. Plasma).
polkitPolicyOwners = [ "shahab" ]; polkitPolicyOwners = ["shahab"];
}; };
programs.dconf.enable = true; programs.dconf.enable = true;
@@ -224,7 +228,7 @@ in
ovmf = { ovmf = {
enable = true; enable = true;
packages = with pkgs; [ OVMFFull.fd ]; packages = with pkgs; [OVMFFull.fd];
}; };
}; };
}; };