nixos-config/machines/calcite/configuration.nix

274 lines
5.9 KiB
Nix
Raw Normal View History

{ config, pkgs, ... }:
2023-03-29 13:14:37 +00:00
{
imports =
[
# Include the results of the hardware scan.
./hardware-configuration.nix
./network.nix
2023-04-19 06:16:39 +00:00
../sops.nix
../clash.nix
2023-03-29 13:14:37 +00:00
];
# Bootloader.
boot.loader.systemd-boot.enable = true;
boot.loader.efi.canTouchEfiVariables = true;
boot.loader.efi.efiSysMountPoint = "/boot/efi";
# boot.kernelPackages = pkgs.linuxPackages_latest;
boot.kernelModules = [ "nvidia" "nvidia_modeset" "nvidia_uvm" ];
boot.supportedFilesystems = [ "ntfs" ];
2023-03-29 13:14:37 +00:00
networking.hostName = "calcite";
2023-03-29 13:14:37 +00:00
programs.vim.defaultEditor = true;
2023-03-29 13:14:37 +00:00
# Keep this even if enabled in home manager
programs.fish.enable = true;
environment.shells = [ pkgs.fish ];
users.defaultUserShell = pkgs.fish;
2023-04-19 06:16:39 +00:00
2023-03-29 13:14:37 +00:00
# Setup wireguard
# Set your time zone.
time.timeZone = "Asia/Shanghai";
# Select internationalisation properties.
i18n.defaultLocale = "en_US.utf8";
i18n.extraLocaleSettings = {
LC_ADDRESS = "zh_CN.utf8";
LC_IDENTIFICATION = "zh_CN.utf8";
LC_MEASUREMENT = "zh_CN.utf8";
LC_MONETARY = "zh_CN.utf8";
LC_NAME = "zh_CN.utf8";
LC_NUMERIC = "zh_CN.utf8";
LC_PAPER = "zh_CN.utf8";
LC_TELEPHONE = "zh_CN.utf8";
LC_TIME = "en_US.utf8";
};
2023-05-27 01:39:16 +00:00
i18n.inputMethod = {
enabled = "fcitx5";
fcitx5.addons = with pkgs; [ fcitx5-rime ];
};
2023-03-29 13:14:37 +00:00
# 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;
2023-05-27 01:39:16 +00:00
services.xserver.windowManager.icewm.enable = true;
2023-03-29 13:14:37 +00:00
# Configure keymap in X11
services.xserver = {
layout = "us";
xkbVariant = "";
};
# Enable CUPS to print documents.
services.printing.enable = true;
services.printing.drivers = [ pkgs.hplip ];
# Enable sound with pipewire.
sound.enable = true;
hardware.pulseaudio.enable = false;
security.rtkit.enable = true;
services.pipewire = {
enable = true;
wireplumber.enable = true;
alsa.enable = true;
#alsa.support32Bit = true;
pulse.enable = true;
# If you want to use JACK applications, uncomment this
jack.enable = true;
};
# Define a user account. Don't forget to set a password with passwd.
users.users.xin = {
isNormalUser = true;
description = "xin";
extraGroups = [ "networkmanager" "wheel" "wireshark" ];
};
# Enable automatic login for the user.
services.xserver.displayManager.autoLogin.enable = true;
services.xserver.displayManager.autoLogin.user = "xin";
2023-05-27 01:39:16 +00:00
# Smart services
services.smartd.enable = true;
2023-03-29 13:14:37 +00:00
# Workaround for GNOME autologin: https://github.com/NixOS/nixpkgs/issues/103746#issuecomment-945091229
systemd.services."getty@tty1".enable = false;
systemd.services."autovt@tty1".enable = false;
# Allow unfree packages
nixpkgs.config.allowUnfree = true;
nixpkgs.config.permittedInsecurePackages = [
"openssl-1.1.1w"
# For wechat-uos
"electron-19.1.9"
];
2023-03-29 13:14:37 +00:00
# List packages installed in system profile. To search, run:
# $ nix search wget
environment.systemPackages = with pkgs; [
# Filesystem
nfs-utils
winetricks
wineWowPackages.waylandFull
faudio
# ==== CLI tools ==== #
rust-analyzer
2023-03-29 13:14:37 +00:00
# tesseract5 # ocr
ocrmypdf # pdfocr
2023-03-29 13:14:37 +00:00
grc
2023-05-27 01:39:16 +00:00
sops
2023-04-03 07:33:15 +00:00
git-crypt
2023-04-03 09:41:33 +00:00
2023-05-27 01:39:16 +00:00
# ==== Development ==== #
2023-03-29 13:14:37 +00:00
# Language server
clang-tools
rnix-lsp
# C/C++
gcc
gdb
# Python
# reference: https://nixos.wiki/wiki/Python
(
let
my-python-packages = python-packages: with python-packages; [
pandas
requests
numpy
pyyaml
];
python-with-my-packages = python3.withPackages my-python-packages;
in
python-with-my-packages
)
# Tex
texlive.combined.scheme-full
# ==== GUI Softwares ==== #
2023-07-21 17:20:55 +00:00
# IDE
jetbrains.jdk # patch jetbrain runtime java
jetbrains.clion
jetbrains.pycharm-professional
jetbrains.idea-ultimate
android-studio
2023-03-29 13:14:37 +00:00
# Gnome tweaks
gnomeExtensions.dash-to-dock
gnomeExtensions.hide-top-bar
gnomeExtensions.tray-icons-reloaded
gnome.gnome-tweaks
gthumb
# Multimedia
vlc
obs-studio
spotify
digikam
# IM
tdesktop
qq
config.nur.repos.xddxdd.wechat-uos
2023-03-29 13:14:37 +00:00
# Password manager
keepassxc
# Browser
firefox
chromium
microsoft-edge
# Writting
obsidian
zotero
wpsoffice
2023-05-27 01:39:16 +00:00
onlyoffice-bin
2023-03-29 13:14:37 +00:00
config.nur.repos.linyinfeng.wemeet
virt-manager
2023-05-27 01:39:16 +00:00
ghidra
2023-03-29 13:14:37 +00:00
];
system.stateVersion = "22.05";
2023-03-29 13:14:37 +00:00
# Use mirror for binary cache
nix.settings.substituters = [
"https://mirrors.ustc.edu.cn/nix-channels/store"
"https://mirrors.tuna.tsinghua.edu.cn/nix-channels/store"
2023-03-29 13:14:37 +00:00
];
2023-07-21 17:20:55 +00:00
nix.gc = {
automatic = true;
dates = "weekly";
options = "--delete-older-than 30d";
};
2023-07-22 14:56:46 +00:00
nix.settings.trusted-users = [ "xin" "root" ];
nix.extraOptions = ''
!include "${config.sops.secrets.github_public_token.path}"
'';
sops = {
secrets.github_public_token = {
owner = "xin";
};
};
2023-03-29 13:14:37 +00:00
# MTP support
services.gvfs.enable = true;
# Fonts
fonts = {
packages = with pkgs; [
(nerdfonts.override { fonts = [ "FiraCode" ]; })
2023-03-29 13:14:37 +00:00
noto-fonts
noto-fonts-emoji
liberation_ttf
mplus-outline-fonts.githubRelease
dina-font
proggyfonts
ubuntu_font_family
# Chinese
wqy_microhei
wqy_zenhei
noto-fonts-cjk-sans
noto-fonts-cjk-serif
source-han-sans
source-han-serif
];
fontconfig = {
defaultFonts = {
serif = [ "Noto Serif CJK SC" "Ubuntu" ];
sansSerif = [ "Noto Sans CJK SC" "Ubuntu" ];
monospace = [ "FiraCode NerdFont Mono" "Ubuntu" ];
2023-03-29 13:14:37 +00:00
};
};
};
# Virtualization
virtualisation = {
libvirtd.enable = true;
podman = {
enable = true;
enableNvidia = true;
};
2023-04-16 02:30:45 +00:00
docker = {
enable = true;
autoPrune.enable = true;
};
2023-03-29 13:14:37 +00:00
};
}