Compare commits

...

22 Commits

Author SHA1 Message Date
c0f9f1d622 update: nix flake inputs 2025-06-20 22:12:02 +02:00
c1e22f2e7b update: nixos 25.05 2025-06-08 17:01:12 +02:00
bcdd79d400 update: nix flake 2025-06-08 15:06:34 +02:00
5de2d44c01 chore: install IntelliJ Community edition for transcaffeine 2025-03-06 20:02:08 +01:00
d13363f709 chore(home-manager): temporarely disable gpg config file generation 2025-03-04 20:35:38 +01:00
6d1a757145 fix: ignore NetworkManager-wait-online.service 2025-03-04 20:21:47 +01:00
b874613227 feat(affogato): use upstream nixos-hardware model, enable power-profiles-daemon, add repo-local pkgs overlay 2025-03-04 20:21:04 +01:00
fef153c9d8 chore: add libidevicemobile, enable usbmuxd service 2025-01-24 21:11:17 +01:00
e4a1565c78 chore(affogato): open firewall for orcaslicer 2024-12-19 21:13:53 +01:00
be811d1025 chore(profiles/graphical): add orca-slicer from nixpkgs 2024-12-17 12:59:04 +01:00
71f58b12bd feat(home-manager/firefox): configure default profile 2024-12-03 22:00:10 +01:00
a0d0477fa2 chore(home-manager/gpg-agent): template agent configuration from upstream dotfiles 2024-12-03 20:39:25 +01:00
bd46837713 chore: build utility functions 2024-12-03 20:20:09 +01:00
e5aef16a97 feat(home-manager): manage gpg.conf with configuration from upstream dotfile repository 2024-12-02 22:45:50 +01:00
20cc8bee1b feat(home-manager): manage git config from upstream dotfiles repository 2024-12-02 20:44:26 +01:00
e85351d49e chore: allow impure evaluation inputs 2024-12-02 20:34:11 +01:00
f01482a7da feat: set EDITOR = VISUAL = vim 2024-11-27 20:41:37 +01:00
8ba96a860a chore: update flake.lock 2024-11-27 20:39:27 +01:00
278a4e0e24 chore: set some hardware options 2024-11-27 20:36:15 +01:00
3ced5bb138 fix: correct shell alias 2024-11-27 20:35:22 +01:00
b4d7447612 chore: use home-manager for transcaffeine 2024-11-27 20:34:08 +01:00
f9b964d69a feat: add home-manager 2024-11-27 20:33:16 +01:00
15 changed files with 260 additions and 21 deletions

66
flake.lock generated
View File

