Compare commits
30 commits
Author | SHA1 | Date | |
---|---|---|---|
0dad3d244e | |||
2a15c44249 | |||
f03c4875ff | |||
697b148924 | |||
9ee785acfe | |||
426a2d5814 | |||
84e2cc3b80 | |||
ef017dc3ed | |||
d56b3bb359 | |||
71de72c798 | |||
6b36ea4418 | |||
cbf0ba3586 | |||
89459effd8 | |||
c0a0046260 | |||
cd17fbc9f7 | |||
5129e0a933 | |||
3489459d11 | |||
862322b4c8 | |||
81fbf5b098 | |||
644f398896 | |||
4c09acde73 | |||
931380d698 | |||
ad403bad0a | |||
50eacc53ee | |||
44a4ac95a9 | |||
c6a0a4f631 | |||
dacc41068b | |||
32771cf392 | |||
7539811ce3 | |||
c6100f63d7 |
80 changed files with 1640 additions and 413 deletions
1
.gitignore
vendored
1
.gitignore
vendored
|
@ -1 +1,2 @@
|
||||||
secrets.nix
|
secrets.nix
|
||||||
|
result
|
||||||
|
|
5
.vscode/settings.json
vendored
Normal file
5
.vscode/settings.json
vendored
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
{
|
||||||
|
"cSpell.words": [
|
||||||
|
"pkgs"
|
||||||
|
]
|
||||||
|
}
|
438
flake.lock
generated
438
flake.lock
generated
|
@ -16,20 +16,42 @@
|
||||||
"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",
|
"flake-utils": "flake-utils_2",
|
||||||
"nixpkgs": [
|
"nixpkgs": [
|
||||||
"nixpkgs"
|
"nixpkgs"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"dir": "/pkgs/firefox-addons",
|
"dir": "/pkgs/firefox-addons",
|
||||||
"lastModified": 1733875367,
|
"lastModified": 1735979945,
|
||||||
"narHash": "sha256-eBMHOM1KvbK8dTrM4N8ytNl8NeJF4lLyoPBRae1CqKs=",
|
"narHash": "sha256-qT25PnbcQ30ypnI8fNazRDsq3WmBXC8Lo+OvPr+Ct+o=",
|
||||||
"owner": "rycee",
|
"owner": "rycee",
|
||||||
"repo": "nur-expressions",
|
"repo": "nur-expressions",
|
||||||
"rev": "bda0131e0a7b6b5b687f5ffd8a8622054e7c444d",
|
"rev": "b93d8cdf12139da45146a6c3cf53141a437c41ec",
|
||||||
"type": "gitlab"
|
"type": "gitlab"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
|
@ -42,7 +64,7 @@
|
||||||
"firefox-nightly": {
|
"firefox-nightly": {
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"cachix": "cachix",
|
"cachix": "cachix",
|
||||||
"flake-compat": "flake-compat",
|
"flake-compat": "flake-compat_2",
|
||||||
"lib-aggregate": "lib-aggregate",
|
"lib-aggregate": "lib-aggregate",
|
||||||
"mozilla": "mozilla",
|
"mozilla": "mozilla",
|
||||||
"nixpkgs": [
|
"nixpkgs": [
|
||||||
|
@ -50,11 +72,11 @@
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1733834155,
|
"lastModified": 1735993795,
|
||||||
"narHash": "sha256-5A7EfzSmdApKmfHGtGZ4NQvMEpI/NI6VIzTNq9sUH4E=",
|
"narHash": "sha256-1jwzAW9/oRWbE6IeInTaemSAxda5fQJhSbkDcwvKMBU=",
|
||||||
"owner": "nix-community",
|
"owner": "nix-community",
|
||||||
"repo": "flake-firefox-nightly",
|
"repo": "flake-firefox-nightly",
|
||||||
"rev": "f0ab3cfa3607e08169b1d87e63fe9b1e5a57f515",
|
"rev": "0c4828eee2c87f9bde77d6e37fed30fd77e9d959",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
|
@ -64,6 +86,22 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"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=",
|
||||||
|
@ -78,7 +116,7 @@
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"flake-compat_2": {
|
"flake-compat_3": {
|
||||||
"flake": false,
|
"flake": false,
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1696426674,
|
"lastModified": 1696426674,
|
||||||
|
@ -95,6 +133,21 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"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=",
|
||||||
|
@ -109,7 +162,7 @@
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"flake-utils_2": {
|
"flake-utils_3": {
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"systems": "systems"
|
"systems": "systems"
|
||||||
},
|
},
|
||||||
|
@ -127,9 +180,9 @@
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"flake-utils_3": {
|
"flake-utils_4": {
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"systems": "systems_2"
|
"systems": "systems_3"
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1710146030,
|
"lastModified": 1710146030,
|
||||||
|
@ -145,6 +198,48 @@
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
"flake-utils_5": {
|
||||||
|
"inputs": {
|
||||||
|
"systems": "systems_4"
|
||||||
|
},
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1681202837,
|
||||||
|
"narHash": "sha256-H+Rh19JDwRtpVPAWp64F+rlEtxUWBAQW28eAi3SRSzg=",
|
||||||
|
"owner": "numtide",
|
||||||
|
"repo": "flake-utils",
|
||||||
|
"rev": "cfacdce06f30d2b68473a46042957675eebb3401",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "numtide",
|
||||||
|
"repo": "flake-utils",
|
||||||
|
"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": [
|
||||||
|
@ -152,11 +247,11 @@
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1733873195,
|
"lastModified": 1736013363,
|
||||||
"narHash": "sha256-dTosiZ3sZ/NKoLKQ++v8nZdEHya0eTNEsaizNp+MUPM=",
|
"narHash": "sha256-P4lsS2Y5GzBfC8OfXtD/xWEucX6oHGTjOzjEjEJbXfc=",
|
||||||
"owner": "nix-community",
|
"owner": "nix-community",
|
||||||
"repo": "home-manager",
|
"repo": "home-manager",
|
||||||
"rev": "f26aa4b76fb7606127032d33ac73d7d507d82758",
|
"rev": "0d7908bd09165db6699908b7e3970f137327cbf0",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
|
@ -168,15 +263,15 @@
|
||||||
},
|
},
|
||||||
"lib-aggregate": {
|
"lib-aggregate": {
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"flake-utils": "flake-utils_2",
|
"flake-utils": "flake-utils_3",
|
||||||
"nixpkgs-lib": "nixpkgs-lib"
|
"nixpkgs-lib": "nixpkgs-lib"
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1733660018,
|
"lastModified": 1735474663,
|
||||||
"narHash": "sha256-DHW2Hzyo8W6wVPGFaYLM9mKMH/qAtHJSUZ4ti7LHMCY=",
|
"narHash": "sha256-EFuucE6VnP/OFlMZV/sDxaEiz1z2Amfj91zQSQXbUUk=",
|
||||||
"owner": "nix-community",
|
"owner": "nix-community",
|
||||||
"repo": "lib-aggregate",
|
"repo": "lib-aggregate",
|
||||||
"rev": "f710791be27b31ea1ee9c40a94d08bcbba99b3c0",
|
"rev": "c9ad2f4cedf71f3a2e9a614b0c4a60ecd798a855",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
|
@ -201,6 +296,53 @@
|
||||||
"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": [
|
||||||
|
@ -208,11 +350,11 @@
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1733629314,
|
"lastModified": 1735443188,
|
||||||
"narHash": "sha256-U0vivjQFAwjNDYt49Krevs1murX9hKBFe2Ye0cHpgbU=",
|
"narHash": "sha256-AydPpRBh8+NOkrLylG7vTsHrGO2b5L7XkMEL5HlzcA8=",
|
||||||
"owner": "nix-community",
|
"owner": "nix-community",
|
||||||
"repo": "nix-index-database",
|
"repo": "nix-index-database",
|
||||||
"rev": "f1e477a7dd11e27e7f98b646349cd66bbabf2fb8",
|
"rev": "55ab1e1df5daf2476e6b826b69a82862dcbd7544",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
|
@ -221,6 +363,33 @@
|
||||||
"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": [
|
||||||
|
@ -243,11 +412,11 @@
|
||||||
},
|
},
|
||||||
"nixpkgs": {
|
"nixpkgs": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1733759999,
|
"lastModified": 1734119587,
|
||||||
"narHash": "sha256-463SNPWmz46iLzJKRzO3Q2b0Aurff3U1n0nYItxq7jU=",
|
"narHash": "sha256-AKU6qqskl0yf2+JdRdD0cfxX4b9x3KKV5RqA6wijmPM=",
|
||||||
"owner": "NixOS",
|
"owner": "NixOS",
|
||||||
"repo": "nixpkgs",
|
"repo": "nixpkgs",
|
||||||
"rev": "a73246e2eef4c6ed172979932bc80e1404ba2d56",
|
"rev": "3566ab7246670a43abd2ffa913cc62dad9cdf7d5",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
|
@ -257,13 +426,60 @@
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"nixpkgs-24-11": {
|
"nixpkgs-docs": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1733550349,
|
"lastModified": 1705957679,
|
||||||
"narHash": "sha256-NcGumB4Lr6KSDq+nIqXtNA8QwAQKDSZT7N9OTGWbTrs=",
|
"narHash": "sha256-Q8LJaVZGJ9wo33wBafvZSzapYsjOaNjP/pOnSiKVGHY=",
|
||||||
"owner": "NixOS",
|
"owner": "NixOS",
|
||||||
"repo": "nixpkgs",
|
"repo": "nixpkgs",
|
||||||
"rev": "e2605d0744c2417b09f8bf850dfca42fcf537d34",
|
"rev": "9a333eaa80901efe01df07eade2c16d183761fa3",
|
||||||
|
"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": {
|
||||||
|
@ -273,21 +489,60 @@
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"nixpkgs-lib": {
|
"nixpkgs_2": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1733620091,
|
"lastModified": 1735834308,
|
||||||
"narHash": "sha256-5WoMeCkaXqTZwwCNLRzyLxEJn8ISwjx4cNqLgqKwg9s=",
|
"narHash": "sha256-dklw3AXr3OGO4/XT1Tu3Xz9n/we8GctZZ75ZWVqAVhk=",
|
||||||
"owner": "nix-community",
|
"owner": "NixOS",
|
||||||
"repo": "nixpkgs.lib",
|
"repo": "nixpkgs",
|
||||||
"rev": "f4dc9a6c02e5e14d91d158522f69f6ab4194eb5b",
|
"rev": "6df24922a1400241dae323af55f30e4318a6ca65",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
"owner": "nix-community",
|
"owner": "NixOS",
|
||||||
"repo": "nixpkgs.lib",
|
"ref": "nixos-unstable",
|
||||||
|
"repo": "nixpkgs",
|
||||||
"type": "github"
|
"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": {
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"home-manager": [
|
"home-manager": [
|
||||||
|
@ -298,11 +553,11 @@
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1733858086,
|
"lastModified": 1735049224,
|
||||||
"narHash": "sha256-h2BDIDKiqgMpA6E+mu0RgMGy3FeM6k+EuJ9xgOQ1+zw=",
|
"narHash": "sha256-fWUd9kyXdepphJ7cCzOsuSo7l0kbFCkUqfgKqZyFZzE=",
|
||||||
"owner": "nix-community",
|
"owner": "nix-community",
|
||||||
"repo": "plasma-manager",
|
"repo": "plasma-manager",
|
||||||
"rev": "7e2010249529931a3848054d5ff0dbf24675ab68",
|
"rev": "d16bbded0ae452bc088489e7dca3ef58d8d1830b",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
|
@ -313,16 +568,36 @@
|
||||||
},
|
},
|
||||||
"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",
|
"nixpkgs": "nixpkgs_2",
|
||||||
"nixpkgs-24-11": "nixpkgs-24-11",
|
"nixpkgs-stable": "nixpkgs-stable",
|
||||||
"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"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"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": {
|
||||||
|
@ -345,6 +620,22 @@
|
||||||
"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,
|
||||||
|
@ -361,6 +652,36 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"systems_2": {
|
"systems_2": {
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1689347949,
|
||||||
|
"narHash": "sha256-12tWmuL2zgBgZkdoB6qXZsgJEH9LR3oUgpaQq2RbI80=",
|
||||||
|
"owner": "nix-systems",
|
||||||
|
"repo": "default-linux",
|
||||||
|
"rev": "31732fcf5e8fea42e59c2488ad31a0e651500f68",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "nix-systems",
|
||||||
|
"repo": "default-linux",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"systems_3": {
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1681028828,
|
||||||
|
"narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=",
|
||||||
|
"owner": "nix-systems",
|
||||||
|
"repo": "default",
|
||||||
|
"rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "nix-systems",
|
||||||
|
"repo": "default",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"systems_4": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1681028828,
|
"lastModified": 1681028828,
|
||||||
"narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=",
|
"narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=",
|
||||||
|
@ -377,18 +698,18 @@
|
||||||
},
|
},
|
||||||
"vscode-extensions": {
|
"vscode-extensions": {
|
||||||
"inputs": {
|
"inputs": {
|
||||||
"flake-compat": "flake-compat_2",
|
"flake-compat": "flake-compat_3",
|
||||||
"flake-utils": "flake-utils_3",
|
"flake-utils": "flake-utils_4",
|
||||||
"nixpkgs": [
|
"nixpkgs": [
|
||||||
"nixpkgs"
|
"nixpkgs"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1733795858,
|
"lastModified": 1735955120,
|
||||||
"narHash": "sha256-K595Q2PrZv2iiumdBkwM2G456T2lKsLD71bn/fbJiQ0=",
|
"narHash": "sha256-gmIt30sWS5U44ySODi3Q/89IV6ylt5P0eKayg0pXQTA=",
|
||||||
"owner": "nix-community",
|
"owner": "nix-community",
|
||||||
"repo": "nix-vscode-extensions",
|
"repo": "nix-vscode-extensions",
|
||||||
"rev": "66ced222ef9235f90dbdd754ede3d6476722aaa9",
|
"rev": "06a3dcdfa6e6c39695203c281cf6d2c800bd7649",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
|
@ -396,6 +717,27 @@
|
||||||
"repo": "nix-vscode-extensions",
|
"repo": "nix-vscode-extensions",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
"vscode-server": {
|
||||||
|
"inputs": {
|
||||||
|
"flake-utils": "flake-utils_5",
|
||||||
|
"nixpkgs": [
|
||||||
|
"nixpkgs"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"locked": {
|
||||||
|
"lastModified": 1729422940,
|
||||||
|
"narHash": "sha256-DlvJv33ml5UTKgu4b0HauOfFIoDx6QXtbqUF3vWeRCY=",
|
||||||
|
"owner": "nix-community",
|
||||||
|
"repo": "nixos-vscode-server",
|
||||||
|
"rev": "8b6db451de46ecf9b4ab3d01ef76e59957ff549f",
|
||||||
|
"type": "github"
|
||||||
|
},
|
||||||
|
"original": {
|
||||||
|
"owner": "nix-community",
|
||||||
|
"repo": "nixos-vscode-server",
|
||||||
|
"type": "github"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"root": "root",
|
"root": "root",
|
||||||
|
|
118
flake.nix
118
flake.nix
|
@ -2,9 +2,14 @@
|
||||||
description = "NixOS Configuration";
|
description = "NixOS Configuration";
|
||||||
|
|
||||||
inputs = {
|
inputs = {
|
||||||
# General NixOS config
|
# Nixpkgs
|
||||||
nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";
|
nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";
|
||||||
nixpkgs-24-11.url = "github:NixOS/nixpkgs/nixos-24.11";
|
nixpkgs-stable.url = "github:NixOS/nixpkgs/nixos-24.11"; # Used when unstable hydra fails
|
||||||
|
# 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";
|
||||||
|
@ -48,71 +53,68 @@
|
||||||
url = "github:nix-community/nix-vscode-extensions";
|
url = "github:nix-community/nix-vscode-extensions";
|
||||||
inputs.nixpkgs.follows = "nixpkgs";
|
inputs.nixpkgs.follows = "nixpkgs";
|
||||||
};
|
};
|
||||||
|
# VSCode server support
|
||||||
|
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@{ nixpkgs, home-manager, plasma-manager, nix-index-database, ... }: let
|
outputs = inputs@{ self, nixpkgs, home-manager, colmena, nix-on-droid, ... }: let
|
||||||
system = "x86_64-linux";
|
utils = import ./utils {
|
||||||
pkgs = nixpkgs.legacyPackages.${system};
|
inherit inputs;
|
||||||
secrets = import ./secrets.nix;
|
secrets = import ./secrets.nix;
|
||||||
|
};
|
||||||
in {
|
in {
|
||||||
nixosConfigurations.ty-nixos = nixpkgs.lib.nixosSystem {
|
# Setup home-manager configurations
|
||||||
inherit system;
|
# Mines Isengard
|
||||||
|
homeConfigurations.tyler_beckman = utils.createHomeManagerConfig {
|
||||||
modules = [
|
meta = {
|
||||||
./hosts/laptop
|
preset = "cli";
|
||||||
|
username = "tyler_beckman";
|
||||||
# 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 = true;
|
|
||||||
beets.enable = true;
|
|
||||||
firefox.enable = true;
|
|
||||||
thunderbird.enable = true;
|
|
||||||
rescrobbled.enable = true;
|
|
||||||
vscode.enable = true;
|
|
||||||
};
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
# Setup NixOS configurations
|
||||||
|
nixosConfigurations = {
|
||||||
|
"ty-nixos" = utils.createNixosSystem { entrypoint = ./hosts/laptop; };
|
||||||
|
"ty-laptop-server" = utils.createNixosSystem { entrypoint = ./hosts/laptop-server; };
|
||||||
|
};
|
||||||
|
|
||||||
|
# Setup colmena configurations
|
||||||
|
colmena = utils.createColmenaHive {
|
||||||
|
hostConfigs = [
|
||||||
|
{
|
||||||
|
name = "ty-nixos";
|
||||||
|
entrypoint = ./hosts/laptop;
|
||||||
|
allowLocal = true;
|
||||||
|
}
|
||||||
|
{
|
||||||
|
name = "ty-laptop-server";
|
||||||
|
entrypoint = ./hosts/laptop-server;
|
||||||
|
sshHost = "old-lenovo-laptop";
|
||||||
}
|
}
|
||||||
];
|
];
|
||||||
|
|
||||||
specialArgs = {
|
|
||||||
inherit inputs system secrets;
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
|
|
||||||
nixosConfigurations."ty-laptop-server" = nixpkgs.lib.nixosSystem {
|
# Setup nix-on-droid configurations
|
||||||
inherit system;
|
nixOnDroidConfigurations.default = utils.createDroidSystem { entrypoint = ./nix-on-droid/ty-pixel; };
|
||||||
|
|
||||||
modules = [
|
# Enable direct flake support for colmena
|
||||||
./hosts/laptop-server
|
colmenaHive = colmena.lib.makeHive self.outputs.colmena;
|
||||||
|
|
||||||
# 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;
|
|
||||||
};
|
|
||||||
}
|
|
||||||
];
|
|
||||||
|
|
||||||
specialArgs = {
|
|
||||||
inherit inputs system secrets;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
}
|
}
|
|
@ -1,4 +1,4 @@
|
||||||
{ lib, config, ... }:
|
{ ... }:
|
||||||
{
|
{
|
||||||
imports = [
|
imports = [
|
||||||
./email.nix
|
./email.nix
|
|
@ -1,9 +1,9 @@
|
||||||
{ lib, ty-home-manager-options, ... }:
|
{ lib, config, ... }:
|
||||||
{
|
{
|
||||||
accounts.email.accounts = lib.mkIf ty-home-manager-options.thunderbird.enable {
|
accounts.email.accounts = lib.mkIf config.meta.home-manager.email.enable {
|
||||||
PurelyMail = rec {
|
PurelyMail = let address = "ty@myriation.xyz"; in {
|
||||||
realName = "Tyler Beckman";
|
realName = "Tyler Beckman";
|
||||||
address = "ty@myriation.xyz";
|
inherit address;
|
||||||
userName = address;
|
userName = address;
|
||||||
primary = true;
|
primary = true;
|
||||||
|
|
||||||
|
@ -38,12 +38,12 @@
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
thunderbird.enable = true;
|
thunderbird.enable = config.meta.home-manager.email.thunderbird.enable;
|
||||||
};
|
};
|
||||||
|
|
||||||
Gmail = rec {
|
Gmail = let address = "tbeckman530@gmail.com"; in {
|
||||||
realName = "Tyler Beckman";
|
realName = "Tyler Beckman";
|
||||||
address = "tbeckman530@gmail.com";
|
inherit address;
|
||||||
userName = address;
|
userName = address;
|
||||||
flavor = "gmail.com";
|
flavor = "gmail.com";
|
||||||
|
|
||||||
|
@ -62,12 +62,12 @@
|
||||||
|
|
||||||
smtp.tls.useStartTls = false;
|
smtp.tls.useStartTls = false;
|
||||||
|
|
||||||
thunderbird.enable = true;
|
thunderbird.enable = config.meta.home-manager.email.thunderbird.enable;
|
||||||
};
|
};
|
||||||
|
|
||||||
School = rec {
|
School = let address = "tyler_beckman@mines.edu"; in {
|
||||||
realName = "Tyler Beckman";
|
realName = "Tyler Beckman";
|
||||||
address = "tyler_beckman@mines.edu";
|
inherit address;
|
||||||
userName = address;
|
userName = address;
|
||||||
flavor = "outlook.office365.com";
|
flavor = "outlook.office365.com";
|
||||||
|
|
||||||
|
@ -77,6 +77,15 @@
|
||||||
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;
|
||||||
|
};
|
||||||
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
|
@ -1,7 +1,14 @@
|
||||||
{ lib, secrets, ty-home-manager-options, ... }:
|
{ lib, secrets, config, pkgs, ... }:
|
||||||
{
|
{
|
||||||
programs.beets = lib.mkIf ty-home-manager-options.beets.enable {
|
programs.beets = lib.mkIf config.meta.home-manager.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";
|
22
home-manager/config/default.nix
Normal file
22
home-manager/config/default.nix
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
{ ... }:
|
||||||
|
{
|
||||||
|
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
|
||||||
|
];
|
||||||
|
}
|
|
@ -1,6 +1,6 @@
|
||||||
{ lib, ty-home-manager-options, ... }:
|
{ lib, config, ... }:
|
||||||
{
|
{
|
||||||
xdg.desktopEntries = lib.mkIf ty-home-manager-options.plasma.enable {
|
xdg.desktopEntries = lib.mkIf config.meta.home-manager.desktop.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" ];
|
|
@ -1,6 +1,6 @@
|
||||||
{ pkgs, inputs, system, lib, ty-home-manager-options, ... }:
|
{ pkgs, inputs, system, lib, config, ... }:
|
||||||
{
|
{
|
||||||
programs.firefox = lib.mkIf ty-home-manager-options.firefox.enable {
|
programs.firefox = lib.mkIf config.meta.home-manager.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://nixos.wiki/index.php?search={searchTerms}"; }];
|
urls = [{ template = "https://wiki.nixos.org/w/index.php?search={searchTerms}"; }];
|
||||||
iconUpdateURL = "https://nixos.wiki/favicon.png";
|
iconUpdateURL = "https://wiki.nixos.org/nixos.png";
|
||||||
updateInterval = 24 * 60 * 60 * 1000; # every day
|
updateInterval = 24 * 60 * 60 * 1000; # every day
|
||||||
definedAliases = [ "@nw" ];
|
definedAliases = [ "@nw" ];
|
||||||
};
|
};
|
|
@ -1,4 +1,4 @@
|
||||||
{ pkgs, ... }:
|
{ pkgs, config, ... }:
|
||||||
{
|
{
|
||||||
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 = pkgs.pinentry-qt;
|
pinentryPackage = if (config.meta.home-manager.desktop.enable) then pkgs.pinentry-qt else pkgs.pinentry-tty;
|
||||||
sshKeys = [
|
sshKeys = [
|
||||||
"817A829FB1FB95441156F93C7F4FD04ACDDE5E48 0"
|
"817A829FB1FB95441156F93C7F4FD04ACDDE5E48 0"
|
||||||
];
|
];
|
|
@ -1,12 +1,12 @@
|
||||||
{ pkgs, lib, config, ty-home-manager-options, ... }:
|
{ pkgs, lib, config, ... }:
|
||||||
{
|
{
|
||||||
config = lib.mkIf ty-home-manager-options.plasma.enable {
|
config = lib.mkIf config.meta.home-manager.desktop.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 = {
|
theme = lib.mkIf config.meta.home-manager.desktop.plasma.enable {
|
||||||
name = "Breeze-Dark";
|
name = "Breeze-Dark";
|
||||||
package = pkgs.kdePackages.breeze-gtk;
|
package = pkgs.kdePackages.breeze-gtk;
|
||||||
};
|
};
|
106
home-manager/config/packages.nix
Executable file
106
home-manager/config/packages.nix
Executable file
|
@ -0,0 +1,106 @@
|
||||||
|
{ 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
|
||||||
|
]);
|
||||||
|
}
|
|
@ -1,6 +1,6 @@
|
||||||
{ pkgs, lib, ty-home-manager-options, ... }:
|
{ pkgs, lib, config, ... }:
|
||||||
{
|
{
|
||||||
programs.plasma = lib.mkIf ty-home-manager-options.plasma.enable {
|
programs.plasma = lib.mkIf config.meta.home-manager.desktop.plasma.enable {
|
||||||
enable = true;
|
enable = true;
|
||||||
|
|
||||||
workspace = {
|
workspace = {
|
6
home-manager/config/prismlauncher.nix
Normal file
6
home-manager/config/prismlauncher.nix
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
{ config, lib, ... }:
|
||||||
|
{
|
||||||
|
programs.custom.prism-launcher = lib.mkIf config.meta.home-manager.desktop.enable {
|
||||||
|
enable = true;
|
||||||
|
};
|
||||||
|
}
|
23
home-manager/config/rescrobbled.nix
Normal file
23
home-manager/config/rescrobbled.nix
Normal file
|
@ -0,0 +1,23 @@
|
||||||
|
{ 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;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
|
@ -9,6 +9,7 @@
|
||||||
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";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
|
@ -5,6 +5,7 @@
|
||||||
./direnv.nix
|
./direnv.nix
|
||||||
./konsole.nix
|
./konsole.nix
|
||||||
./starship.nix
|
./starship.nix
|
||||||
|
./tldr.nix
|
||||||
./zsh.nix
|
./zsh.nix
|
||||||
];
|
];
|
||||||
}
|
}
|
|
@ -1,6 +1,6 @@
|
||||||
{ pkgs, lib, ty-home-manager-options, ... }:
|
{ pkgs, lib, config, ... }:
|
||||||
{
|
{
|
||||||
programs.konsole = lib.mkIf ty-home-manager-options.plasma.enable {
|
programs.konsole = lib.mkIf config.meta.home-manager.desktop.plasma.enable {
|
||||||
enable = true;
|
enable = true;
|
||||||
defaultProfile = "Primary";
|
defaultProfile = "Primary";
|
||||||
profiles = {
|
profiles = {
|
|
@ -57,10 +57,9 @@
|
||||||
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 = "[$ssh_symbol$hostname]($style)";
|
format = "[$hostname]($style)";
|
||||||
};
|
};
|
||||||
|
|
||||||
shell = {
|
shell = {
|
18
home-manager/config/shell/tldr.nix
Normal file
18
home-manager/config/shell/tldr.nix
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
{ ... }:
|
||||||
|
{
|
||||||
|
programs.tealdeer = {
|
||||||
|
enable = true;
|
||||||
|
|
||||||
|
settings = {
|
||||||
|
display = {
|
||||||
|
use_pager = false;
|
||||||
|
compact = false;
|
||||||
|
};
|
||||||
|
|
||||||
|
updates = {
|
||||||
|
auto_update = true;
|
||||||
|
auto_update_interval_hours = 24;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
|
@ -24,6 +24,17 @@
|
||||||
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
|
|
@ -1,6 +1,6 @@
|
||||||
{ pkgs, lib, ty-home-manager-options, ... }:
|
{ pkgs, lib, config, ... }:
|
||||||
{
|
{
|
||||||
programs.thunderbird = lib.mkIf ty-home-manager-options.thunderbird.enable {
|
programs.thunderbird = lib.mkIf config.meta.home-manager.email.thunderbird.enable {
|
||||||
enable = true;
|
enable = true;
|
||||||
package = pkgs.thunderbird-latest;
|
package = pkgs.thunderbird-latest;
|
||||||
profiles = {
|
profiles = {
|
|
@ -1,4 +1,4 @@
|
||||||
{ pkgs, ... }:
|
{ pkgs, lib, config, ... }:
|
||||||
{
|
{
|
||||||
programs.jujutsu = {
|
programs.jujutsu = {
|
||||||
enable = true;
|
enable = true;
|
||||||
|
@ -20,7 +20,7 @@
|
||||||
pager = "delta";
|
pager = "delta";
|
||||||
default-command = "log";
|
default-command = "log";
|
||||||
|
|
||||||
editor = "codium --wait";
|
editor = lib.mkIf (config.meta.home-manager.desktop.enable) "zeditor --wait";
|
||||||
|
|
||||||
diff = {
|
diff = {
|
||||||
format = "git";
|
format = "git";
|
|
@ -1,6 +1,6 @@
|
||||||
{ pkgs, inputs, system, lib, ty-home-manager-options, ... }:
|
{ pkgs, inputs, system, lib, config, ... }:
|
||||||
{
|
{
|
||||||
programs.vscode = lib.mkIf ty-home-manager-options.vscode.enable (
|
programs.vscode = lib.mkIf config.meta.home-manager.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,12 +38,15 @@
|
||||||
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
|
85
home-manager/config/zed.nix
Normal file
85
home-manager/config/zed.nix
Normal file
|
@ -0,0 +1,85 @@
|
||||||
|
{ 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;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
|
@ -1,85 +0,0 @@
|
||||||
{ 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" ];
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,31 +1,50 @@
|
||||||
{ inputs, system, secrets, lib, config, ... }:
|
{ inputs, system, secrets, config, lib, pkgs-stable, ... }:
|
||||||
{
|
{
|
||||||
options.ty-home-manager-options = {
|
imports = [ ./meta.nix ];
|
||||||
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.useGlobalPkgs = true;
|
home-manager = let
|
||||||
home-manager.useUserPackages = true;
|
entrypoint = {
|
||||||
home-manager.sharedModules = [
|
|
||||||
inputs.plasma-manager.homeManagerModules.plasma-manager
|
|
||||||
./custom-modules
|
|
||||||
];
|
|
||||||
home-manager.extraSpecialArgs = {
|
|
||||||
inherit inputs system secrets;
|
|
||||||
inherit (config) ty-home-manager-options;
|
|
||||||
};
|
|
||||||
home-manager.backupFileExtension = "backup";
|
|
||||||
|
|
||||||
home-manager.users.ty = {
|
|
||||||
imports = [
|
imports = [
|
||||||
./home.nix
|
# 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
|
||||||
|
./modules
|
||||||
|
];
|
||||||
|
# Inherit all of my nixos config custom arguments
|
||||||
|
extraSpecialArgs = {
|
||||||
|
inherit inputs system secrets pkgs-stable;
|
||||||
|
};
|
||||||
|
|
||||||
|
# Hopefully avoid file conflicts
|
||||||
|
backupFileExtension = "bak";
|
||||||
|
}
|
||||||
|
|
||||||
|
# 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;
|
||||||
|
})
|
||||||
|
];
|
||||||
};
|
};
|
||||||
}
|
}
|
|
@ -1,22 +0,0 @@
|
||||||
{ 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
|
|
||||||
];
|
|
||||||
}
|
|
74
home-manager/meta.nix
Normal file
74
home-manager/meta.nix
Normal file
|
@ -0,0 +1,74 @@
|
||||||
|
{ 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;
|
||||||
|
})
|
||||||
|
];
|
||||||
|
}
|
|
@ -1,6 +1,7 @@
|
||||||
{ ... }:
|
{ ... }:
|
||||||
{
|
{
|
||||||
imports = [
|
imports = [
|
||||||
|
./prismlauncher.nix
|
||||||
./rescrobbled.nix
|
./rescrobbled.nix
|
||||||
];
|
];
|
||||||
}
|
}
|
|
@ -1,63 +0,0 @@
|
||||||
{ 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
|
|
||||||
]));
|
|
||||||
}
|
|
82
home-manager/modules/prismlauncher.nix
Normal file
82
home-manager/modules/prismlauncher.nix
Normal file
|
@ -0,0 +1,82 @@
|
||||||
|
{ 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;
|
||||||
|
}) ];
|
||||||
|
};
|
||||||
|
}
|
|
@ -1,23 +1,85 @@
|
||||||
{ secrets, lib, ty-home-manager-options, ... }:
|
{ pkgs, lib, config, ... }:
|
||||||
{
|
let tomlFormat = pkgs.formats.toml { }; in {
|
||||||
config = lib.mkIf ty-home-manager-options.rescrobbled.enable {
|
options = {
|
||||||
services.custom.rescrobbled = let s = secrets.programs.rescrobbled; in lib.mkIf s.enable {
|
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;
|
enable = true;
|
||||||
|
|
||||||
session = s.lastfm.session;
|
source = tomlFormat.generate "rescrobbled-config" cfg.settings;
|
||||||
|
|
||||||
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;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
"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" ];
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
18
home-manager/standalone.nix
Normal file
18
home-manager/standalone.nix
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
{ 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}";
|
||||||
|
};
|
||||||
|
}
|
13
hosts/laptop-server/config/bootloader.nix
Normal file
13
hosts/laptop-server/config/bootloader.nix
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
{ ... }:
|
||||||
|
{
|
||||||
|
boot = {
|
||||||
|
loader = {
|
||||||
|
systemd-boot = {
|
||||||
|
enable = true;
|
||||||
|
};
|
||||||
|
efi.canTouchEfiVariables = true;
|
||||||
|
};
|
||||||
|
|
||||||
|
initrd.systemd.enable = true;
|
||||||
|
};
|
||||||
|
}
|
|
@ -1,12 +1,17 @@
|
||||||
{ ... }:
|
{ ... }:
|
||||||
{
|
{
|
||||||
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
|
||||||
];
|
];
|
||||||
}
|
}
|
|
@ -18,4 +18,7 @@
|
||||||
}
|
}
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
# Disable sleep on lid close (because server)
|
||||||
|
services.logind.lidSwitch = "ignore";
|
||||||
}
|
}
|
18
hosts/laptop-server/config/mounts.nix
Normal file
18
hosts/laptop-server/config/mounts.nix
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
{ ... }:
|
||||||
|
{
|
||||||
|
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" ];
|
||||||
|
}
|
57
hosts/laptop-server/config/networking.nix
Normal file
57
hosts/laptop-server/config/networking.nix
Normal file
|
@ -0,0 +1,57 @@
|
||||||
|
{ 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" ];
|
||||||
|
}
|
41
hosts/laptop-server/config/services/caddy/Caddyfile
Normal file
41
hosts/laptop-server/config/services/caddy/Caddyfile
Normal file
|
@ -0,0 +1,41 @@
|
||||||
|
# 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
|
||||||
|
}
|
||||||
|
}
|
26
hosts/laptop-server/config/services/caddy/default.nix
Normal file
26
hosts/laptop-server/config/services/caddy/default.nix
Normal file
|
@ -0,0 +1,26 @@
|
||||||
|
{ 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
|
||||||
|
};
|
||||||
|
}
|
10
hosts/laptop-server/config/services/default.nix
Normal file
10
hosts/laptop-server/config/services/default.nix
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
{ ... }:
|
||||||
|
{
|
||||||
|
imports = [
|
||||||
|
./networking.nix
|
||||||
|
# Individual services
|
||||||
|
./caddy
|
||||||
|
./jellyfin
|
||||||
|
./jellyseerr
|
||||||
|
];
|
||||||
|
}
|
31
hosts/laptop-server/config/services/jellyfin/default.nix
Normal file
31
hosts/laptop-server/config/services/jellyfin/default.nix
Normal file
|
@ -0,0 +1,31 @@
|
||||||
|
{ ... }:
|
||||||
|
{
|
||||||
|
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" ];
|
||||||
|
};
|
||||||
|
}
|
24
hosts/laptop-server/config/services/jellyseerr/default.nix
Normal file
24
hosts/laptop-server/config/services/jellyseerr/default.nix
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
{ ... }:
|
||||||
|
{
|
||||||
|
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" ];
|
||||||
|
};
|
||||||
|
}
|
41
hosts/laptop-server/config/services/networking.nix
Normal file
41
hosts/laptop-server/config/services/networking.nix
Normal file
|
@ -0,0 +1,41 @@
|
||||||
|
{ 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));
|
||||||
|
}
|
|
@ -22,4 +22,8 @@
|
||||||
|
|
||||||
# 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
|
||||||
}
|
}
|
8
hosts/laptop-server/config/vscode-server.nix
Normal file
8
hosts/laptop-server/config/vscode-server.nix
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
{ pkgs, ... }:
|
||||||
|
{
|
||||||
|
services.vscode-server = {
|
||||||
|
enable = true;
|
||||||
|
nodejsPackage = pkgs.nodejs-18_x;
|
||||||
|
installPath = "$HOME/.vscodium-server";
|
||||||
|
};
|
||||||
|
}
|
|
@ -8,8 +8,23 @@
|
||||||
|
|
||||||
{
|
{
|
||||||
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
|
||||||
./modules
|
./config
|
||||||
];
|
];
|
||||||
|
|
||||||
system.stateVersion = "24.11";
|
system.stateVersion = "24.11";
|
||||||
|
|
|
@ -1,7 +0,0 @@
|
||||||
{ ... }:
|
|
||||||
{
|
|
||||||
boot.loader = {
|
|
||||||
systemd-boot.enable = true;
|
|
||||||
efi.canTouchEfiVariables = true;
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -1,17 +0,0 @@
|
||||||
{ ... }:
|
|
||||||
{
|
|
||||||
networking.hostName = "ty-laptop-server";
|
|
||||||
|
|
||||||
# Enable firewall
|
|
||||||
networking.firewall.enable = true;
|
|
||||||
|
|
||||||
# Enable NetworkManager
|
|
||||||
networking.networkmanager.enable = true;
|
|
||||||
|
|
||||||
# Tailscale overlay network configuration
|
|
||||||
services.tailscale = {
|
|
||||||
enable = true;
|
|
||||||
useRoutingFeatures = "both";
|
|
||||||
openFirewall = true;
|
|
||||||
};
|
|
||||||
}
|
|
|
@ -4,4 +4,6 @@
|
||||||
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;
|
||||||
}
|
}
|
|
@ -1,6 +1,8 @@
|
||||||
{ 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
|
|
@ -2,6 +2,8 @@
|
||||||
{
|
{
|
||||||
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;
|
||||||
|
|
|
@ -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 = false; # Open source module is still very much beta
|
open = true; # Open source module is still very much beta
|
||||||
|
|
||||||
nvidiaSettings = true;
|
nvidiaSettings = true;
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
{ pkgs, inputs, ... }:
|
{ pkgs, inputs, system, ... }:
|
||||||
{
|
{
|
||||||
# Install system packages
|
# Install system packages
|
||||||
environment.systemPackages = with pkgs; [
|
environment.systemPackages = with pkgs; [
|
||||||
|
@ -6,8 +6,11 @@
|
||||||
wget
|
wget
|
||||||
curl
|
curl
|
||||||
neovim
|
neovim
|
||||||
home-manager
|
|
||||||
wl-clipboard-rs
|
wl-clipboard-rs
|
||||||
|
# Nix utilities
|
||||||
|
home-manager
|
||||||
|
inputs.colmena.packages."${system}".colmena
|
||||||
|
nvd
|
||||||
# VCS
|
# VCS
|
||||||
git
|
git
|
||||||
jujutsu
|
jujutsu
|
||||||
|
@ -18,12 +21,21 @@
|
||||||
# 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;
|
||||||
|
|
|
@ -19,4 +19,11 @@
|
||||||
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
|
||||||
}
|
}
|
|
@ -1,12 +1,36 @@
|
||||||
{ 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
|
||||||
./modules
|
./config
|
||||||
];
|
];
|
||||||
|
|
||||||
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;
|
||||||
}
|
}
|
25
nix-on-droid/ty-pixel/default.nix
Normal file
25
nix-on-droid/ty-pixel/default.nix
Normal file
|
@ -0,0 +1,25 @@
|
||||||
|
{ 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";
|
||||||
|
}
|
39
nix-on-droid/ty-pixel/environment.nix
Normal file
39
nix-on-droid/ty-pixel/environment.nix
Normal file
|
@ -0,0 +1,39 @@
|
||||||
|
{ 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 = "";
|
||||||
|
};
|
||||||
|
}
|
|
@ -19,6 +19,12 @@
|
||||||
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 = {
|
||||||
|
|
109
utils/default.nix
Normal file
109
utils/default.nix
Normal file
|
@ -0,0 +1,109 @@
|
||||||
|
{ 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};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
Loading…
Reference in a new issue