Compare commits

..

1 commit

Author SHA1 Message Date
81269c0f75
Services 2024-12-12 16:23:35 -07:00
82 changed files with 475 additions and 1591 deletions

1
.gitignore vendored
View file

@ -1,2 +1 @@
secrets.nix secrets.nix
result

View file

@ -1,5 +0,0 @@
{
"cSpell.words": [
"pkgs"
]
}

411
flake.lock generated
View file

@ -16,42 +16,20 @@
"type": "github" "type": "github"
} }
}, },
"colmena": {
"inputs": {
"flake-compat": "flake-compat",
"flake-utils": "flake-utils",
"nix-github-actions": "nix-github-actions",
"nixpkgs": "nixpkgs",
"stable": "stable"
},
"locked": {
"lastModified": 1734897875,
"narHash": "sha256-LLpiqfOGBippRax9F33kSJ/Imt8gJXb6o0JwSBiNHCk=",
"owner": "zhaofengli",
"repo": "colmena",
"rev": "a6b51f5feae9bfb145daa37fd0220595acb7871e",
"type": "github"
},
"original": {
"owner": "zhaofengli",
"repo": "colmena",
"type": "github"
}
},
"firefox-addons": { "firefox-addons": {
"inputs": { "inputs": {
"flake-utils": "flake-utils_2", "flake-utils": "flake-utils",
"nixpkgs": [ "nixpkgs": [
"nixpkgs" "nixpkgs"
] ]
}, },
"locked": { "locked": {
"dir": "/pkgs/firefox-addons", "dir": "/pkgs/firefox-addons",
"lastModified": 1735979945, "lastModified": 1733875367,
"narHash": "sha256-qT25PnbcQ30ypnI8fNazRDsq3WmBXC8Lo+OvPr+Ct+o=", "narHash": "sha256-eBMHOM1KvbK8dTrM4N8ytNl8NeJF4lLyoPBRae1CqKs=",
"owner": "rycee", "owner": "rycee",
"repo": "nur-expressions", "repo": "nur-expressions",
"rev": "b93d8cdf12139da45146a6c3cf53141a437c41ec", "rev": "bda0131e0a7b6b5b687f5ffd8a8622054e7c444d",
"type": "gitlab" "type": "gitlab"
}, },
"original": { "original": {
@ -64,7 +42,7 @@
"firefox-nightly": { "firefox-nightly": {
"inputs": { "inputs": {
"cachix": "cachix", "cachix": "cachix",
"flake-compat": "flake-compat_2", "flake-compat": "flake-compat",
"lib-aggregate": "lib-aggregate", "lib-aggregate": "lib-aggregate",
"mozilla": "mozilla", "mozilla": "mozilla",
"nixpkgs": [ "nixpkgs": [
@ -72,11 +50,11 @@
] ]
}, },
"locked": { "locked": {
"lastModified": 1735993795, "lastModified": 1733834155,
"narHash": "sha256-1jwzAW9/oRWbE6IeInTaemSAxda5fQJhSbkDcwvKMBU=", "narHash": "sha256-5A7EfzSmdApKmfHGtGZ4NQvMEpI/NI6VIzTNq9sUH4E=",
"owner": "nix-community", "owner": "nix-community",
"repo": "flake-firefox-nightly", "repo": "flake-firefox-nightly",
"rev": "0c4828eee2c87f9bde77d6e37fed30fd77e9d959", "rev": "f0ab3cfa3607e08169b1d87e63fe9b1e5a57f515",
"type": "github" "type": "github"
}, },
"original": { "original": {
@ -86,22 +64,6 @@
} }
}, },
"flake-compat": { "flake-compat": {
"flake": false,
"locked": {
"lastModified": 1650374568,
"narHash": "sha256-Z+s0J8/r907g149rllvwhb4pKi8Wam5ij0st8PwAh+E=",
"owner": "edolstra",
"repo": "flake-compat",
"rev": "b4a34015c698c7793d592d66adbab377907a2be8",
"type": "github"
},
"original": {
"owner": "edolstra",
"repo": "flake-compat",
"type": "github"
}
},
"flake-compat_2": {
"locked": { "locked": {
"lastModified": 1717312683, "lastModified": 1717312683,
"narHash": "sha256-FrlieJH50AuvagamEvWMIE6D2OAnERuDboFDYAED/dE=", "narHash": "sha256-FrlieJH50AuvagamEvWMIE6D2OAnERuDboFDYAED/dE=",
@ -116,7 +78,7 @@
"type": "github" "type": "github"
} }
}, },
"flake-compat_3": { "flake-compat_2": {
"flake": false, "flake": false,
"locked": { "locked": {
"lastModified": 1696426674, "lastModified": 1696426674,
@ -133,21 +95,6 @@
} }
}, },
"flake-utils": { "flake-utils": {
"locked": {
"lastModified": 1659877975,
"narHash": "sha256-zllb8aq3YO3h8B/U0/J1WBgAL8EX5yWf5pMj3G0NAmc=",
"owner": "numtide",
"repo": "flake-utils",
"rev": "c0e246b9b83f637f4681389ecabcb2681b4f3af0",
"type": "github"
},
"original": {
"owner": "numtide",
"repo": "flake-utils",
"type": "github"
}
},
"flake-utils_2": {
"locked": { "locked": {
"lastModified": 1629284811, "lastModified": 1629284811,
"narHash": "sha256-JHgasjPR0/J1J3DRm4KxM4zTyAj4IOJY8vIl75v/kPI=", "narHash": "sha256-JHgasjPR0/J1J3DRm4KxM4zTyAj4IOJY8vIl75v/kPI=",
@ -162,7 +109,7 @@
"type": "github" "type": "github"
} }
}, },
"flake-utils_3": { "flake-utils_2": {
"inputs": { "inputs": {
"systems": "systems" "systems": "systems"
}, },
@ -180,9 +127,9 @@
"type": "github" "type": "github"
} }
}, },
"flake-utils_4": { "flake-utils_3": {
"inputs": { "inputs": {
"systems": "systems_3" "systems": "systems_2"
}, },
"locked": { "locked": {
"lastModified": 1710146030, "lastModified": 1710146030,
@ -198,9 +145,9 @@
"type": "github" "type": "github"
} }
}, },
"flake-utils_5": { "flake-utils_4": {
"inputs": { "inputs": {
"systems": "systems_4" "systems": "systems_3"
}, },
"locked": { "locked": {
"lastModified": 1681202837, "lastModified": 1681202837,
@ -216,30 +163,6 @@
"type": "github" "type": "github"
} }
}, },
"flatpaks": {
"inputs": {
"home-manager": [
"home-manager"
],
"nixpkgs": [
"nixpkgs"
],
"systems": "systems_2"
},
"locked": {
"lastModified": 1733581530,
"narHash": "sha256-W+orHmF+XpZosrBFAFRs7sS1iVKYveg9SutkzSXMVsI=",
"owner": "GermanBread",
"repo": "declarative-flatpak",
"rev": "b88bd5b65f8e7c35eec0a90cfd6e096b2e7f79c0",
"type": "github"
},
"original": {
"owner": "GermanBread",
"repo": "declarative-flatpak",
"type": "github"
}
},
"home-manager": { "home-manager": {
"inputs": { "inputs": {
"nixpkgs": [ "nixpkgs": [
@ -247,11 +170,11 @@
] ]
}, },
"locked": { "locked": {
"lastModified": 1736013363, "lastModified": 1733873195,
"narHash": "sha256-P4lsS2Y5GzBfC8OfXtD/xWEucX6oHGTjOzjEjEJbXfc=", "narHash": "sha256-dTosiZ3sZ/NKoLKQ++v8nZdEHya0eTNEsaizNp+MUPM=",
"owner": "nix-community", "owner": "nix-community",
"repo": "home-manager", "repo": "home-manager",
"rev": "0d7908bd09165db6699908b7e3970f137327cbf0", "rev": "f26aa4b76fb7606127032d33ac73d7d507d82758",
"type": "github" "type": "github"
}, },
"original": { "original": {
@ -263,15 +186,15 @@
}, },
"lib-aggregate": { "lib-aggregate": {
"inputs": { "inputs": {
"flake-utils": "flake-utils_3", "flake-utils": "flake-utils_2",
"nixpkgs-lib": "nixpkgs-lib" "nixpkgs-lib": "nixpkgs-lib"
}, },
"locked": { "locked": {
"lastModified": 1735474663, "lastModified": 1733660018,
"narHash": "sha256-EFuucE6VnP/OFlMZV/sDxaEiz1z2Amfj91zQSQXbUUk=", "narHash": "sha256-DHW2Hzyo8W6wVPGFaYLM9mKMH/qAtHJSUZ4ti7LHMCY=",
"owner": "nix-community", "owner": "nix-community",
"repo": "lib-aggregate", "repo": "lib-aggregate",
"rev": "c9ad2f4cedf71f3a2e9a614b0c4a60ecd798a855", "rev": "f710791be27b31ea1ee9c40a94d08bcbba99b3c0",
"type": "github" "type": "github"
}, },
"original": { "original": {
@ -296,53 +219,6 @@
"type": "github" "type": "github"
} }
}, },
"nix-formatter-pack": {
"inputs": {
"nixpkgs": [
"nix-on-droid",
"nixpkgs"
],
"nmd": [
"nix-on-droid",
"nmd"
],
"nmt": "nmt"
},
"locked": {
"lastModified": 1705252799,
"narHash": "sha256-HgSTREh7VoXjGgNDwKQUYcYo13rPkltW7IitHrTPA5c=",
"owner": "Gerschtli",
"repo": "nix-formatter-pack",
"rev": "2de39dedd79aab14c01b9e2934842051a160ffa5",
"type": "github"
},
"original": {
"owner": "Gerschtli",
"repo": "nix-formatter-pack",
"type": "github"
}
},
"nix-github-actions": {
"inputs": {
"nixpkgs": [
"colmena",
"nixpkgs"
]
},
"locked": {
"lastModified": 1729742964,
"narHash": "sha256-B4mzTcQ0FZHdpeWcpDYPERtyjJd/NIuaQ9+BV1h+MpA=",
"owner": "nix-community",
"repo": "nix-github-actions",
"rev": "e04df33f62cdcf93d73e9a04142464753a16db67",
"type": "github"
},
"original": {
"owner": "nix-community",
"repo": "nix-github-actions",
"type": "github"
}
},
"nix-index-database": { "nix-index-database": {
"inputs": { "inputs": {
"nixpkgs": [ "nixpkgs": [
@ -350,11 +226,11 @@
] ]
}, },
"locked": { "locked": {
"lastModified": 1735443188, "lastModified": 1733629314,
"narHash": "sha256-AydPpRBh8+NOkrLylG7vTsHrGO2b5L7XkMEL5HlzcA8=", "narHash": "sha256-U0vivjQFAwjNDYt49Krevs1murX9hKBFe2Ye0cHpgbU=",
"owner": "nix-community", "owner": "nix-community",
"repo": "nix-index-database", "repo": "nix-index-database",
"rev": "55ab1e1df5daf2476e6b826b69a82862dcbd7544", "rev": "f1e477a7dd11e27e7f98b646349cd66bbabf2fb8",
"type": "github" "type": "github"
}, },
"original": { "original": {
@ -363,33 +239,6 @@
"type": "github" "type": "github"
} }
}, },
"nix-on-droid": {
"inputs": {
"home-manager": [
"home-manager"
],
"nix-formatter-pack": "nix-formatter-pack",
"nixpkgs": [
"nixpkgs"
],
"nixpkgs-docs": "nixpkgs-docs",
"nixpkgs-for-bootstrap": "nixpkgs-for-bootstrap",
"nmd": "nmd"
},
"locked": {
"lastModified": 1725658585,
"narHash": "sha256-P29z4Gt89n5ps1U7+qmIrj0BuRXGZQSIaOe2+tsPgfw=",
"owner": "nix-community",
"repo": "nix-on-droid",
"rev": "5d88ff2519e4952f8d22472b52c531bb5f1635fc",
"type": "github"
},
"original": {
"owner": "nix-community",
"repo": "nix-on-droid",
"type": "github"
}
},
"nixos-grub-themes": { "nixos-grub-themes": {
"inputs": { "inputs": {
"nixpkgs": [ "nixpkgs": [
@ -412,11 +261,11 @@
}, },
"nixpkgs": { "nixpkgs": {
"locked": { "locked": {
"lastModified": 1734119587, "lastModified": 1733759999,
"narHash": "sha256-AKU6qqskl0yf2+JdRdD0cfxX4b9x3KKV5RqA6wijmPM=", "narHash": "sha256-463SNPWmz46iLzJKRzO3Q2b0Aurff3U1n0nYItxq7jU=",
"owner": "NixOS", "owner": "NixOS",
"repo": "nixpkgs", "repo": "nixpkgs",
"rev": "3566ab7246670a43abd2ffa913cc62dad9cdf7d5", "rev": "a73246e2eef4c6ed172979932bc80e1404ba2d56",
"type": "github" "type": "github"
}, },
"original": { "original": {
@ -426,60 +275,13 @@
"type": "github" "type": "github"
} }
}, },
"nixpkgs-docs": { "nixpkgs-24-11": {
"locked": { "locked": {
"lastModified": 1705957679, "lastModified": 1733550349,
"narHash": "sha256-Q8LJaVZGJ9wo33wBafvZSzapYsjOaNjP/pOnSiKVGHY=", "narHash": "sha256-NcGumB4Lr6KSDq+nIqXtNA8QwAQKDSZT7N9OTGWbTrs=",
"owner": "NixOS", "owner": "NixOS",
"repo": "nixpkgs", "repo": "nixpkgs",
"rev": "9a333eaa80901efe01df07eade2c16d183761fa3", "rev": "e2605d0744c2417b09f8bf850dfca42fcf537d34",
"type": "github"
},
"original": {
"owner": "NixOS",
"ref": "release-23.05",
"repo": "nixpkgs",
"type": "github"
}
},
"nixpkgs-for-bootstrap": {
"locked": {
"lastModified": 1720244366,
"narHash": "sha256-WrDV0FPMVd2Sq9hkR5LNHudS3OSMmUrs90JUTN+MXpA=",
"owner": "NixOS",
"repo": "nixpkgs",
"rev": "49ee0e94463abada1de470c9c07bfc12b36dcf40",
"type": "github"
},
"original": {
"owner": "NixOS",
"repo": "nixpkgs",
"rev": "49ee0e94463abada1de470c9c07bfc12b36dcf40",
"type": "github"
}
},
"nixpkgs-lib": {
"locked": {
"lastModified": 1735434288,
"narHash": "sha256-zg9W8r2xBLoWW47mFYzodngQmalqV7abjXncBcwAQZ8=",
"owner": "nix-community",
"repo": "nixpkgs.lib",
"rev": "97ed8d4ba97b1d4858bdc39cdabfdebc623de82b",
"type": "github"
},
"original": {
"owner": "nix-community",
"repo": "nixpkgs.lib",
"type": "github"
}
},
"nixpkgs-stable": {
"locked": {
"lastModified": 1735922141,
"narHash": "sha256-vk0xwGZSlvZ/596yxOtsk4gxsIx2VemzdjiU8zhjgWw=",
"owner": "NixOS",
"repo": "nixpkgs",
"rev": "d29ab98cd4a70a387b8ceea3e930b3340d41ac5a",
"type": "github" "type": "github"
}, },
"original": { "original": {
@ -489,58 +291,33 @@
"type": "github" "type": "github"
} }
}, },
"nixpkgs-lib": {
"locked": {
"lastModified": 1733620091,
"narHash": "sha256-5WoMeCkaXqTZwwCNLRzyLxEJn8ISwjx4cNqLgqKwg9s=",
"owner": "nix-community",
"repo": "nixpkgs.lib",
"rev": "f4dc9a6c02e5e14d91d158522f69f6ab4194eb5b",
"type": "github"
},
"original": {
"owner": "nix-community",
"repo": "nixpkgs.lib",
"type": "github"
}
},
"nixpkgs_2": { "nixpkgs_2": {
"locked": { "locked": {
"lastModified": 1735834308, "lastModified": 1682134069,
"narHash": "sha256-dklw3AXr3OGO4/XT1Tu3Xz9n/we8GctZZ75ZWVqAVhk=", "narHash": "sha256-TnI/ZXSmRxQDt2sjRYK/8j8iha4B4zP2cnQCZZ3vp7k=",
"owner": "NixOS", "owner": "NixOS",
"repo": "nixpkgs", "repo": "nixpkgs",
"rev": "6df24922a1400241dae323af55f30e4318a6ca65", "rev": "fd901ef4bf93499374c5af385b2943f5801c0833",
"type": "github" "type": "github"
}, },
"original": { "original": {
"owner": "NixOS", "id": "nixpkgs",
"ref": "nixos-unstable", "type": "indirect"
"repo": "nixpkgs",
"type": "github"
}
},
"nmd": {
"inputs": {
"nixpkgs": [
"nix-on-droid",
"nixpkgs-docs"
],
"scss-reset": "scss-reset"
},
"locked": {
"lastModified": 1705050560,
"narHash": "sha256-x3zzcdvhJpodsmdjqB4t5mkVW22V3wqHLOun0KRBzUI=",
"owner": "~rycee",
"repo": "nmd",
"rev": "66d9334933119c36f91a78d565c152a4fdc8d3d3",
"type": "sourcehut"
},
"original": {
"owner": "~rycee",
"repo": "nmd",
"type": "sourcehut"
}
},
"nmt": {
"flake": false,
"locked": {
"lastModified": 1648075362,
"narHash": "sha256-u36WgzoA84dMVsGXzml4wZ5ckGgfnvS0ryzo/3zn/Pc=",
"owner": "rycee",
"repo": "nmt",
"rev": "d83601002c99b78c89ea80e5e6ba21addcfe12ae",
"type": "gitlab"
},
"original": {
"owner": "rycee",
"repo": "nmt",
"type": "gitlab"
} }
}, },
"plasma-manager": { "plasma-manager": {
@ -553,11 +330,11 @@
] ]
}, },
"locked": { "locked": {
"lastModified": 1735049224, "lastModified": 1733858086,
"narHash": "sha256-fWUd9kyXdepphJ7cCzOsuSo7l0kbFCkUqfgKqZyFZzE=", "narHash": "sha256-h2BDIDKiqgMpA6E+mu0RgMGy3FeM6k+EuJ9xgOQ1+zw=",
"owner": "nix-community", "owner": "nix-community",
"repo": "plasma-manager", "repo": "plasma-manager",
"rev": "d16bbded0ae452bc088489e7dca3ef58d8d1830b", "rev": "7e2010249529931a3848054d5ff0dbf24675ab68",
"type": "github" "type": "github"
}, },
"original": { "original": {
@ -568,38 +345,19 @@
}, },
"root": { "root": {
"inputs": { "inputs": {
"colmena": "colmena",
"firefox-addons": "firefox-addons", "firefox-addons": "firefox-addons",
"firefox-nightly": "firefox-nightly", "firefox-nightly": "firefox-nightly",
"flatpaks": "flatpaks",
"home-manager": "home-manager", "home-manager": "home-manager",
"nix-index-database": "nix-index-database", "nix-index-database": "nix-index-database",
"nix-on-droid": "nix-on-droid",
"nixos-grub-themes": "nixos-grub-themes", "nixos-grub-themes": "nixos-grub-themes",
"nixpkgs": "nixpkgs_2", "nixpkgs": "nixpkgs",
"nixpkgs-stable": "nixpkgs-stable", "nixpkgs-24-11": "nixpkgs-24-11",
"plasma-manager": "plasma-manager", "plasma-manager": "plasma-manager",
"sddm-sugar-candy-nix": "sddm-sugar-candy-nix", "sddm-sugar-candy-nix": "sddm-sugar-candy-nix",
"vscode-extensions": "vscode-extensions", "vscode-extensions": "vscode-extensions",
"vscode-server": "vscode-server" "vscode-server": "vscode-server"
} }
}, },
"scss-reset": {
"flake": false,
"locked": {
"lastModified": 1631450058,
"narHash": "sha256-muDlZJPtXDIGevSEWkicPP0HQ6VtucbkMNygpGlBEUM=",
"owner": "andreymatin",
"repo": "scss-reset",
"rev": "0cf50e27a4e95e9bb5b1715eedf9c54dee1a5a91",
"type": "github"
},
"original": {
"owner": "andreymatin",
"repo": "scss-reset",
"type": "github"
}
},
"sddm-sugar-candy-nix": { "sddm-sugar-candy-nix": {
"inputs": { "inputs": {
"nixpkgs": [ "nixpkgs": [
@ -620,22 +378,6 @@
"type": "github" "type": "github"
} }
}, },
"stable": {
"locked": {
"lastModified": 1730883749,
"narHash": "sha256-mwrFF0vElHJP8X3pFCByJR365Q2463ATp2qGIrDUdlE=",
"owner": "NixOS",
"repo": "nixpkgs",
"rev": "dba414932936fde69f0606b4f1d87c5bc0003ede",
"type": "github"
},
"original": {
"owner": "NixOS",
"ref": "nixos-24.05",
"repo": "nixpkgs",
"type": "github"
}
},
"systems": { "systems": {
"locked": { "locked": {
"lastModified": 1681028828, "lastModified": 1681028828,
@ -653,16 +395,16 @@
}, },
"systems_2": { "systems_2": {
"locked": { "locked": {
"lastModified": 1689347949, "lastModified": 1681028828,
"narHash": "sha256-12tWmuL2zgBgZkdoB6qXZsgJEH9LR3oUgpaQq2RbI80=", "narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=",
"owner": "nix-systems", "owner": "nix-systems",
"repo": "default-linux", "repo": "default",
"rev": "31732fcf5e8fea42e59c2488ad31a0e651500f68", "rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e",
"type": "github" "type": "github"
}, },
"original": { "original": {
"owner": "nix-systems", "owner": "nix-systems",
"repo": "default-linux", "repo": "default",
"type": "github" "type": "github"
} }
}, },
@ -681,35 +423,20 @@
"type": "github" "type": "github"
} }
}, },
"systems_4": {
"locked": {
"lastModified": 1681028828,
"narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=",
"owner": "nix-systems",
"repo": "default",
"rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e",
"type": "github"
},
"original": {
"owner": "nix-systems",
"repo": "default",
"type": "github"
}
},
"vscode-extensions": { "vscode-extensions": {
"inputs": { "inputs": {
"flake-compat": "flake-compat_3", "flake-compat": "flake-compat_2",
"flake-utils": "flake-utils_4", "flake-utils": "flake-utils_3",
"nixpkgs": [ "nixpkgs": [
"nixpkgs" "nixpkgs"
] ]
}, },
"locked": { "locked": {
"lastModified": 1735955120, "lastModified": 1733795858,
"narHash": "sha256-gmIt30sWS5U44ySODi3Q/89IV6ylt5P0eKayg0pXQTA=", "narHash": "sha256-K595Q2PrZv2iiumdBkwM2G456T2lKsLD71bn/fbJiQ0=",
"owner": "nix-community", "owner": "nix-community",
"repo": "nix-vscode-extensions", "repo": "nix-vscode-extensions",
"rev": "06a3dcdfa6e6c39695203c281cf6d2c800bd7649", "rev": "66ced222ef9235f90dbdd754ede3d6476722aaa9",
"type": "github" "type": "github"
}, },
"original": { "original": {
@ -720,10 +447,8 @@
}, },
"vscode-server": { "vscode-server": {
"inputs": { "inputs": {
"flake-utils": "flake-utils_5", "flake-utils": "flake-utils_4",
"nixpkgs": [ "nixpkgs": "nixpkgs_2"
"nixpkgs"
]
}, },
"locked": { "locked": {
"lastModified": 1729422940, "lastModified": 1729422940,

118
flake.nix
View file

@ -2,14 +2,9 @@
description = "NixOS Configuration"; description = "NixOS Configuration";
inputs = { inputs = {
# Nixpkgs # General NixOS config
nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable"; nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";
nixpkgs-stable.url = "github:NixOS/nixpkgs/nixos-24.11"; # Used when unstable hydra fails nixpkgs-24-11.url = "github:NixOS/nixpkgs/nixos-24.11";
# Colmena unstable
colmena = {
url = "github:zhaofengli/colmena";
# inputs.nixpkgs.follows = "nixpkgs";
};
# Nixpkgs index for command-not-found support # Nixpkgs index for command-not-found support
nix-index-database = { nix-index-database = {
url = "github:nix-community/nix-index-database"; url = "github:nix-community/nix-index-database";
@ -54,67 +49,76 @@
inputs.nixpkgs.follows = "nixpkgs"; inputs.nixpkgs.follows = "nixpkgs";
}; };
# VSCode server support # VSCode server support
vscode-server = { vscode-server.url = "github:nix-community/nixos-vscode-server";
url = "github:nix-community/nixos-vscode-server";
inputs.nixpkgs.follows = "nixpkgs";
};
# Flatpak support
flatpaks = {
url = "github:GermanBread/declarative-flatpak";
inputs.nixpkgs.follows = "nixpkgs";
inputs.home-manager.follows = "home-manager";
};
# Nix-on-droid support
nix-on-droid = {
url = "github:nix-community/nix-on-droid";
inputs = {
nixpkgs.follows = "nixpkgs";
home-manager.follows = "home-manager";
};
};
}; };
outputs = inputs@{ self, nixpkgs, home-manager, colmena, nix-on-droid, ... }: let outputs = inputs@{ nixpkgs, home-manager, plasma-manager, nix-index-database, vscode-server, ... }: let
utils = import ./utils { system = "x86_64-linux";
inherit inputs; pkgs = nixpkgs.legacyPackages.${system};
secrets = import ./secrets.nix; secrets = import ./secrets.nix;
};
in { in {
# Setup home-manager configurations nixosConfigurations.ty-nixos = nixpkgs.lib.nixosSystem {
# Mines Isengard inherit system;
homeConfigurations.tyler_beckman = utils.createHomeManagerConfig {
meta = {
preset = "cli";
username = "tyler_beckman";
};
};
# Setup NixOS configurations modules = [
nixosConfigurations = { ./hosts/laptop
"ty-nixos" = utils.createNixosSystem { entrypoint = ./hosts/laptop; };
"ty-laptop-server" = utils.createNixosSystem { entrypoint = ./hosts/laptop-server; };
};
# Setup colmena configurations # Better command-not-found
colmena = utils.createColmenaHive { nix-index-database.nixosModules.nix-index
hostConfigs = [ { programs.nix-index-database.comma.enable = true; }
# Home manager
home-manager.nixosModules.home-manager
./home-manager
{ {
name = "ty-nixos"; ty-home-manager-options = {
entrypoint = ./hosts/laptop; plasma.enable = true;
allowLocal = true; beets.enable = true;
} firefox.enable = true;
{ thunderbird.enable = true;
name = "ty-laptop-server"; rescrobbled.enable = true;
entrypoint = ./hosts/laptop-server; vscode.enable = true;
sshHost = "old-lenovo-laptop"; };
} }
]; ];
specialArgs = {
inherit inputs system secrets;
};
}; };
# Setup nix-on-droid configurations nixosConfigurations."ty-laptop-server" = nixpkgs.lib.nixosSystem {
nixOnDroidConfigurations.default = utils.createDroidSystem { entrypoint = ./nix-on-droid/ty-pixel; }; inherit system;
# Enable direct flake support for colmena modules = [
colmenaHive = colmena.lib.makeHive self.outputs.colmena; ./hosts/laptop-server
# Better command-not-found
nix-index-database.nixosModules.nix-index
{ programs.nix-index-database.comma.enable = true; }
# Home manager
home-manager.nixosModules.home-manager
./home-manager
{
ty-home-manager-options = {
plasma.enable = false;
beets.enable = false;
firefox.enable = false;
thunderbird.enable = false;
rescrobbled.enable = false;
vscode.enable = false;
};
}
# VSCode server support
vscode-server.nixosModules.default
({ pkgs, ... }: { services.vscode-server = { enable = true; nodejsPackage = pkgs.nodejs-18_x; installPath = "$HOME/.vscodium-server"; }; })
];
specialArgs = {
inherit inputs system secrets;
};
};
}; };
} }

View file

@ -1,22 +0,0 @@
{ ... }:
{
imports = [
# Directories
./accounts
./shell
./vcs
# Individual files
./beets.nix
./desktop.nix
./firefox.nix
./gpg.nix
./gtk.nix
./packages.nix
./plasma.nix
./prismlauncher.nix
./rescrobbled.nix
./thunderbird.nix
./vscode.nix
./zed.nix
];
}

View file

@ -1,106 +0,0 @@
{ pkgs, pkgs-stable, inputs, system, lib, config, ... }:
{
home.packages =
## Packages that are always installed, no matter what
(with pkgs; [
# :3
fastfetch # Modern & faster neofetch alternative
# CLI Tools
ripgrep # Text searching and manipulation
jq # JSON filtering
eza # Directory lister
bat # File reading
doggo # DNS Requests
nmap # Network scanning
glow # Markdown rendering
usbutils # `lsusb`
pciutils # `lspci`
unzip # Extract zip files
xh # HTTPie-like rust cli tool
rar
bitwarden-cli
# Editor
neovim # CLI-Based editor
# Process tools
btop # Process monitor
hyperfine # CLI Benchmarker
])
## Packages that are only installed when a desktop environment is desired
++ (lib.optionals config.meta.home-manager.desktop.enable (with pkgs; [
# Documents
logseq # Outliner
libreoffice-qt6-fresh # Office-style editing
hunspell
hunspellDicts.en_US-large
pkgs-stable.orca-slicer # 3d-printing
(pkgs.calibre.overrideAttrs (old: {
postInstall = ''
wrapProgram $out/bin/calibre \
--set-default ACSM_LIBCRYPTO ${pkgs.openssl.out}/lib/libcrypto.so \
--set-default ACSM_LIBSSL ${pkgs.openssl.out}/lib/libssl.so
'';
})) # E-book reading (with overridden openssl libs for acsm-calibre-plugin support)
# Video
jellyfin-media-player # Jellyfin electron client w/ MPV
vlc # Video file player
# Chat
element-desktop # Matrix client
vesktop # Discord client
signal-desktop # Signal client
# KDE Themes
vimix-cursors # Cursors
(pkgs.callPackage ../../packages/beautyline {}) # Icons
(pkgs.callPackage ../../packages/magna-splash-6 {}) # Splash
# Programming
jetbrains.idea-ultimate # Jetbrains IntelliJ Idea Ultimate IDE
jetbrains.rust-rover # Jetbrains Rust IDE
nixd # LSP for .nix files
gcc # GNU C++ Compiler
(lib.meta.hiPrio clang) # LLVM C++ Compiler (better than g++)
clang-tools # Clang language server
cling # C++ REPL
deno # Typescript & Javascript runtime
gnumake # Makefile support
httptoolkit # HTTP Interception
android-tools # ADB and the such
beekeeper-studio # SQL Database viewer
# Games
(heroic.override {
extraPkgs = pkgs: [
pkgs.gamemode
pkgs.gamescope
];
# Workaround electron 31 build failure on unstable
heroic-unwrapped = (pkgs.heroic-unwrapped.override {
electron = pkgs-stable.electron_31;
});
}) # GOG & Epic Games Launcher
# UI Tools
qalculate-qt # Calculator
# Process tools cont.
nvtopPackages.full # GPU Monitor, only really necessary if we have a GPU to look at
]))
## Packages that are only installed if plasma is used as the desktop environment
++ (lib.optionals config.meta.home-manager.desktop.plasma.enable (with pkgs.kdePackages; [
kate # IDE
elisa # Music
kdeconnect-kde # Phone sync
polkit-kde-agent-1 # Polkit authentication popup support
]))
## Firefox is only installed when requested
++ (lib.optionals config.meta.home-manager.firefox.enable [
# Firefox nightly
inputs.firefox-nightly.packages.${system}.firefox-nightly-bin
]);
}

View file

@ -1,6 +0,0 @@
{ config, lib, ... }:
{
programs.custom.prism-launcher = lib.mkIf config.meta.home-manager.desktop.enable {
enable = true;
};
}

View file

@ -1,23 +0,0 @@
{ secrets, lib, config, ... }:
{
config = lib.mkIf config.meta.home-manager.rescrobbled.enable {
services.custom.rescrobbled = let s = secrets.programs.rescrobbled; in lib.mkIf s.enable {
enable = true;
session = s.lastfm.session;
settings = {
player-whitelist = [ "elisa" ];
listenbrainz = lib.mkIf (s.listenbrainz.token != null) [
{
token = s.listenbrainz.token;
}
];
lastfm-key = lib.mkIf (s.lastfm.key != null && s.lastfm.secret != null) s.lastfm.key;
lastfm-secret = lib.mkIf (s.lastfm.key != null && s.lastfm.secret != null) s.lastfm.secret;
};
};
};
}

View file

@ -1,18 +0,0 @@
{ ... }:
{
programs.tealdeer = {
enable = true;
settings = {
display = {
use_pager = false;
compact = false;
};
updates = {
auto_update = true;
auto_update_interval_hours = 24;
};
};
};
}

View file

@ -1,85 +0,0 @@
{ lib, config, pkgs, ... }:
{
programs.zed-editor = lib.mkIf config.meta.home-manager.vscode.enable {
enable = true;
extensions = [
# Language support
"nix" "toml" "deno" "kotlin" "java"
# Themes
"catppuccin"
];
userSettings = {
auto_update = false;
base_keymap = "VSCode";
load_direnv = "shell_hook";
show_whitespaces = "boundary";
tab_size = 4;
theme = "Catppuccin Mocha";
buffer_font_family = "FiraCode Nerd Font";
format_on_save = "off";
soft_wrap = "none";
terminal = {
dock = "bottom";
font_family = "FiraCode Nerd Font";
font_size = 14;
line_height = "standard"; # Comfortable breaks my powerline
working_directory = "current_project_directory";
env.TERM = "xterm-256color";
};
lsp = {
rust-analyzer = {
binary = {
path = lib.getExe pkgs.rust-analyzer;
};
};
nix = {
binary = {
path = lib.getExe pkgs.nixd;
};
};
vtsls = {
binary = {
path = lib.getExe pkgs.vtsls;
arguments = [ "--stdio" ];
};
};
kotlin-language-server = {
binary = {
path = lib.getExe' pkgs.kotlin-language-server "kotlin-language-server";
};
};
jdtls = {
binary = {
path = lib.getExe pkgs.jdt-language-server;
};
};
};
languages = {
Nix = {
language_servers = [ "nixd" "!nil" ];
};
};
# Disable the bullshit
assistant = {
enabled = false;
button = false;
version = "1";
};
features.inline_completion_provider = "none";
telemetry = {
diagnostics = false;
metrics = false;
};
};
};
}

View file

@ -1,7 +1,6 @@
{ ... }: { ... }:
{ {
imports = [ imports = [
./prismlauncher.nix
./rescrobbled.nix ./rescrobbled.nix
]; ];
} }

View file

@ -0,0 +1,85 @@
{ pkgs, lib, config, ... }:
let tomlFormat = pkgs.formats.toml { }; in {
options = {
services.custom.rescrobbled = {
enable = lib.mkEnableOption "rescrobbled";
package = lib.mkOption {
type = lib.types.package;
default = (pkgs.callPackage ../../packages/rescrobbled {});
defaultText = lib.literalExpression "pkgs.rescrobbled";
description = "The package to use for rescrobbled";
};
session = lib.mkOption {
type = lib.types.str;
description = ''
The session token to use for last.fm.
This can be found by setting a last.fm API key & secret,
and then manually running the daemon. Then, the session token
will be located at {file}`$XDG_CONFIG_HOME/rescrobbled/session`.
'';
default = null;
};
settings = lib.mkOption {
type = tomlFormat.type;
default = {};
example = lib.literalExpression ''
lastfm-key = "Last.fm API key"
lastfm-secret = "Last.fm API secret"
min-play-time = 0
player-whitelist = [ "Player MPRIS identity or bus name" ]
filter-script = "path/to/script"
[[listenbrainz]]
url = "Custom API URL"
token = "User token"
'';
description = ''
Configuration written to
{file}`$XDG_CONFIG_HOME/rescrobbled/config.toml`.
See <https://github.com/InputUsername/rescrobbled#configuration> for the full list
of options.
'';
};
};
};
config = let cfg = config.services.custom.rescrobbled; in lib.mkIf cfg.enable {
home.packages = [ cfg.package ];
xdg.configFile ={
"rescrobbled/config.toml" = lib.mkIf (cfg.settings != { }) {
enable = true;
source = tomlFormat.generate "rescrobbled-config" cfg.settings;
};
"rescrobbled/session" = lib.mkIf (cfg.settings != { }) {
enable = true;
# Force makes it easy to generate the session file, then add it to nix cfg without issues
force = true;
text = cfg.session;
};
};
systemd.user.services.rescrobbled = {
Unit = {
Description = "An MPRIS scrobbler";
Documentation = "https://github.com/InputUsername/rescrobbled";
Wants = "network-online.target";
After = "network-online.target";
};
Service = {
ExecStartPre = "${pkgs.coreutils}/bin/sleep 15"; # Avoid listenbrainz errors by adding delay till network is connected
ExecStart = "${cfg.package}/bin/rescrobbled";
};
Install.WantedBy = [ "default.target" ];
};
};
}

View file

@ -1,50 +1,31 @@
{ inputs, system, secrets, config, lib, pkgs-stable, ... }: { inputs, system, secrets, lib, config, ... }:
{ {
imports = [ ./meta.nix ]; options.ty-home-manager-options = {
plasma.enable = lib.mkEnableOption "plasma configuration";
firefox.enable = lib.mkEnableOption "firefox configuration";
thunderbird.enable = lib.mkEnableOption "thunderbird configuration";
vscode.enable = lib.mkEnableOption "vscode configuration";
beets.enable = lib.mkEnableOption "beets configuration";
rescrobbled.enable = lib.mkEnableOption "rescrobbled configuration";
};
config = { config = {
home-manager = let home-manager.useGlobalPkgs = true;
entrypoint = { home-manager.useUserPackages = true;
imports = [ home-manager.sharedModules = [
# Import meta options for configuring the configuration
./meta.nix
# Import all of my config
./config
];
home.stateVersion = "24.05";
# Inherit my home manager config options
meta.home-manager = config.meta.home-manager;
};
in lib.mkMerge [
## General home-manager.* options
{
# Allow user installation of packages
useGlobalPkgs = true;
useUserPackages = true;
sharedModules = [
# Import plasma manager and all of my custom modules for use
inputs.plasma-manager.homeManagerModules.plasma-manager inputs.plasma-manager.homeManagerModules.plasma-manager
./modules ./custom-modules
]; ];
# Inherit all of my nixos config custom arguments home-manager.extraSpecialArgs = {
extraSpecialArgs = { inherit inputs system secrets;
inherit inputs system secrets pkgs-stable; inherit (config) ty-home-manager-options;
}; };
home-manager.backupFileExtension = "backup";
# Hopefully avoid file conflicts home-manager.users.ty = {
backupFileExtension = "bak"; imports = [
} ./home.nix
# The nixos home-manager module and the nix-on-droid compatibility have different options,
# so this handles both in the same file
(if (config.meta.home-manager.interface == "nixos") then {
users.ty = entrypoint;
} else {
config = entrypoint;
})
]; ];
}; };
};
} }

22
home-manager/home.nix Executable file
View file

@ -0,0 +1,22 @@
{ lib, config, ... }:
{
home.stateVersion = "24.05";
home.username = "ty";
home.homeDirectory = "/home/ty";
imports = [
./modules/packages.nix
./modules/plasma.nix
./modules/vcs
./modules/firefox.nix
./modules/thunderbird.nix
./modules/accounts
./modules/gpg.nix
./modules/shell
./modules/vscode.nix
./modules/desktop.nix
./modules/gtk.nix
./modules/beets.nix
./modules/rescrobbled.nix
];
}

View file

@ -1,74 +0,0 @@
{ lib, config, ... }:
{
options.meta.home-manager = {
# Presets for easy configuring the configuration
preset = lib.mkOption {
type = lib.types.nullOr (lib.types.enum [ "plasma-desktop" "cli" ]);
default = null;
defaultText = lib.literalExpression "null";
description = ''
The preset to use for enabling individual home-manager meta configuration options.
Presets:
- plasma-desktop
- Will enable anything that requires a desktop, and plasma-specific configuration
- cli
- Will only enable what is necessary for a CLI environment, excluding everything else
'';
};
# Individual configuration options
beets.enable = lib.mkEnableOption "beets configuration";
desktop = {
enable = lib.mkEnableOption "configuration that requires a desktop environment";
plasma.enable = lib.mkEnableOption "plasma configuration";
};
email = {
enable = lib.mkEnableOption "email configuration";
thunderbird.enable = lib.mkEnableOption "email configuration for thunderbird";
};
firefox.enable = lib.mkEnableOption "firefox configuration";
rescrobbled.enable = lib.mkEnableOption "rescrobbled configuration";
vscode.enable = lib.mkEnableOption "vscode configuration";
username = lib.mkOption {
type = lib.types.str;
default = "ty";
defaultText = lib.literalExpression ''"ty"'';
description = "The username to apply the config as (only applies in standalone config)";
};
interface = lib.mkOption {
type = lib.types.enum [ "nixos" "nix-on-droid" ];
default = "nixos";
defaultText = lib.literalExpression ''"nixos"'';
description = "The interface to use for configuring home-manger as a module";
};
};
# Handle preset logic
config.meta.home-manager = lib.mkMerge [
# Desktop w/ Plasma preset
(lib.mkIf (config.meta.home-manager.preset == "plasma-desktop") {
beets.enable = true;
desktop.enable = true;
desktop.plasma.enable = true;
email.enable = true;
email.thunderbird.enable = true;
firefox.enable = true;
rescrobbled.enable = true;
vscode.enable = true;
})
# CLI Preset
(lib.mkIf (config.meta.home-manager.preset == "cli") {
beets.enable = false;
desktop.enable = false;
desktop.plasma.enable = false;
email.enable = false;
email.thunderbird.enable = false;
firefox.enable = false;
rescrobbled.enable = false;
vscode.enable = false;
})
];
}

View file

@ -1,4 +1,4 @@
{ ... }: { lib, config, ... }:
{ {
imports = [ imports = [
./email.nix ./email.nix

View file

@ -1,9 +1,9 @@
{ lib, config, ... }: { lib, ty-home-manager-options, ... }:
{ {
accounts.email.accounts = lib.mkIf config.meta.home-manager.email.enable { accounts.email.accounts = lib.mkIf ty-home-manager-options.thunderbird.enable {
PurelyMail = let address = "ty@myriation.xyz"; in { PurelyMail = rec {
realName = "Tyler Beckman"; realName = "Tyler Beckman";
inherit address; address = "ty@myriation.xyz";
userName = address; userName = address;
primary = true; primary = true;
@ -38,12 +38,12 @@
}; };
}; };
thunderbird.enable = config.meta.home-manager.email.thunderbird.enable; thunderbird.enable = true;
}; };
Gmail = let address = "tbeckman530@gmail.com"; in { Gmail = rec {
realName = "Tyler Beckman"; realName = "Tyler Beckman";
inherit address; address = "tbeckman530@gmail.com";
userName = address; userName = address;
flavor = "gmail.com"; flavor = "gmail.com";
@ -62,12 +62,12 @@
smtp.tls.useStartTls = false; smtp.tls.useStartTls = false;
thunderbird.enable = config.meta.home-manager.email.thunderbird.enable; thunderbird.enable = true;
}; };
School = let address = "tyler_beckman@mines.edu"; in { School = rec {
realName = "Tyler Beckman"; realName = "Tyler Beckman";
inherit address; address = "tyler_beckman@mines.edu";
userName = address; userName = address;
flavor = "outlook.office365.com"; flavor = "outlook.office365.com";
@ -77,15 +77,6 @@
sent = "Sent Items"; sent = "Sent Items";
trash = "Trash"; trash = "Trash";
}; };
thunderbird = {
enable = config.meta.home-manager.email.thunderbird.enable;
# Manually set oauth2 as the authentication method (home-manager does not have proper support)
settings = id: {
"mail.smtpserver.smtp_${id}.authMethod" = 10;
"mail.server.server_${id}.authMethod" = 10;
};
};
}; };
}; };
} }

View file

@ -1,14 +1,7 @@
{ lib, secrets, config, pkgs, ... }: { lib, secrets, ty-home-manager-options, ... }:
{ {
programs.beets = lib.mkIf config.meta.home-manager.beets.enable { programs.beets = lib.mkIf ty-home-manager-options.beets.enable {
enable = true; enable = true;
package = pkgs.beets.override {
pluginOverrides = {
# Build for some GPU lang LLVM dependency failed on hydra as of disabling, and I don't use it
# TODO: Switch to using disableAllPlugins for an allowlist of plugins
autobpm.enable = false;
};
};
settings = { settings = {
directory = "~/Music"; directory = "~/Music";

View file

@ -1,6 +1,6 @@
{ lib, config, ... }: { lib, ty-home-manager-options, ... }:
{ {
xdg.desktopEntries = lib.mkIf config.meta.home-manager.desktop.enable { xdg.desktopEntries = lib.mkIf ty-home-manager-options.plasma.enable {
# Override vesktop for matching icon in beautyline (make it generic discord icon) # Override vesktop for matching icon in beautyline (make it generic discord icon)
vesktop = { vesktop = {
categories = [ "Network" "InstantMessaging" "Chat" ]; categories = [ "Network" "InstantMessaging" "Chat" ];

View file

@ -1,6 +1,6 @@
{ pkgs, inputs, system, lib, config, ... }: { pkgs, inputs, system, lib, ty-home-manager-options, ... }:
{ {
programs.firefox = lib.mkIf config.meta.home-manager.firefox.enable { programs.firefox = lib.mkIf ty-home-manager-options.firefox.enable {
enable = true; enable = true;
policies = { policies = {
ExtensionSettings = { ExtensionSettings = {
@ -160,8 +160,8 @@
}; };
# NixOS Wiki Search # NixOS Wiki Search
"NixOS Wiki" = { "NixOS Wiki" = {
urls = [{ template = "https://wiki.nixos.org/w/index.php?search={searchTerms}"; }]; urls = [{ template = "https://nixos.wiki/index.php?search={searchTerms}"; }];
iconUpdateURL = "https://wiki.nixos.org/nixos.png"; iconUpdateURL = "https://nixos.wiki/favicon.png";
updateInterval = 24 * 60 * 60 * 1000; # every day updateInterval = 24 * 60 * 60 * 1000; # every day
definedAliases = [ "@nw" ]; definedAliases = [ "@nw" ];
}; };

View file

@ -1,4 +1,4 @@
{ pkgs, config, ... }: { pkgs, ... }:
{ {
programs.gpg = { programs.gpg = {
enable = true; enable = true;
@ -56,7 +56,7 @@
enable = true; enable = true;
enableSshSupport = true; enableSshSupport = true;
enableZshIntegration = true; enableZshIntegration = true;
pinentryPackage = if (config.meta.home-manager.desktop.enable) then pkgs.pinentry-qt else pkgs.pinentry-tty; pinentryPackage = pkgs.pinentry-qt;
sshKeys = [ sshKeys = [
"817A829FB1FB95441156F93C7F4FD04ACDDE5E48 0" "817A829FB1FB95441156F93C7F4FD04ACDDE5E48 0"
]; ];

View file

@ -1,12 +1,12 @@
{ pkgs, lib, config, ... }: { pkgs, lib, config, ty-home-manager-options, ... }:
{ {
config = lib.mkIf config.meta.home-manager.desktop.enable { config = lib.mkIf ty-home-manager-options.plasma.enable {
gtk = { gtk = {
enable = true; enable = true;
gtk2.configLocation = "${config.xdg.configHome}/gtk-2.0/gtkrc"; gtk2.configLocation = "${config.xdg.configHome}/gtk-2.0/gtkrc";
theme = lib.mkIf config.meta.home-manager.desktop.plasma.enable { theme = {
name = "Breeze-Dark"; name = "Breeze-Dark";
package = pkgs.kdePackages.breeze-gtk; package = pkgs.kdePackages.breeze-gtk;
}; };

View file

@ -0,0 +1,63 @@
{ pkgs, inputs, system, lib, ty-home-manager-options, ... }:
{
home.packages = (with pkgs; [
# :3
fastfetch # Modern & faster neofetch alternative
# CLI Tools
ripgrep # Text searching and manipulation
jq # JSON filtering
eza # Directory lister
bat # File reading
doggo # DNS Requests
nmap # Network scanning
glow # Markdown rendering
tealdeer # TLDR
usbutils # `lsusb`
pciutils # `lspci`
unzip # Extract zip files
# Process tools
btop # Process monitor
nvtopPackages.full # GPU monitor
]) ++ (lib.optionals ty-home-manager-options.plasma.enable (with pkgs; [
# Documents
logseq # Outliner
libreoffice-qt6-fresh # Office-style editing
# Video
jellyfin-media-player # Jellyfin electron client w/ MPV
vlc # Video file player
# Chat
element-desktop # Matrix client
vesktop # Discord client
signal-desktop # Signal client
# KDE Themes
vimix-cursors # Cursors
(pkgs.callPackage ../../packages/beautyline {}) # Icons
(pkgs.callPackage ../../packages/magna-splash-6 {}) # Splash
# Programming
jetbrains.idea-ultimate # Jetbrains IntelliJ Idea Ultimate IDE
nixd # LSP for .nix files
gcc # GNU C++ Compiler
(lib.meta.hiPrio clang) # LLVM C++ Compiler (better than g++)
clang-tools # Clang language server
cling # C++ REPL
deno # Typescript & Javascript runtime
gnumake # Makefile support
# UI Tools
qalculate-qt # Calculator
])) ++ (lib.optionals ty-home-manager-options.firefox.enable [
# Firefox nightly
inputs.firefox-nightly.packages.${system}.firefox-nightly-bin
]) ++ (lib.optionals ty-home-manager-options.plasma.enable (with pkgs.kdePackages; [
kate # IDE
elisa # Music
kdeconnect-kde # Phone sync
polkit-kde-agent-1 # Polkit authentication popup support
]));
}

View file

@ -1,6 +1,6 @@
{ pkgs, lib, config, ... }: { pkgs, lib, ty-home-manager-options, ... }:
{ {
programs.plasma = lib.mkIf config.meta.home-manager.desktop.plasma.enable { programs.plasma = lib.mkIf ty-home-manager-options.plasma.enable {
enable = true; enable = true;
workspace = { workspace = {

View file

@ -1,82 +0,0 @@
{ lib, pkgs, config, ... }:
{
options = {
programs.custom.prism-launcher = {
enable = lib.mkEnableOption "prism launcher";
package = lib.mkPackageOption pkgs "Prism Launcher" {
default = "prismlauncher";
};
javaPackages = lib.mkOption {
type = lib.types.listOf lib.types.package;
default = [
# These three JREs cover most minecraft versions
pkgs.temurin-jre-bin-21
pkgs.temurin-jre-bin-17
pkgs.temurin-jre-bin-8
];
defaultText = lib.literalExpression "with pkgs; [ temurin-jre-bin-21 temurin-jre-bin-17 temurin-jre-bin-8 ]";
description = "The java packages to provide to Prism Launcher for running the game";
};
additionalPrograms = lib.mkOption {
type = lib.types.listOf lib.types.package;
default = [];
defaultText = lib.literalExpression "[]";
description = ''
Additional programs that will be added to Prism Launcher's PATH.
Use this for mods that require an extra binary to be present to function.
'';
};
additionalLibs = lib.mkOption {
type = lib.types.listOf lib.types.package;
default = [];
defaultText = lib.literalExpression "[]";
description = ''
Additional dynamic libraries that will be added to Prism Launcher's LD_LIBRARY_PATH.
Use this for mods that require an extra native library to be present to function.
'';
};
controllerSupport = lib.mkOption {
type = lib.types.bool;
default = true;
defaultText = lib.literalExpression "true";
description = "Whether to enable controller support for Prism Launcher";
};
gamemodeSupport = lib.mkOption {
type = lib.types.bool;
default = true;
defaultText = lib.literalExpression "true";
description = "Whether to enable Feral GameMode support for Prism Launcher";
};
textToSpeechSupport = lib.mkOption {
type = lib.types.bool;
default = true;
defaultText = lib.literalExpression "true";
description = "Whether to enable text-to-speech support for Prism Launcher";
};
msaClientID = lib.mkOption {
type = lib.types.nullOr lib.types.str;
default = null;
defaultText = lib.literalExpression "null";
description = ''
A custom MSA Client ID to use for authentication with microsoft servers.
Do not override this unless truly necessary.
'';
};
};
};
config = let
cfg = config.programs.custom.prism-launcher;
in lib.mkIf cfg.enable {
home.packages = [ (cfg.package.override {
jdks = cfg.javaPackages;
inherit (cfg) additionalPrograms additionalLibs controllerSupport gamemodeSupport textToSpeechSupport msaClientID;
}) ];
};
}

View file

@ -1,85 +1,23 @@
{ pkgs, lib, config, ... }: { secrets, lib, ty-home-manager-options, ... }:
let tomlFormat = pkgs.formats.toml { }; in { {
options = { config = lib.mkIf ty-home-manager-options.rescrobbled.enable {
services.custom.rescrobbled = { services.custom.rescrobbled = let s = secrets.programs.rescrobbled; in lib.mkIf s.enable {
enable = lib.mkEnableOption "rescrobbled";
package = lib.mkOption {
type = lib.types.package;
default = (pkgs.callPackage ../../packages/rescrobbled {});
defaultText = lib.literalExpression "pkgs.rescrobbled";
description = "The package to use for rescrobbled";
};
session = lib.mkOption {
type = lib.types.str;
description = ''
The session token to use for last.fm.
This can be found by setting a last.fm API key & secret,
and then manually running the daemon. Then, the session token
will be located at {file}`$XDG_CONFIG_HOME/rescrobbled/session`.
'';
default = null;
};
settings = lib.mkOption {
type = tomlFormat.type;
default = {};
example = lib.literalExpression ''
lastfm-key = "Last.fm API key"
lastfm-secret = "Last.fm API secret"
min-play-time = 0
player-whitelist = [ "Player MPRIS identity or bus name" ]
filter-script = "path/to/script"
[[listenbrainz]]
url = "Custom API URL"
token = "User token"
'';
description = ''
Configuration written to
{file}`$XDG_CONFIG_HOME/rescrobbled/config.toml`.
See <https://github.com/InputUsername/rescrobbled#configuration> for the full list
of options.
'';
};
};
};
config = let cfg = config.services.custom.rescrobbled; in lib.mkIf cfg.enable {
home.packages = [ cfg.package ];
xdg.configFile ={
"rescrobbled/config.toml" = lib.mkIf (cfg.settings != { }) {
enable = true; enable = true;
source = tomlFormat.generate "rescrobbled-config" cfg.settings; session = s.lastfm.session;
};
"rescrobbled/session" = lib.mkIf (cfg.settings != { }) { settings = {
enable = true; player-whitelist = [ "elisa" ];
# Force makes it easy to generate the session file, then add it to nix cfg without issues
force = true;
text = cfg.session; listenbrainz = lib.mkIf (s.listenbrainz.token != null) [
}; {
}; token = s.listenbrainz.token;
}
];
systemd.user.services.rescrobbled = { lastfm-key = lib.mkIf (s.lastfm.key != null && s.lastfm.secret != null) s.lastfm.key;
Unit = { lastfm-secret = lib.mkIf (s.lastfm.key != null && s.lastfm.secret != null) s.lastfm.secret;
Description = "An MPRIS scrobbler";
Documentation = "https://github.com/InputUsername/rescrobbled";
Wants = "network-online.target";
After = "network-online.target";
}; };
Service = {
ExecStartPre = "${pkgs.coreutils}/bin/sleep 15"; # Avoid listenbrainz errors by adding delay till network is connected
ExecStart = "${cfg.package}/bin/rescrobbled";
};
Install.WantedBy = [ "default.target" ];
}; };
}; };
} }

View file

@ -9,7 +9,6 @@
truecolor = true; truecolor = true;
shown_boxes = "proc cpu mem net gpu0"; shown_boxes = "proc cpu mem net gpu0";
update_ms = 100; update_ms = 100;
temp_scale = "fahrenheit";
}; };
}; };
} }

View file

@ -5,7 +5,6 @@
./direnv.nix ./direnv.nix
./konsole.nix ./konsole.nix
./starship.nix ./starship.nix
./tldr.nix
./zsh.nix ./zsh.nix
]; ];
} }

View file

@ -1,6 +1,6 @@
{ pkgs, lib, config, ... }: { pkgs, lib, ty-home-manager-options, ... }:
{ {
programs.konsole = lib.mkIf config.meta.home-manager.desktop.plasma.enable { programs.konsole = lib.mkIf ty-home-manager-options.plasma.enable {
enable = true; enable = true;
defaultProfile = "Primary"; defaultProfile = "Primary";
profiles = { profiles = {

View file

@ -27,12 +27,12 @@
+ "\${custom.date}" + "\${custom.date}"
+ "[ ](fg:007 bg:prev_bg)" + "[ ](fg:007 bg:prev_bg)"
+ "$battery" + "$battery"
+ "[](fg:prev_bg)[](fg:242)" + "[](fg:prev_bg)[ ](fg:242)"
# Left prompter # Left prompter
+ "\n[ ](fg:242)"; + "\n[ ](fg:242)";
# Right prompter # Right prompter
right_format = "[](fg:242)"; right_format = "[ ](fg:242)";
os = { os = {
disabled = false; disabled = false;
@ -57,9 +57,10 @@
hostname = { hostname = {
disabled = false; disabled = false;
ssh_only = false; ssh_only = false;
ssh_symbol = "🌐 ";
trim_at = ""; trim_at = "";
style = "bg:prev_bg fg:prev_fg"; style = "bg:prev_bg fg:prev_fg";
format = "[$hostname]($style)"; format = "[$ssh_symbol$hostname]($style)";
}; };
shell = { shell = {

View file

@ -24,17 +24,6 @@
bindkey "^H" backward-kill-word bindkey "^H" backward-kill-word
bindkey "^Z" undo bindkey "^Z" undo
''; '';
# Disable saving the history file, as it is handled by atuin
history = {
# Tell it to not save anything to disk
save = 0;
# If it still tries to save anything, have it write to /dev/null instead just in case
path = "/dev/null";
# We leave size at the default to allow zsh to have command history in memory
# for features like !! or !cmdname, but simply have it stop writing to disk
size = 10000;
};
}; };
# Atuin shell history # Atuin shell history

View file

@ -1,6 +1,6 @@
{ pkgs, lib, config, ... }: { pkgs, lib, ty-home-manager-options, ... }:
{ {
programs.thunderbird = lib.mkIf config.meta.home-manager.email.thunderbird.enable { programs.thunderbird = lib.mkIf ty-home-manager-options.thunderbird.enable {
enable = true; enable = true;
package = pkgs.thunderbird-latest; package = pkgs.thunderbird-latest;
profiles = { profiles = {

View file

@ -1,4 +1,4 @@
{ pkgs, lib, config, ... }: { pkgs, ... }:
{ {
programs.jujutsu = { programs.jujutsu = {
enable = true; enable = true;
@ -20,7 +20,7 @@
pager = "delta"; pager = "delta";
default-command = "log"; default-command = "log";
editor = lib.mkIf (config.meta.home-manager.desktop.enable) "zeditor --wait"; editor = "codium --wait";
diff = { diff = {
format = "git"; format = "git";

View file

@ -1,6 +1,6 @@
{ pkgs, inputs, system, lib, config, ... }: { pkgs, inputs, system, lib, ty-home-manager-options, ... }:
{ {
programs.vscode = lib.mkIf config.meta.home-manager.vscode.enable ( programs.vscode = lib.mkIf ty-home-manager-options.vscode.enable (
let vscode-package = pkgs.vscodium; in { let vscode-package = pkgs.vscodium; in {
enable = true; enable = true;
package = vscode-package; package = vscode-package;
@ -23,7 +23,7 @@
# Language support # Language support
rust-lang.rust-analyzer # Rust rust-lang.rust-analyzer # Rust
llvm-vs-code-extensions.vscode-clangd # C++ llvm-vs-code-extensions.vscode-clangd # C++
# vadimcn.vscode-lldb # C++ Debugging vadimcn.vscode-lldb # C++ Debugging
jnoortheen.nix-ide # Nix jnoortheen.nix-ide # Nix
tamasfe.even-better-toml # TOML tamasfe.even-better-toml # TOML
yzhang.markdown-all-in-one # Markdown yzhang.markdown-all-in-one # Markdown
@ -38,15 +38,12 @@
mkhl.direnv # nix-direnv autoloading mkhl.direnv # nix-direnv autoloading
cschlosser.doxdocgen # C++ Doxygen generator cschlosser.doxdocgen # C++ Doxygen generator
tomoki1207.pdf # PDF Viewing tomoki1207.pdf # PDF Viewing
exodiusstudios.comment-anchors # Comment anchors and highlighting
]) ])
++ (with vscode-marketplace; [ ++ (with vscode-marketplace; [
yy0931.save-as-root # Save as root over SSH yy0931.save-as-root # Save as root over SSH
akiramiyakoda.cppincludeguard # Auto-insert header guards for header files akiramiyakoda.cppincludeguard # Auto-insert header guards for header files
]) ])
) ++ (with pkgs.vscode-extensions; [ );
vadimcn.vscode-lldb
]);
userSettings = { userSettings = {
# Editor # Editor

View file

@ -1,18 +0,0 @@
{ inputs, config, ... }:
{
imports = [
# Import plasma manager and all of my custom modules for use
inputs.plasma-manager.homeManagerModules.plasma-manager
./modules
# Import main config
./meta.nix
./config
];
home = {
stateVersion = "24.11";
username = config.meta.home-manager.username;
homeDirectory = /. + "/home/${config.meta.home-manager.username}";
};
}

View file

@ -1,13 +0,0 @@
{ ... }:
{
boot = {
loader = {
systemd-boot = {
enable = true;
};
efi.canTouchEfiVariables = true;
};
initrd.systemd.enable = true;
};
}

View file

@ -1,18 +0,0 @@
{ ... }:
{
fileSystems."/mnt/hdd" = {
device = "/dev/mapper/hdd";
fsType = "btrfs";
options = [ "compress=zstd:3" "autodefrag" "nofail" ];
encrypted = {
enable = true;
label = "hdd";
blkDev = "/dev/disk/by-uuid/eab5e1d6-6956-46fd-b3ac-5fcf525e1df8";
keyFile = "/sysroot/root/hdd.key";
};
};
# Loading the uas kernel module early is needed to mount the above drive via USB-SATA adapter
boot.initrd.kernelModules = [ "uas" ];
}

View file

@ -1,57 +0,0 @@
{ pkgs, ... }:
{
networking = {
hostName = "ty-laptop-server";
# TODO Firewall causes issues with containers, need to fix it
firewall = {
enable = true;
package = pkgs.iptables;
};
# Enable NetworkManager
networkmanager = {
enable = true;
ensureProfiles = {
# secrets.entries = [
# {
# file = "/run/";
# }
# ];
profiles = {
eduroam = {
"802-1x" = {
eap = "peap;";
identity = "tyler_beckman@mines.edu";
password-flags = "1";
phase2-auth = "mschapv2";
};
connection = {
autoconnect-priority = "99";
id = "eduroam";
permissions = "user:ty:;";
type = "wifi";
};
ipv4.method = "auto";
ipv6.method = "disabled"; # I hate mines IT
wifi = {
mode = "infrastructure";
ssid = "eduroam";
};
wifi-security.key-mgmt = "wpa-eap";
};
};
};
};
};
# Tailscale overlay network configuration
services.tailscale = {
enable = true;
useRoutingFeatures = "both";
openFirewall = true;
};
networking.firewall.trustedInterfaces = [ "tailscale0" ];
}

View file

@ -1,41 +0,0 @@
# Global options
{
acme_dns porkbun {
api_key {env.PORKBUN_API_KEY}
api_secret_key {env.PORKBUN_API_SECRET_KEY}
}
email ty@myriation.xyz
storage file_system {
root /var/lib/caddy
}
}
# Handle all routes handled by this server
https://*.m.myriation.xyz {
# Enforce always using HTTPS
header Strict-Transport-Security "max-age=31536000; includeSubDomains; preload"
# Give an HTTP cat on any errors
handle_errors {
header Content-Type text/html
respond "<!DOCTYPE html><html><head><title>Error :(</title></head><body><img src=\"https://http.cat/{http.error.status_code}\" alt=\"cat\"></body></html>" {http.error.status_code}
}
# Configure all service matchers
@jellyfin host jellyfin.m.myriation.xyz
@jellyseerr host jellyseerr.m.myriation.xyz
# Handle all services
handle @jellyfin {
reverse_proxy jellyfin.containers:8096
}
handle @jellyseerr {
reverse_proxy jellyseerr.containers:5055
}
# Handle all unmatched requests as a 404
handle {
error "Not Found" 404
}
}

View file

@ -1,26 +0,0 @@
{ pkgs, secrets, ... }:
{
# TODO: Containerize once I setup a proper shared bridge network
services.caddy = {
enable = true;
package = pkgs.caddy.withPlugins {
plugins = [ "github.com/caddy-dns/porkbun@v0.2.1" ];
hash = "sha256-oizWuPXI0M9ngBCt/iEXWt+/33wpKlCs1yBPKnzFhRY=";
};
# Use a custom config because doing Caddyfile in multiline nix strings
# feels messy (and not syntax highlighted)
configFile = ./Caddyfile;
};
# Pass secrets through the systemd service's environment variables
systemd.services.caddy.environment = {
PORKBUN_API_KEY = secrets.programs.caddy.porkbun_api_key;
PORKBUN_API_SECRET_KEY = secrets.programs.caddy.porkbun_secret_key;
};
# Allow caddy through the firewall
networking.firewall = {
allowedTCPPorts = [ 80 443 ]; # HTTP/1-2
allowedUDPPorts = [ 443 ]; # HTTP/3 w/ QUIC
};
}

View file

@ -1,10 +0,0 @@
{ ... }:
{
imports = [
./networking.nix
# Individual services
./caddy
./jellyfin
./jellyseerr
];
}

View file

@ -1,31 +0,0 @@
{ ... }:
{
containers.jellyfin = {
config = { pkgs, ... }: {
system.stateVersion = "25.05";
services.jellyfin = {
enable = true;
package = pkgs.jellyfin;
};
# Firewall on the host system is enough + this firewall seems to break networking
networking.firewall.enable = false;
networking.resolvconf.enable = false;
};
autoStart = true;
bindMounts = {
"/var/lib/jellyfin/libraries" = {
hostPath = "/mnt/hdd/jellyfin";
isReadOnly = false;
};
};
};
networking = {
firewall.trustedInterfaces = [ "ve-jellyfin" ];
nat.internalInterfaces = [ "ve-jellyfin" ];
networkmanager.unmanaged = [ "interface-name:ve-jellyfin" ];
};
}

View file

@ -1,24 +0,0 @@
{ ... }:
{
containers.jellyseerr = {
config = { pkgs, ... }: {
system.stateVersion = "25.11";
services.jellyseerr = {
enable = true;
package = pkgs.jellyseerr;
};
# Firewall on the host system is enough + this firewall seems to break networking
networking.firewall.enable = false;
networking.resolvconf.enable = false;
};
autoStart = true;
};
networking = {
firewall.trustedInterfaces = [ "ve-jellyseerr" ];
nat.internalInterfaces = [ "ve-jellyseerr" ];
networkmanager.unmanaged = [ "interface-name:ve-jellyseerr" ];
};
}

View file

@ -1,41 +0,0 @@
{ lib, ... }:
let
services = {
jellyfin = {
hostByte = 2;
};
jellyseerr = {
hostByte = 3;
};
};
in {
config = lib.mkMerge ([{
# Config always added
networking = {
nat = {
enable = true;
externalInterface = "wlp2s0";
};
};
}] ++ builtins.map (serviceName: {
# Config added per-service
containers.${serviceName} = {
privateNetwork = true;
# Give it an address of 172.30.0.X on the host-side and 172.30.1.X inside the container
# This appears to be necessary as both having addresses the same seems to cause issues
hostAddress = "172.30.0.${builtins.toString services.${serviceName}.hostByte}";
localAddress = "172.30.1.${builtins.toString services.${serviceName}.hostByte}";
bindMounts."/etc/resolv.conf" = {
hostPath = "/etc/resolv.conf";
isReadOnly = true;
};
};
networking = {
firewall.trustedInterfaces = [ "ve-${serviceName}" ];
nat.internalInterfaces = [ "ve-${serviceName}" ];
networkmanager.unmanaged = [ "interface-name:ve-${serviceName}" ];
};
}) (builtins.attrNames services));
}

View file

@ -1,8 +0,0 @@
{ pkgs, ... }:
{
services.vscode-server = {
enable = true;
nodejsPackage = pkgs.nodejs-18_x;
installPath = "$HOME/.vscodium-server";
};
}

View file

@ -8,23 +8,9 @@
{ {
imports = [ imports = [
## External modules
# Better command-not-found
inputs.nix-index-database.nixosModules.nix-index
{ programs.nix-index-database.comma.enable = true; }
# Home manager
inputs.home-manager.nixosModules.home-manager
../../home-manager
{ meta.home-manager.preset = "cli"; }
# VSCode server support
inputs.vscode-server.nixosModules.default
## Normal configuration
./hardware-configuration.nix ./hardware-configuration.nix
./config ./modules
./services
]; ];
system.stateVersion = "24.11"; system.stateVersion = "24.11";

View file

@ -0,0 +1,7 @@
{ ... }:
{
boot.loader = {
systemd-boot.enable = true;
efi.canTouchEfiVariables = true;
};
}

View file

@ -1,17 +1,12 @@
{ ... }: { ... }:
{ {
imports = [ imports = [
# Folders
./services
# Individual files
./bootloader.nix ./bootloader.nix
./display.nix ./display.nix
./locale.nix ./locale.nix
./mounts.nix
./networking.nix ./networking.nix
./nixpkgs.nix ./nixpkgs.nix
./programs.nix ./programs.nix
./users.nix ./users.nix
./vscode-server.nix
]; ];
} }

View file

@ -18,7 +18,4 @@
} }
]; ];
}; };
# Disable sleep on lid close (because server)
services.logind.lidSwitch = "ignore";
} }

View file

@ -0,0 +1,22 @@
{ ... }:
{
networking = {
hostName = "ty-laptop-server";
# Enable firewall
firewall = {
enable = true;
trustedInterfaces = [ "lo" "ve-jellyfin" ];
};
# Enable NetworkManager
networkmanager.enable = true;
};
# Tailscale overlay network configuration
services.tailscale = {
enable = true;
useRoutingFeatures = "both";
openFirewall = true;
};
}

View file

@ -19,11 +19,4 @@
hashedPassword = secrets.passwords.users.ty; hashedPassword = secrets.passwords.users.ty;
}; };
}; };
# Enable polkit user authentication
security.polkit.enable = true;
security.pam.services.systemd-run0 = {
setEnvironment = true;
pamMount = false;
}; # https://github.com/NixOS/nixpkgs/issues/361592#issuecomment-2516342739
} }

View file

@ -0,0 +1,15 @@
{ ... }:
{
imports = [
./jellyfin.nix
];
networking = {
nat = {
enable = true;
internalInterfaces = ["ve-jellyfin"];
externalInterface = "wlp2s0";
};
networkmanager.unmanaged = [ "interface-name:ve-jellyfin" ];
};
}

View file

@ -0,0 +1,17 @@
{ config, ... }:
{
containers.jellyfin = {
config = { pkgs, ...}: {
system.stateVersion = "25.05";
services.jellyfin = {
enable = true;
package = pkgs.jellyfin;
};
};
autoStart = true;
privateNetwork = true;
hostAddress = "172.30.0.2"; # TODO define in config option
localAddress = "172.30.0.2";
};
}

View file

@ -1,36 +1,12 @@
{ inputs, ... }: { inputs, ... }:
{ {
imports = [ imports = [
## External modules
# Better command-not-found
inputs.nix-index-database.nixosModules.nix-index
{ programs.nix-index-database.comma.enable = true; }
# Home manager
inputs.home-manager.nixosModules.home-manager
../../home-manager
{ meta.home-manager.preset = "plasma-desktop"; }
## Normal configuration
./hardware-configuration.nix ./hardware-configuration.nix
./config ./modules
]; ];
system.stateVersion = "24.05"; system.stateVersion = "24.05";
nix.settings.experimental-features = [ "nix-command" "flakes" ];
nix.nixPath = [ "nixpkgs=${inputs.nixpkgs}" ]; nix.nixPath = [ "nixpkgs=${inputs.nixpkgs}" ];
nix.settings = {
experimental-features = [ "nix-command" "flakes" ];
substituters = [
"https://colmena.cachix.org"
];
trusted-public-keys = [
"colmena.cachix.org-1:7BzpDnjjH8ki2CT3f6GdOk7QAzPOl+1t3LvTLXqYcSg="
];
auto-optimise-store = true;
};
nix.gc.automatic = true;
} }

View file

@ -4,6 +4,4 @@
services.desktopManager.plasma6.enable = true; services.desktopManager.plasma6.enable = true;
programs.dconf.enable = true; programs.dconf.enable = true;
programs.partition-manager.enable = true; programs.partition-manager.enable = true;
# Fix some programs not using the portal properly
xdg.portal.xdgOpenUsePortal = true;
} }

View file

@ -1,8 +1,6 @@
{ pkgs, ... }: { pkgs, ... }:
{ {
fonts = { fonts = {
fontDir.enable = true;
packages = with pkgs; [ packages = with pkgs; [
# Core fonts (Arial, Times new roman and the such) # Core fonts (Arial, Times new roman and the such)
corefonts corefonts

View file

@ -2,8 +2,6 @@
{ {
networking.hostName = "ty-nixos"; networking.hostName = "ty-nixos";
# networking.hosts = { "23.95.137.176" = [ "s.optifine.net" ]; };
# Enable firewall # Enable firewall
networking.firewall.enable = true; networking.firewall.enable = true;

View file

@ -12,7 +12,7 @@
# Experimentally turn off Nvidia GPU when not in use # Experimentally turn off Nvidia GPU when not in use
powerManagement.finegrained = false; powerManagement.finegrained = false;
open = true; # Open source module is still very much beta open = false; # Open source module is still very much beta
nvidiaSettings = true; nvidiaSettings = true;

View file

@ -1,4 +1,4 @@
{ pkgs, inputs, system, ... }: { pkgs, inputs, ... }:
{ {
# Install system packages # Install system packages
environment.systemPackages = with pkgs; [ environment.systemPackages = with pkgs; [
@ -6,11 +6,8 @@
wget wget
curl curl
neovim neovim
wl-clipboard-rs
# Nix utilities
home-manager home-manager
inputs.colmena.packages."${system}".colmena wl-clipboard-rs
nvd
# VCS # VCS
git git
jujutsu jujutsu
@ -21,21 +18,12 @@
# Enable waydroid # Enable waydroid
virtualisation.waydroid.enable = true; virtualisation.waydroid.enable = true;
# Enable flatpak
services.flatpak.enable = true;
# Enable steam # Enable steam
programs.steam = { programs.steam = {
enable = true; enable = true;
extest.enable = true; extest.enable = true;
extraPackages = [
pkgs.vimix-cursors # Necessary so cursor size and theme are correct while inside the steam window
];
}; };
programs.gamemode.enable = true;
programs.gamescope.enable = true;
# Install zsh # Install zsh
programs.zsh.enable = true; programs.zsh.enable = true;

View file

@ -22,8 +22,4 @@
# Enable polkit user authentication # Enable polkit user authentication
security.polkit.enable = true; security.polkit.enable = true;
security.pam.services.systemd-run0 = {
setEnvironment = true;
pamMount = false;
}; # https://github.com/NixOS/nixpkgs/issues/361592#issuecomment-2516342739
} }

View file

@ -1,25 +0,0 @@
{ inputs, pkgs, ... }: {
imports = [
./environment.nix
# Import full home-manager config
../../home-manager
];
meta.home-manager = { preset = "cli"; interface = "nix-on-droid"; };
nix = {
extraOptions = ''
experimental-features = nix-command flakes
'';
nixPath = [ "nixpkgs=${inputs.nixpkgs}" ];
};
user.shell = "${pkgs.zsh}/bin/zsh";
time.timeZone = "America/Denver";
terminal = {
font = "${pkgs.nerd-fonts.fira-code}/share/fonts/truetype/NerdFonts/FiraCode/FiraCodeNerdFont-Regular.ttf";
};
system.stateVersion = "24.05";
}

View file

@ -1,39 +0,0 @@
{ pkgs, ... }:
{
environment = {
etcBackupExtension = ".bak";
packages = with pkgs; [
# Basic necessities
wget
curl
neovim
# Basic necessities copied from https://github.com/nix-community/nix-on-droid/blob/5d88ff2519e4952f8d22472b52c531bb5f1635fc/templates/home-manager/nix-on-droid.nix#L9C1-L26C11
procps
killall
diffutils
findutils
utillinux
tzdata
hostname
man
gnugrep
gnupg
gnused
gnutar
bzip2
gzip
xz
zip
unzip
# Nix tools
nvd
# VCS
git
jujutsu
];
motd = "";
};
}

View file

@ -19,12 +19,6 @@
token = null; token = null;
}; };
}; };
caddy = {
# The API key and secret key to use for provisioning HTTPS certificates
porkbun_api_key = null;
porkbun_secret_key = null;
};
}; };
passwords = { passwords = {

View file

@ -1,109 +0,0 @@
{ inputs, secrets }:
{
createHomeManagerConfig = {
system ? "x86_64-linux",
meta ? {}
}: inputs.home-manager.lib.homeManagerConfiguration {
pkgs = import inputs.nixpkgs { inherit system; config.allowUnfree = true; };
modules = [
../home-manager/standalone.nix
{ meta.home-manager = meta; }
];
extraSpecialArgs = {
inherit inputs system secrets;
pkgs-stable = inputs.nixpkgs-stable.legacyPackages.${system};
};
};
createNixosSystem = {
system ? "x86_64-linux",
entrypoint
}: inputs.nixpkgs.lib.nixosSystem {
inherit system;
specialArgs = {
inherit inputs system secrets;
pkgs-stable = inputs.nixpkgs-stable.legacyPackages.${system};
};
modules = [ entrypoint ];
};
createColmenaHive = {
defaultSystem ? "x86_64-linux",
hostConfigs ? []
}: {
# Set meta options for the colmena hive
meta = {
# Standard options
allowApplyAll = false;
# Defaults for nodes
nixpkgs = import inputs.nixpkgs { system = defaultSystem; };
specialArgs = {
inherit inputs secrets;
system = defaultSystem;
};
# Overrides for individual nodes
nodeNixpkgs = (
builtins.foldl'
(acc: cur:
acc // {
${cur.name} = inputs.nixpkgs.legacyPackages.${cur.system};
}
)
{}
(builtins.filter
(c: builtins.hasAttr "system" c && c.system != defaultSystem)
hostConfigs)
);
nodeSpecialArgs = (
builtins.foldl'
(acc: cur:
acc // {
${cur.name} = {
inherit inputs secrets;
system = cur.system;
pkgs-stable = inputs.nixpkgs-stable.legacyPackages.${cur.system};
};
}
)
{}
(builtins.filter
(c: builtins.hasAttr "system" c && c.system != defaultSystem)
hostConfigs)
);
};
} // (
# Add all of the hosts
builtins.foldl'
(acc: cur:
acc // {
${cur.name} = { ... }: {
deployment = {
replaceUnknownProfiles = if (builtins.hasAttr "allowLocal" cur) then cur.allowLocal else false;
targetUser = if (builtins.hasAttr "sshUser" cur) then cur.sshUser else "root";
targetHost = if (builtins.hasAttr "sshHost" cur) then cur.sshHost else cur.name;
targetPort = if (builtins.hasAttr "sshPort" cur) then cur.sshPort else 22;
allowLocalDeployment = if (builtins.hasAttr "allowLocal" cur) then cur.allowLocal else false;
};
imports = [ cur.entrypoint ];
};
}
)
{}
hostConfigs
);
createDroidSystem = {
system ? "aarch64-linux",
entrypoint
}: inputs.nix-on-droid.lib.nixOnDroidConfiguration {
pkgs = inputs.nixpkgs.legacyPackages.${system};
modules = [ entrypoint ];
extraSpecialArgs = {
inherit inputs system secrets;
pkgs-stable = inputs.nixpkgs-stable.legacyPackages.${system};
};
};
}