@ -1,24 +1,76 @@
{
"nodes": {
"nixpkgs": {
"home-manager": {
"inputs": {
"nixpkgs": "nixpkgs"
},
"locked": {
"lastModified": 1731755305,
"narHash": "sha256-v5P3dk5JdiT+4x69ZaB18B8+Rcu3TIOrcdG4uEX7WZ8=",
"lastModified": 1749154018,
"narHash": "sha256-gjN3j7joRvT3a8Zgcylnd4NFsnXeDBumqiu4HmY1RIg=",
"owner": "nix-community",
"repo": "home-manager",
"rev": "7aae0ee71a17b19708b93b3ed448a1a0952bf111",
"type": "github"
},
"original": {
"owner": "nix-community",
"ref": "release-25.05",
"repo": "home-manager",
"type": "github"
}
},
"nixos-hardware": {
"locked": {
"lastModified": 1750431636,
"narHash": "sha256-vnzzBDbCGvInmfn2ijC4HsIY/3W1CWbwS/YQoFgdgPg=",
"owner": "NixOS",
"repo": "nixpkgs",
"rev": "057f63b6dc1a2c67301286152eb5af20747a9cb4",
"repo": "nixos-hardware",
"rev": "1552a9f4513f3f0ceedcf90320e48d3d47165712",
"type": "github"
},
"original": {
"owner": "NixOS",
"ref": "nixos-24.11",
"repo": "nixos-hardware",
"type": "github"
}
},
"nixpkgs": {
"locked": {
"lastModified": 1749024892,
"narHash": "sha256-OGcDEz60TXQC+gVz5sdtgGJdKVYr6rwdzQKuZAJQpCA=",
"owner": "NixOS",
"repo": "nixpkgs",
"rev": "8f1b52b04f2cb6e5ead50bd28d76528a2f0380ef",
"type": "github"
},
"original": {
"owner": "NixOS",
"ref": "nixos-25.05",
"repo": "nixpkgs",
"type": "github"
}
},
"nixpkgs_2": {
"locked": {
"lastModified": 1750259320,
"narHash": "sha256-H8J4H2XCIMEJ5g6fZ179QfQvsc2dUqhqfBjC8RAHNRY=",
"owner": "NixOS",
"repo": "nixpkgs",
"rev": "9ba04bda9249d5d5e5238303c9755de5a49a79c5",
"type": "github"
},
"original": {
"owner": "NixOS",
"ref": "nixos-25.05",
"repo": "nixpkgs",
"type": "github"
}
},
"root": {
"inputs": {
"nixpkgs": "nixpkgs"
"home-manager": "home-manager",
"nixos-hardware": "nixos-hardware",
"nixpkgs": "nixpkgs_2"
}
}
},

View File

@ -1,9 +1,11 @@
{
inputs = {
nixpkgs.url = "github:NixOS/nixpkgs/nixos-24.11";
nixpkgs.url = "github:NixOS/nixpkgs/nixos-25.05";
home-manager.url = "github:nix-community/home-manager/release-25.05";
nixos-hardware.url = "github:NixOS/nixos-hardware";
};
outputs = inputs @ { self, nixpkgs }: {
outputs = inputs @ { self, nixpkgs, ... }: {
nixosConfigurations.affogato = nixpkgs.lib.nixosSystem {
system = "x86_64-linux";
modules = [

View File

@ -1,10 +1,12 @@
{ pkgs, ... }: {
{ inputs, pkgs, ... }: {
imports = [
inputs.nixos-hardware.nixosModules.chuwi-minibook-x
./hardware-configuration.nix
./n100.nix
../../profiles/base
../../profiles/graphical
../../profiles/kde
../../profiles/home-manager
../../users/transcaffeine
../../users/leona
];
@ -13,10 +15,8 @@
boot.loader.systemd-boot.enable = true;
boot.loader.efi.canTouchEfiVariables = true;
boot.kernelPackages = pkgs.linuxPackages_latest;
#boot.kernelPackages = pkgs.linuxPackages_6_6;
boot.kernelPackages = pkgs.linuxPackages_6_13;
boot.kernelParams = [
"fbcon=rotate:1"
# disable panel self refresh for i915
#"i915.enable_psr=0"
# set max cstate to 2 (suspend?)
@ -30,21 +30,30 @@
"78.94.116.221" = [
"git.finally.coffee"
"chat.finallycoffee.eu"
"matrix.finallycoffee.eu"
"cloud.finallycoffee.eu"
];
};
networking.firewall = {
enable = true;
allowedTCPPorts = [ 8883 ];
allowedUDPPorts = [ 2021 ];
};
# Set your time zone.
time.timeZone = "Europe/Berlin";
# Network
networking.networkmanager.enable = true;
networking.networkmanager.unmanaged = [ "p2p-dev-wlp0s20f3" ];
systemd.services.ModemManager.enable = true;
systemd.services.NetworkManager-wait-online.enable = false;
services.printing.enable = true;
services.avahi.enable = true;
services.tailscale.enable = true;
services.blueman.enable = true;
services.power-profiles-daemon.enable = true;
# TODO: delete this later
system.stateVersion = "23.05"; # Did you read the comment?

View File

@ -36,7 +36,6 @@
networking.useDHCP = lib.mkDefault true;
# networking.interfaces.enp0s20f0u1u3.useDHCP = lib.mkDefault true;
powerManagement.cpuFreqGovernor = lib.mkDefault "powersave";
hardware.cpu.intel.updateMicrocode = lib.mkDefault config.hardware.enableRedistributableFirmware;
hardware.bluetooth.enable = true;

5
pkgs/default.nix Normal file
View File

@ -0,0 +1,5 @@
final: prev: {
cpupower = prev.cpupower.overrideAttrs (oldAttrs: {
nativeBuildInputs = oldAttrs.nativeBuildInputs ++ [ prev.which ];
});
}

View File

@ -1,4 +1,7 @@
{ inputs, pkgs, ...}: {
nixpkgs.overlays = [
(import ../../pkgs)
];
nixpkgs.config.allowUnfree = true;
nix.settings.trusted-users = [ "root" "@wheel" ];
nix.registry.nixpkgs.flake = inputs.nixpkgs;
@ -20,10 +23,13 @@
};
};
environment.shellAliases = {
"nixos-switch" = "nixos-rebuild switch --flake .#";
"nom-affogato" = "nom build .#nixosConfigurations.affogato.config.system.build.toplevel";
"nixos-switch" = "sudo nixos-rebuild switch --impure --flake .#";
"nom-affogato" = "nom build .#nixosConfigurations.affogato.config.system.build.toplevel --impure";
};
environment.variables = {
EDITOR = "vim";
VISUAL = "vim";
};
environment.systemPackages = with pkgs; [
python3
vim

View File

@ -6,10 +6,13 @@
pulse.enable = true;
};
services.usbmuxd.enable = true;
environment.systemPackages = with pkgs; [
firefox
thunderbird
vlc
orca-slicer
usbutils
pciutils
pinentry-qt
@ -18,8 +21,9 @@
usb-modeswitch-data
modemmanager
xdg-desktop-portal
xdg-desktop-portal-kde
kdePackages.xdg-desktop-portal-kde
grim
wireguard-tools
libimobiledevice
];
}

View File

@ -0,0 +1,5 @@
{ inputs, config, pkgs, ... }: {
imports = [ inputs.home-manager.nixosModules.home-manager ];
home-manager.useGlobalPkgs = true;
home-manager.useUserPackages = true;
}

View File

@ -2,10 +2,10 @@
# Plasma
services.xserver.enable = true;
services.displayManager.sddm.enable = true;
services.xserver.desktopManager.plasma5.enable = true;
services.desktopManager.plasma6.enable = true;
environment.systemPackages = with pkgs; [
xdg-desktop-portal
xdg-desktop-portal-kde
kdePackages.xdg-desktop-portal-kde
];
}

View File

@ -20,6 +20,8 @@
wget
nix-output-monitor
nix-diff
jetbrains.idea-community
];
};
home-manager.users.transcaffeine = import ./home-manager/default.nix;
}

View File

@ -0,0 +1,19 @@
{ lib, pkgs, ... }: {
imports = [
./git.nix
./gnupg.nix
];
home.stateVersion = "24.11";
services.darkman = {
enable = true;
settings = {
lat = 49.0800;
lng = 8.23300;
portal = true;
dbusserver = true;
};
};
home.preferXdgDirectories = true;
programs.firefox = import ./firefox.nix { inherit lib; };
}

View File

@ -0,0 +1,32 @@
{ lib, ... }:
{
profiles.default = {
id = 42;
isDefault = true;
name = "default";
containers = {
personal = {
id = 1;
color = "blue";
icon = "fingerprint";
name = "transcaffeine.me";
};
finallycoffee = {
id = 2;
color = "purple";
icon = "fingerprint";
name = "finally.coffee";
};
};
extensions = [
"uBlock0@raymondhill.net"
"uMatrix@raymondhill.net"
"{c607c8df-14a7-4f28-894f-29e8722976af}"
"default-theme@mozilla.org"
"addon@darkreader.org"
"@testpilot-containers"
"protoots@trans.rights"
];
};
}

View File

@ -0,0 +1,31 @@
{ lib, ... }: {
programs.git = let
gitconfig = builtins.fromTOML (
lib.readFile
((builtins.fetchGit {
url = "https://git.finally.coffee/transcaffeine/dotfiles.git";
ref = "main";
rev = "3811febee134e62d3539c472005f04710d913611";
shallow = false;
}).outPath + "/config/git/gitconfig")
);
key = gitconfig.user.signingKey;
aliases = gitconfig.alias;
in {
enable = true;
userName = gitconfig.user.name;
userEmail = gitconfig.user.email;
signing = {
signByDefault = true;
inherit key;
};
inherit aliases;
extraConfig = {
format = gitconfig.format;
commit = gitconfig.commit;
tag = gitconfig.tag;
pull = gitconfig.pull;
rebase = gitconfig.rebase;
};
};
}

View File

@ -0,0 +1,59 @@
{ lib, config, ... }:
let
repo = (builtins.fetchGit {
url = "https://git.finally.coffee/transcaffeine/dotfiles.git";
ref = "main";
shallow = true;
});
utils = import ../../../utils { inherit lib; };
in {
programs.gpg = let
gpgconf = builtins.listToAttrs (
map (entry: {
name = toString (lib.sublist 0 1 (lib.splitString " " entry));
value = toString (lib.sublist 1 100 (lib.splitString " " entry));
}) (
builtins.filter (value: value != "") (
lib.splitString "\n" (
lib.readFile (repo.outPath + "/config/gnupg/gpg.conf")
)
)
)
);
in {
enable = true;
settings = gpgconf;
};
services.gpg-agent = let
gpg_agent_config = builtins.listToAttrs (
map (entry: let
val = toString (lib.sublist 1 100 (lib.splitString " " entry));
emptyStringToTrue = (x: if lib.isBool x then x else if x == "" then true else x);
in {
name = toString (lib.sublist 0 1 (lib.splitString " " entry));
value = emptyStringToTrue val;
}) (
builtins.filter (v: v != "") (
lib.splitString "\n" (
lib.readFile (repo.outPath + "/config/gnupg/gpg-agent.conf")
)
)
)
);
in {
enable = true;
enableSshSupport = gpg_agent_config."enable-ssh-support";
defaultCacheTtl = gpg_agent_config."default-cache-ttl" or 300;
maxCacheTtl = gpg_agent_config."max-cache-ttl" or 900;
defaultCacheTtlSsh = gpg_agent_config."default-cache-ttl-ssh" or 300;
maxCacheTtlSsh = gpg_agent_config."max-cache-ttl-ssh" or 900;
extraConfig = utils.attrsToConfig {
"ignore-cache-for-signing" = gpg_agent_config."ignore-cache-for-signing";
"no-allow-external-cache" = gpg_agent_config."no-allow-external-cache";
};
};
home.file."${config.programs.gpg.homedir}/gpg.conf".enable = false;
home.file."${config.programs.gpg.homedir}/gpg-agent.conf".enable = false;
}

14
utils/default.nix Normal file
View File

@ -0,0 +1,14 @@
{ lib, ...}:
rec {
_tupleToEntry = x: x.name + (if lib.isBool x.value then "" else (" " + x.value));
attrsToConfig = attrs: (
lib.concatStringsSep "\n" (
map (_tupleToEntry) (
builtins.filter (e: e.value != false) (
lib.attrsToList attrs
)
)
)
);
}