10 Commits

Author SHA1 Message Date
Hadi
acb7db87df Release v2.2.0
Former-commit-id: e6f66110f0
2024-08-19 20:32:10 +02:00
Hadi
0f5b7f60b6 Update
Former-commit-id: caaa500232
2024-08-19 19:42:20 +02:00
Hadi
d7264b0de1 Update
Former-commit-id: e27d43df71
2024-08-19 19:41:24 +02:00
Hadi
23b518381a Update
Former-commit-id: 79a69d245c
2024-08-19 19:36:21 +02:00
Hadi
8876aae16c Update
Former-commit-id: 849eb5dd11
2024-08-19 00:38:27 +02:00
Hadi
0ed5d1cf04 Update
Former-commit-id: 31ac58592e
2024-08-19 00:15:43 +02:00
Hadi
83decac5e9 Update
Former-commit-id: b9fda769bc
2024-08-18 23:57:00 +02:00
Hadi
9104494893 Update
Former-commit-id: 94c88e04f2
2024-08-18 23:56:48 +02:00
Hadi
10d1a73eeb Update
Former-commit-id: 9d74ac9d82
2024-08-18 23:52:21 +02:00
Hadi
307c0b5edd Update
Former-commit-id: a64c79ae22
2024-08-18 23:43:17 +02:00
47 changed files with 332 additions and 670 deletions

View File

@@ -1,8 +1,8 @@
[//]: # (Title: Nixy) [//]: # (Title: Nixy)
[//]: # (Description: Nixy is a Hyprland NixOS configuration with home-manager, secrets and custom theming all in one place. It's a simple way to manage your system configuration and dotfiles.) [//]: # (Description: Nixy is a Hyprland NixOS configuration with home-manager, secrets and custom theming all in one place. It's a simple way to manage your system configuration and dotfiles.)
[//]: # (Author: Hadi) [//]: # (Author: Hadi)
[//]: # (Date: 08/18/24) [//]: # (Date: 08/19/24)
[//]: # (Version: v2.0.1) [//]: # (Version: v2.1.0)
<div align="center"> <div align="center">
<img src="https://raw.githubusercontent.com/anotherhadi/nixy/main/docs/src/logo.png" width="100px" /> <img src="https://raw.githubusercontent.com/anotherhadi/nixy/main/docs/src/logo.png" width="100px" />
@@ -15,7 +15,7 @@
<br> <br>
<div align="center"> <div align="center">
<a href="https://github.com/anotherhadi/nixy"> <a href="https://github.com/anotherhadi/nixy">
<img src="https://img.shields.io/static/v1.svg?style=for-the-badge&label=Version&message=v2.0.1&colorA=181825&colorB=89b4fa&logo=githubactions&logoColor=89b4fa"/> <img src="https://img.shields.io/static/v1.svg?style=for-the-badge&label=Version&message=v2.1.0&colorA=181825&colorB=89b4fa&logo=githubactions&logoColor=89b4fa"/>
</a> </a>
<a href="https://github.com/anotherhadi/nixy/stargazers"> <a href="https://github.com/anotherhadi/nixy/stargazers">
<img src="https://img.shields.io/github/stars/anotherhadi/nixy?color=89b4fa&labelColor=181825&style=for-the-badge&logo=starship&logoColor=89b4fa"> <img src="https://img.shields.io/github/stars/anotherhadi/nixy?color=89b4fa&labelColor=181825&style=for-the-badge&logo=starship&logoColor=89b4fa">
@@ -54,7 +54,7 @@ It's a simple way to manage your system configuration and dotfiles.
- 🏠 `home` are the dotfiles and configuration files for the users - 🏠 `home` are the dotfiles and configuration files for the users
- 'programs' is a collection of apps configured with home-manager - 'programs' is a collection of apps configured with home-manager
- 'scripts' is a folder full of bash scripts (see [SCRIPTS.md](docs/SCRIPTS.md)) - 'scripts' is a folder full of bash scripts (see [SCRIPTS.md](docs/SCRIPTS.md))
- 'system' is some desktop environment like configuration - 'system' is some "desktop environment" configuration
- 'wallpapers' are... wallpapers - 'wallpapers' are... wallpapers
- 💻 `hosts` are the system configuration files - 💻 `hosts` are the system configuration files
- 'laptop' is my configuration for my laptop with Nvidia that you can copy - 'laptop' is my configuration for my laptop with Nvidia that you can copy

View File

@@ -8,11 +8,12 @@ The laptop configuration is used by an Omen 16 laptop w/ nvidia and an amd gpu r
The configurations files can be found in the `hosts/laptop` directory. The configurations files can be found in the `hosts/laptop` directory.
| Category | Name | | Category | Name |
|-----------------------------------------|----------------| | --------------------------------------- | -------------- |
| WM | Hyprland | | WM | Hyprland |
| | hyprlock | | | hyprlock |
| | hyprpaper | | | hyprpaper |
| | hypridle | | | hypridle |
| | hyprcursor |
| | wlogout | | | wlogout |
| Bar | waybar | | Bar | waybar |
| Terminal | kitty | | Terminal | kitty |
@@ -49,7 +50,6 @@ I exposed some services to the internet using a reverse proxy (Nginx) and cloudf
- Nextcloud - Nextcloud
- Vaultwarden - Vaultwarden
- Adguard Home - Adguard Home
- Unifi Controler
- Uptime Kuma - Uptime Kuma
- "Jackflix" - "Jackflix"
- Jellyfin, Transmission, *arr - Jellyfin, Transmission, *arr

View File

@@ -2,37 +2,37 @@
The list of the keybindings working on Hyprland: The list of the keybindings working on Hyprland:
| Description | Keybinding | Command | | Description | Keybinding |
| --------------------------- | ---------------------- | ------------------------------------------------------------------ | |-----------------------------|--------------------------|
| Switch Workspace | SUPER + {Number} | workspace {Number} | | Switch Workspace | SUPER + {Number} |
| Move app to Workspace | SUPER SHIFT + {Number} | movetoworkspace {Number} | | Move app to Workspace | SHIFT + SUPER + {Number} |
| Kitty | SUPER + RETURN | exec \${pkgs.kitty}/bin/kitty | | Kitty | SUPER + RETURN |
| Thunar | SUPER + E | exec \${pkgs.xfce.thunar}/bin/thunar | | Thunar | SUPER + E |
| Qutebrowser | SUPER + B | exec \${pkgs.qutebrowser}/bin/qutebrowser | | Qutebrowser | SUPER + B |
| Bitwarden | SUPER + K | exec \${pkgs.bitwarden}/bin/bitwarden | | Bitwarden | SUPER + K |
| Peaclock | SUPER + C | exec \${pkgs.kitty}/bin/kitty --class peaclock peaclock | | Peaclock | SUPER + C |
| Lock | SUPER + L | exec \${pkgs.hyprlock}/bin/hyprlock | | Lock | SUPER + L |
| Powermenu | SUPER + X | exec powermenu | | Powermenu | SUPER + X |
| Launcher | SUPER + SPACE | exec menu | | Launcher | SUPER + SPACE |
| Close window | SUPER + Q | killactive | | Close window | SUPER + Q |
| Toggle Floating | SUPER + T | togglefloating | | Toggle Floating | SUPER + T |
| Toggle Fullscreen | SUPER + F | fullscreen | | Toggle Fullscreen | SUPER + F |
| Move focus left | SUPER + left | movefocus l | | Move focus left | SUPER + left |
| Move focus Right | SUPER + right | movefocus r | | Move focus Right | SUPER + right |
| Move focus Up | SUPER + up | movefocus u | | Move focus Up | SUPER + up |
| Move focus Down | SUPER + down | movefocus d | | Move focus Down | SUPER + down |
| Screenshot window | SUPER + PRINT | exec screenshot window | | Screenshot window | SUPER + PRINT |
| Screenshot monitor | PRINT | exec screenshot monitor | | Screenshot monitor | PRINT |
| Screenshot region | SUPER SHIFT + PRINT | exec screenshot region | | Screenshot region | SHIFT + SUPER + PRINT |
| Screenshot region then edit | ALT PRINT | exec screenshot region swappy | | Screenshot region then edit | ALT PRINT |
| Turn off night shift | SUPER + F2 | exec night-shift-off | | Turn off night shift | SUPER + F2 |
| Turn on night shift | SUPER + F3 | exec night-shift-on | | Turn on night shift | SUPER + F3 |
| Choose sound output | SUPER + F5 | exec \${pkgs.kitty}/bin/kitty --class floating zsh -c sound-output | | Choose sound output | SUPER + F5 |
| Move Window (mouse) | SUPER + mouse:272 | movewindow | | Move Window (mouse) | SUPER + mouse:272 |
| Resize Window (mouse) | SUPER + R | resizewindow | | Resize Window (mouse) | SUPER + R |
| Toggle Mute | XF86AudioMute | exec sound-toggle | | Toggle Mute | XF86AudioMute |
| Lock when closing Lid | switch:Lid Switch | exec \${pkgs.hyprlock}/bin/hyprlock | | Lock when closing Lid | switch:Lid Switch |
| Sound Up | XF86AudioRaiseVolume | exec sound-up | | Sound Up | XF86AudioRaiseVolume |
| Sound Down | XF86AudioLowerVolume | exec sound-down | | Sound Down | XF86AudioLowerVolume |
| Brightness Up | XF86MonBrightnessUp | exec brightness-up | | Brightness Up | XF86MonBrightnessUp |
| Brightness Down | XF86MonBrightnessDown | exec brightness-down | | Brightness Down | XF86MonBrightnessDown |

View File

@@ -2,43 +2,33 @@
feel free to contribute <3 ([CONTRIBUTING.md](CONTRIBUTING.md)) feel free to contribute <3 ([CONTRIBUTING.md](CONTRIBUTING.md))
- [ ] Jackflix V2
- Backup Radarr, Prowlarr, Sonarr config
- [ ] Nixy - [ ] Nixy
- [~] Installation script ([install.sh](./scripts/install.sh) to test on a fresh install)
- [~] Variables-template with defaults
- [ ] Themes - [ ] Themes
- [ ] macOS theme
- [ ] Tofi (Wofi, but terminal based)
- [ ] Qutebrowser - [ ] Qutebrowser
- [ ] !!! Bitwarden integration (I need this.) - [ ] !!! Bitwarden integration (I need this.)
- [ ] Hyprland - [ ] Hyprland
- [-] Implement Hyprcursor (see home/system/hyprland/hyprcursor.nix: Not working, small cursor on some apps, big one on others) - [ ] Implement Hyprcursor
- [ ] Animations based on app name echo "Compresing png files..."
- [ ] Wofi: popin - [ ] wofi: popin
- [ ] Wlogout: fade in - [ ] wlogout: fade in
- [ ] Fix screenshots - [ ] Fix screenshots (screenshot region's border shows up in the screenshot, hyprshot jq error?)
- [ ] Fix hyprlock - [ ] Hyprlock themes
- [ ] Hyprlock tty theme - [ ] Hypridle fix: suspend not working?
- [ ] Nixvim - [ ] Nixvim
- [ ] Keymaps: - [ ] Keymaps:
- Trouble - Trouble
- Tagbar - Tagbar (actually not working)
- [ ] Disable background color for headlines.nvim for titles - [ ] Disable background color for headlines.nvim for titles
- [ ] Backup system for some folders ($home/dev, $home/pictures, ...) ## Server
- [ ] Exclude file pattern (nodes modules, ...)
- [ ] Auto backup when a specific usb key is plugged
- [ ] Pika backup?
- [ ] Markdown to pdf tool - [ ] Server configuration is actually broken, need to update with the new modules
- [ ] Jackflix V2
- [ ] Server - Backup Radarr, Prowlarr, Sonarr config
- [ ] Bitcoin-git - Take a look into buildarr
- [ ] ServerFetch: Neofetch like, but for server: CPU, RAM, Disk, Network, Uptime, status (check with uptime kuma API) - [ ] Bitcoin-git: to test
- [ ] Ntfy auth file - [ ] Ntfy auth file
- [ ] Launch transmission-openvpn on boot (see hosts/server/modules/jackflix/transmission.nix) - [ ] Secrets mode 0444: not secure

View File

@@ -28,8 +28,8 @@ Wallpapers can be found in the `/home/wallpapers` folder.
| mountains.png | ![mountains.png](../home/wallpapers/mountains.png) | | mountains.png | ![mountains.png](../home/wallpapers/mountains.png) |
| nix.png | ![nix.png](../home/wallpapers/nix.png) | | nix.png | ![nix.png](../home/wallpapers/nix.png) |
| problems.png | ![problems.png](../home/wallpapers/problems.png) | | problems.png | ![problems.png](../home/wallpapers/problems.png) |
| sea2.png | ![sea2.png](../home/wallpapers/sea2.png) |
| sea.png | ![sea.png](../home/wallpapers/sea.png) | | sea.png | ![sea.png](../home/wallpapers/sea.png) |
| see.png | ![see.png](../home/wallpapers/see.png) |
| space2.png | ![space2.png](../home/wallpapers/space2.png) | | space2.png | ![space2.png](../home/wallpapers/space2.png) |
| space.png | ![space.png](../home/wallpapers/space.png) | | space.png | ![space.png](../home/wallpapers/space.png) |
| street.png | ![street.png](../home/wallpapers/street.png) | | street.png | ![street.png](../home/wallpapers/street.png) |

View File

@@ -7,14 +7,18 @@ echo "Current tag: $TAG"
read -rp "Enter the new tag name: " NEW_TAG read -rp "Enter the new tag name: " NEW_TAG
echo "Compresing png files..." read -rp "Do you want to compress the png files? [y/N]: " COMPRESS_PNG
bash ./docs/scripts/compress_png.sh if [[ "$COMPRESS_PNG" == "y" || "$COMPRESS_PNG" == "Y" ]]; then
echo "Compresing png files..."
bash ./docs/scripts/compress_png.sh
fi
echo "Creating wallpapers preview..." echo "Creating wallpapers preview..."
bash ./docs/scripts/create_preview_wallpapers.sh bash ./docs/scripts/create_preview_wallpapers.sh
echo "Creating README.md..." echo "Creating README.md..."
bash ./docs/scripts/create_readme.sh bash ./docs/scripts/create_readme.sh
echo "Creating keybindings.md..." echo "Creating keybindings.md..."
bash ./docs/scripts/create_keybindings.sh bash ./docs/scripts/keybindings_to_markdown.sh
git add . git add .
git commit -m "Release $NEW_TAG" git commit -m "Release $NEW_TAG"

View File

@@ -17,7 +17,7 @@ It's a simple way to manage your system configuration and dotfiles.
- 🏠 `home` are the dotfiles and configuration files for the users - 🏠 `home` are the dotfiles and configuration files for the users
- 'programs' is a collection of apps configured with home-manager - 'programs' is a collection of apps configured with home-manager
- 'scripts' is a folder full of bash scripts (see [SCRIPTS.md](docs/SCRIPTS.md)) - 'scripts' is a folder full of bash scripts (see [SCRIPTS.md](docs/SCRIPTS.md))
- 'system' is some desktop environment like configuration - 'system' is some "desktop environment" configuration
- 'wallpapers' are... wallpapers - 'wallpapers' are... wallpapers
- 💻 `hosts` are the system configuration files - 💻 `hosts` are the system configuration files
- 'laptop' is my configuration for my laptop with Nvidia that you can copy - 'laptop' is my configuration for my laptop with Nvidia that you can copy

97
flake.lock generated
View File

@@ -92,6 +92,22 @@
"url": "https://flakehub.com/f/edolstra/flake-compat/1.tar.gz" "url": "https://flakehub.com/f/edolstra/flake-compat/1.tar.gz"
} }
}, },
"flake-compat_2": {
"flake": false,
"locked": {
"lastModified": 1696426674,
"narHash": "sha256-kvjfFW7WAETZlt09AgDn1MrtKzP7t90Vf7vypd3OL1U=",
"owner": "edolstra",
"repo": "flake-compat",
"rev": "0f9255e01c2351cc7d116c072cb317785dd33b33",
"type": "github"
},
"original": {
"owner": "edolstra",
"repo": "flake-compat",
"type": "github"
}
},
"flake-parts": { "flake-parts": {
"inputs": { "inputs": {
"nixpkgs-lib": [ "nixpkgs-lib": [
@@ -149,24 +165,6 @@
"type": "github" "type": "github"
} }
}, },
"flake-utils_3": {
"inputs": {
"systems": "systems_4"
},
"locked": {
"lastModified": 1685518550,
"narHash": "sha256-o2d0KcvaXzTrPRIo0kOLV0/QXHhDQ5DTi+OxcjO8xqY=",
"owner": "numtide",
"repo": "flake-utils",
"rev": "a1720a10a6cfe8234c0e93907ffe81be440f4cef",
"type": "github"
},
"original": {
"owner": "numtide",
"repo": "flake-utils",
"type": "github"
}
},
"git-hooks": { "git-hooks": {
"inputs": { "inputs": {
"flake-compat": [ "flake-compat": [
@@ -523,22 +521,6 @@
"type": "github" "type": "github"
} }
}, },
"nixpkgs_4": {
"locked": {
"lastModified": 1686020360,
"narHash": "sha256-Wee7lIlZ6DIZHHLiNxU5KdYZQl0iprENXa/czzI6Cj4=",
"owner": "NixOS",
"repo": "nixpkgs",
"rev": "4729ffac6fd12e26e5a8de002781ffc49b0e94b7",
"type": "github"
},
"original": {
"owner": "NixOS",
"ref": "nixos-unstable",
"repo": "nixpkgs",
"type": "github"
}
},
"nixvim": { "nixvim": {
"inputs": { "inputs": {
"devshell": "devshell", "devshell": "devshell",
@@ -567,21 +549,6 @@
"type": "github" "type": "github"
} }
}, },
"nurpkgs": {
"locked": {
"lastModified": 1724012881,
"narHash": "sha256-lqn4UX+tvtwOmBZ2Dxh6euXKNcXGEYqPolEdjtONDVY=",
"owner": "nix-community",
"repo": "NUR",
"rev": "8c7136cb22fd96cde881225863b450df75876ebc",
"type": "github"
},
"original": {
"owner": "nix-community",
"repo": "NUR",
"type": "github"
}
},
"nuschtosSearch": { "nuschtosSearch": {
"inputs": { "inputs": {
"flake-utils": "flake-utils_2", "flake-utils": "flake-utils_2",
@@ -624,7 +591,6 @@
"nixos-hardware": "nixos-hardware", "nixos-hardware": "nixos-hardware",
"nixpkgs": "nixpkgs_3", "nixpkgs": "nixpkgs_3",
"nixvim": "nixvim", "nixvim": "nixvim",
"nurpkgs": "nurpkgs",
"sops-nix": "sops-nix", "sops-nix": "sops-nix",
"spicetify-nix": "spicetify-nix" "spicetify-nix": "spicetify-nix"
} }
@@ -700,19 +666,21 @@
}, },
"spicetify-nix": { "spicetify-nix": {
"inputs": { "inputs": {
"flake-utils": "flake-utils_3", "flake-compat": "flake-compat_2",
"nixpkgs": "nixpkgs_4" "nixpkgs": [
"nixpkgs"
]
}, },
"locked": { "locked": {
"lastModified": 1704167711, "lastModified": 1723954588,
"narHash": "sha256-kFDq+kf/Di/P8bq5sUP8pVwRkrSVrABksBjMPmLic3s=", "narHash": "sha256-ZTy0Cfv0WLmsZJnFw3OPefzpFogIZU196twuv2B4iLU=",
"owner": "the-argus", "owner": "Gerg-L",
"repo": "spicetify-nix", "repo": "spicetify-nix",
"rev": "1325416f951d6a82cfddb1289864ad782e2b87c4", "rev": "e8c7709abf6fa96b42b8a175583703d6bad07f21",
"type": "github" "type": "github"
}, },
"original": { "original": {
"owner": "the-argus", "owner": "Gerg-L",
"repo": "spicetify-nix", "repo": "spicetify-nix",
"type": "github" "type": "github"
} }
@@ -762,21 +730,6 @@
"type": "github" "type": "github"
} }
}, },
"systems_4": {
"locked": {
"lastModified": 1681028828,
"narHash": "sha256-Vy1rq5AaRuLzOxct8nz4T6wlgyUR7zLU309k9mBC768=",
"owner": "nix-systems",
"repo": "default",
"rev": "da67096a3b9bf56a91d16901293e51ba5b49a27e",
"type": "github"
},
"original": {
"owner": "nix-systems",
"repo": "default",
"type": "github"
}
},
"treefmt-nix": { "treefmt-nix": {
"inputs": { "inputs": {
"nixpkgs": [ "nixpkgs": [

View File

@@ -16,35 +16,28 @@
inputs.nixpkgs.follows = "nixpkgs"; inputs.nixpkgs.follows = "nixpkgs";
}; };
apple-fonts.url = "github:Lyndeno/apple-fonts.nix"; apple-fonts.url = "github:Lyndeno/apple-fonts.nix";
spicetify-nix.url = "github:the-argus/spicetify-nix"; spicetify-nix = {
url = "github:Gerg-L/spicetify-nix";
inputs.nixpkgs.follows = "nixpkgs";
};
sops-nix = { sops-nix = {
url = "github:Mic92/sops-nix"; url = "github:Mic92/sops-nix";
inputs.nixpkgs.follows = "nixpkgs"; inputs.nixpkgs.follows = "nixpkgs";
}; };
hyprland.url = "git+https://github.com/hyprwm/Hyprland?submodules=1"; hyprland.url = "git+https://github.com/hyprwm/Hyprland?submodules=1";
nurpkgs.url = "github:nix-community/NUR";
nixos-hardware.url = "github:NixOS/nixos-hardware/master"; nixos-hardware.url = "github:NixOS/nixos-hardware/master";
}; };
outputs = inputs@{ nixpkgs, ... }: { outputs = inputs@{ nixpkgs, ... }: {
nixosConfigurations = { nixosConfigurations = {
nixy = nixpkgs.lib.nixosSystem { # CHANGE ME nixy = nixpkgs.lib.nixosSystem { # CHANGEME
system = "x86_64-linux"; system = "x86_64-linux";
modules = [ modules = [
./hosts/laptop/configuration.nix # CHANGE ME { _module.args = { inherit inputs; }; }
inputs.nixos-hardware.nixosModules.omen-16-n0005ne # CHANGE ME inputs.nixos-hardware.nixosModules.omen-16-n0280nd # CHANGEME
inputs.home-manager.nixosModules.home-manager inputs.home-manager.nixosModules.home-manager
{ ./hosts/laptop/configuration.nix # CHANGEME
nixpkgs.overlays = [ inputs.nurpkgs.overlay ];
_module.args = { inherit inputs; };
home-manager = {
useGlobalPkgs = true;
useUserPackages = true;
users."hadi" = import ./hosts/laptop/home.nix; # CHANGE ME
extraSpecialArgs = { inherit inputs; };
};
}
]; ];
}; };

View File

@@ -60,7 +60,7 @@
ga = "git add"; ga = "git add";
gc = "git commit"; gc = "git commit";
gcm = "git commit -m"; gcm = "git commit -m";
gcu = "git commit -am 'Update'"; gcu = "git add . && git commit -m 'Update'";
gp = "git push"; gp = "git push";
gpl = "git pull"; gpl = "git pull";
gs = "git status"; gs = "git status";

View File

@@ -1,5 +1,5 @@
{ pkgs, config, lib, inputs, ... }: { pkgs, config, lib, inputs, ... }:
let spicePkgs = inputs.spicetify-nix.packages.${pkgs.system}.default; let spicePkgs = inputs.spicetify-nix.legacyPackages.${pkgs.system};
in { in {
imports = [ inputs.spicetify-nix.homeManagerModules.default ]; imports = [ inputs.spicetify-nix.homeManagerModules.default ];
@@ -33,6 +33,7 @@ in {
lastfm lastfm
historyShortcut historyShortcut
hidePodcasts hidePodcasts
adblock
fullAppDisplay fullAppDisplay
shuffle shuffle
]; ];

View File

@@ -12,6 +12,5 @@
./battery ./battery
./compress ./compress
./misc ./misc
./tofi
]; ];
} }

View File

@@ -1,7 +1,6 @@
{ pkgs, ... }: { pkgs, ... }:
let let
# TODO: Broken - hypshot not working (jq error)
screenshot = pkgs.writeShellScriptBin "screenshot" '' screenshot = pkgs.writeShellScriptBin "screenshot" ''
if [[ $2 == "swappy" ]];then if [[ $2 == "swappy" ]];then
folder="/tmp" folder="/tmp"

View File

@@ -1,62 +0,0 @@
{ pkgs, config, ... }:
let
tofi = pkgs.writeShellScriptBin "tofi" ''
hyprexec="hyprctl dispatch exec"
function exec() {
$@
}
function ui(){
DEFAULT_ICON="󰘳"
# "icon;name;command"[]
apps=(
";Nixy;nixy"
";Nerdfont FZF;nerdfont-fzf"
";Brightness Up;brightness-up"
";Brightness Down;brightness-down"
";Sound Up;sound-up"
";Sound Down;sound-down"
";Sound Toggle Mute;sound-toggle"
";Sound Change Output;sound-output"
";Caffeine;caffeine"
";Night Shift Toggle;night-shift-toggle"
";Firefox;$hyprexec firefox"
";Qutebrowser;$hyprexec qutebrowser"
";Kitty;$hyprexec kitty"
";Thunar;$hyprexec thunar"
";Powermenu;powermenu"
";Wofi;menu"
";Lock;lock"
";Bitwarden;$hyprexec bitwarden"
";Clock; peaclock"
";Nextcloud;$hyprexec nextcloud"
";Spotify;$hyprexec spotify"
";Btop;btop"
";Cava;cava"
";Discord;$hyprexec discord"
";Vlc;$hyprexec vlc"
";Obsidian;$hyprexec obsidian"
)
# Apply default icons if empty:
for i in "''${!apps[@]}"; do
apps[i]=$(echo "''${apps[i]}" | sed 's/^;/'$DEFAULT_ICON';/')
done
fzf_result=$(printf "%s\n" "''${apps[@]}" | awk -F ';' '{print $1" "$2}' | fzf)
[[ -z $fzf_result ]] && exit 0
fzf_result=''${fzf_result/ /;}
line=$(printf "%s\n" "''${apps[@]}" | grep "$fzf_result")
command=$(echo "$line" | sed 's/^[^;]*;//;s/^[^;]*;//')
exec "$command"
exit 0
}
ui
'';
in { home.packages = [ tofi ]; }

View File

@@ -6,7 +6,9 @@
home.packages = with pkgs; [ home.packages = with pkgs; [
hyprshot hyprshot
hyprpicker hyprpicker
# hyprcursor swappy
imv
wf-recorder
xdg-desktop-portal-hyprland xdg-desktop-portal-hyprland
wlr-randr wlr-randr
wl-clipboard wl-clipboard
@@ -15,7 +17,6 @@
wlsunset wlsunset
xwayland xwayland
xdg-desktop-portal-gtk xdg-desktop-portal-gtk
wlroots
qt5ct qt5ct
libva libva
dconf dconf
@@ -102,11 +103,13 @@
]; ];
env = [ env = [
"LIBVA_DRIVER_NAME,nvidia"
"XDG_SESSION_TYPE,wayland" "XDG_SESSION_TYPE,wayland"
"XDG_CURRENT_DESKTOP,Hyprland" "XDG_CURRENT_DESKTOP,Hyprland"
"MOZ_ENABLE_WAYLAND,1"
"ANKI_WAYLAND,1"
"DISABLE_QT5_COMPAT,0"
"NIXOS_OZONE_WL,1"
"XDG_SESSION_TYPE,wayland" "XDG_SESSION_TYPE,wayland"
"GBM_BACKEND,nvidia-drm"
"XDG_SESSION_DESKTOP,Hyprland" "XDG_SESSION_DESKTOP,Hyprland"
"QT_AUTO_SCREEN_SCALE_FACTOR,1" "QT_AUTO_SCREEN_SCALE_FACTOR,1"
"QT_QPA_PLATFORM=wayland,xcb" "QT_QPA_PLATFORM=wayland,xcb"
@@ -115,10 +118,6 @@
"GTK_THEME,FlatColor:dark" "GTK_THEME,FlatColor:dark"
"GTK2_RC_FILES,/home/hadi/.local/share/themes/FlatColor/gtk-2.0/gtkrc" "GTK2_RC_FILES,/home/hadi/.local/share/themes/FlatColor/gtk-2.0/gtkrc"
"NVD_BACKEND,direct" "NVD_BACKEND,direct"
#"WLR_DRM_DEVICES,$HOME/.config/hypr/card"
# "HYPRCURSOR_THEME,macOS"
# "HYPRCURSOR_SIZE,16"
# "XCURSOR_SIZE,16"
]; ];
cursor = { no_hardware_cursors = true; }; cursor = { no_hardware_cursors = true; };

View File

@@ -8,7 +8,7 @@
timeout = 600; timeout = 600;
on-timeout = pkgs.hyprlock + "/bin/hyprlock"; on-timeout = pkgs.hyprlock + "/bin/hyprlock";
} }
# FIXME
# { # {
# timeout = 660; # timeout = 660;
# on-timeout = "systemctl suspend"; # on-timeout = "systemctl suspend";

View File

@@ -6,7 +6,6 @@
programs.waybar = { programs.waybar = {
enable = true; enable = true;
# package = inputs.waybar.packages."${pkgs.system}".waybar;
settings = { settings = {
mainBar = { mainBar = {
layer = config.var.theme.waybar.position; layer = config.var.theme.waybar.position;

View File

@@ -1,160 +1,28 @@
{ pkgs, config, ... }: { { config, ... }: {
imports = [ imports = [
./hardware-configuration.nix
../modules/fonts.nix ../modules/fonts.nix
../modules/nvidia.nix ../modules/nvidia.nix
# ../modules/prime.nix # ../modules/prime.nix
../modules/zsh.nix
../modules/tuigreet.nix ../modules/tuigreet.nix
../modules/auto-upgrade.nix
../modules/timezone.nix
../modules/usb.nix ../modules/usb.nix
../modules/systemd-boot.nix
../modules/users.nix
../modules/audio.nix
../modules/bluetooth.nix
../modules/tailscale.nix
../modules/nix.nix
../modules/network-manager.nix
../modules/home-manager.nix
../modules/utils.nix
./hardware-configuration.nix
./variables.nix ./variables.nix
]; ];
# Bootloader. home-manager.users."${config.var.username}" = import ./home.nix;
boot = {
loader.efi.canTouchEfiVariables = true;
loader.systemd-boot = {
enable = true;
consoleMode = "auto";
};
tmp.cleanOnBoot = true;
kernelPackages =
pkgs.linuxPackages_latest; # _zen, _hardened, _rt, _rt_latest, etc.
};
# Networking
networking.networkmanager.enable = true;
networking.hostName = config.var.hostname;
systemd.services.NetworkManager-wait-online.enable = false;
# Timezone and locale
time.timeZone = config.var.timeZone;
i18n.defaultLocale = config.var.defaultLocale;
i18n.extraLocaleSettings = {
LC_ADDRESS = config.var.extraLocale;
LC_IDENTIFICATION = config.var.extraLocale;
LC_MEASUREMENT = config.var.extraLocale;
LC_MONETARY = config.var.extraLocale;
LC_NAME = config.var.extraLocale;
LC_NUMERIC = config.var.extraLocale;
LC_PAPER = config.var.extraLocale;
LC_TELEPHONE = config.var.extraLocale;
LC_TIME = config.var.extraLocale;
};
# Users
users.users.${config.var.username} = {
isNormalUser = true;
description = "${config.var.username} account";
extraGroups = [ "networkmanager" "wheel" ];
};
services = {
tailscale.enable = config.var.tailscale;
xserver = {
enable = true;
xkb.layout = config.var.keyboardLayout;
xkb.variant = "";
};
blueman.enable = true;
gnome.gnome-keyring.enable = true;
};
console.keyMap = config.var.keyboardLayout;
# Shell
programs.zsh = {
enable = true;
loginShellInit = ''
dbus-update-activation-environment --systemd DISPLAY
'';
};
users.defaultUserShell = pkgs.zsh;
hardware.bluetooth = {
enable = true;
powerOnBoot = true;
};
# Set environment variables
environment.variables = {
XDG_DATA_HOME = "$HOME/.local/share";
PASSWORD_STORE_DIR = "$HOME/.local/share/password-store";
MOZ_ENABLE_WAYLAND = "1";
EDITOR = "nvim";
ANKI_WAYLAND = "1";
DISABLE_QT5_COMPAT = "0";
NIXOS_OZONE_WL = "1";
};
security.rtkit.enable = true;
hardware.pulseaudio.enable = false;
services.pipewire = {
enable = true;
alsa.enable = true;
alsa.support32Bit = true;
pulse.enable = true;
jack.enable = true;
wireplumber = {
enable = true;
extraConfig = {
"10-disable-camera" = {
"wireplumber.profiles" = { main."monitor.libcamera" = "disabled"; };
};
};
};
};
nix = {
extraOptions = ''
warn-dirty = false
'';
settings = {
auto-optimise-store = true;
experimental-features = [ "nix-command" "flakes" ];
substituters = [ "https://hyprland.cachix.org" ];
trusted-public-keys = [
"hyprland.cachix.org-1:a7pgxzMz7+chwVL3/pzj6jIBMioiJM7ypFP8PwtkuGc="
];
};
gc = if config.var.autoGarbageCollector then {
automatic = true;
persistent = true;
dates = "weekly";
options = "--delete-older-than 7d";
} else
{ };
};
nixpkgs.config.allowUnfree = true;
environment.systemPackages = with pkgs; [ networkmanagerapplet ];
nixpkgs.config.permittedInsecurePackages = [ "electron-25.9.0" ];
system.autoUpgrade = if config.var.autoUpgrade then {
enable = true;
dates = "04:00";
flake = "${config.var.configDirectory}";
flags = [ "--update-input" "nixpkgs" "--commit-lock-file" ];
allowReboot = false;
} else
{ };
xdg.portal = {
enable = true;
configPackages = with pkgs; [ xdg-desktop-portal-gtk ];
};
services.libinput.enable = true;
programs.dconf.enable = true;
# Faster rebuilding
documentation = {
enable = true;
doc.enable = false;
man.enable = true;
dev.enable = false;
};
services.dbus.enable = true;
# Don't touch this # Don't touch this
system.stateVersion = "24.05"; system.stateVersion = "24.05";

View File

@@ -10,8 +10,7 @@
../../home/programs/nextcloud ../../home/programs/nextcloud
../../home/programs/nvim ../../home/programs/nvim
../../home/programs/qutebrowser ../../home/programs/qutebrowser
# ../../home/programs/spicetify # TODO: Fix ../../home/programs/spicetify
../../home/programs/zathura
../../home/programs/shell ../../home/programs/shell
../../home/programs/fetch ../../home/programs/fetch
../../home/programs/lf ../../home/programs/lf
@@ -24,6 +23,7 @@
# System (Desktop environment like stuff) # System (Desktop environment like stuff)
../../home/system/dunst ../../home/system/dunst
../../home/system/gtk ../../home/system/gtk
../../home/system/zathura
../../home/system/hyprland ../../home/system/hyprland
../../home/system/waybar ../../home/system/waybar
../../home/system/wlogout ../../home/system/wlogout
@@ -39,10 +39,7 @@
inherit (config.var) homeDirectory; inherit (config.var) homeDirectory;
packages = with pkgs; [ packages = with pkgs; [
swappy
imv
discord discord
obsidian
xfce.thunar xfce.thunar
bitwarden bitwarden
vlc vlc
@@ -55,32 +52,16 @@
nodejs nodejs
python3 python3
jq jq
git-ignore
nurl nurl
prefetch-npm-deps prefetch-npm-deps
figlet figlet
# Infosec
exegol
# Utils # Utils
fd
bc
gcc
blueman
zip zip
unzip unzip
xdg_utils
wget
curl
wf-recorder
glow glow
nwg-displays
wireguard-tools
bitwarden-cli
optipng optipng
pfetch pfetch
usbutils
pandoc pandoc
# Just cool # Just cool
@@ -91,7 +72,6 @@
# Backup # Backup
vscode vscode
tor-browser
firefox firefox
neovide neovide
]; ];
@@ -102,6 +82,7 @@
source = ../../home/wallpapers; source = ../../home/wallpapers;
}; };
# Don't touch this
stateVersion = "24.05"; stateVersion = "24.05";
}; };

View File

@@ -5,7 +5,7 @@
sops = { sops = {
age.keyFile = "/home/hadi/.config/sops/age/keys.txt"; age.keyFile = "/home/hadi/.config/sops/age/keys.txt";
defaultSopsFile = ./laptop.yaml; defaultSopsFile = ./secrets.yaml;
secrets = { secrets = {
sshconfig = { path = "/home/hadi/.ssh/config"; }; sshconfig = { path = "/home/hadi/.ssh/config"; };
github-key = { path = "/home/hadi/.ssh/github"; }; github-key = { path = "/home/hadi/.ssh/github"; };

View File

@@ -18,16 +18,24 @@
email = "112569860+anotherhadi@users.noreply.github.com"; email = "112569860+anotherhadi@users.noreply.github.com";
}; };
stateVersion = "24.05";
autoUpgrade = false; autoUpgrade = false;
autoGarbageCollector = false; autoGarbageCollector = false;
# SOPS
# Sops is a tool to store secrets in git repositories encrypted with GPG.
# change the sops configuration if you want to enable that: # change the sops configuration if you want to enable that:
sops = true; sops = true;
# change the nvim's obsidian configuration if you want to enable that:
obsidian = true; # Enable tailscale
tailscale = true; tailscale = true;
# USBGuard
# If usbguard enabled: set yours pref USB devices (change {id} to your trusted USB device), use `lsusb` command (from usbutils package) to get list
# of all connected USB devices including integrated devices like camera, bluetooth, wifi, etc. with their IDs or just disable `usbguard`
# allow id {id} # device 1...
usbguard = false;
usbguardRules = "";
theme = import ../themes/nixy.nix; # select your theme here theme = import ../themes/nixy.nix; # select your theme here
}; };
} }

20
hosts/modules/audio.nix Normal file
View File

@@ -0,0 +1,20 @@
{
security.rtkit.enable = true;
hardware.pulseaudio.enable = false;
services.pipewire = {
enable = true;
alsa.enable = true;
alsa.support32Bit = true;
pulse.enable = true;
jack.enable = true;
wireplumber = {
enable = true;
extraConfig = {
"10-disable-camera" = {
"wireplumber.profiles" = { main."monitor.libcamera" = "disabled"; };
};
};
};
};
}

View File

@@ -0,0 +1,9 @@
{ config, ... }: {
system.autoUpgrade = {
enable = config.var.autoUpgrade;
dates = "04:00";
flake = "${config.var.configDirectory}";
flags = [ "--update-input" "nixpkgs" "--commit-lock-file" ];
allowReboot = false;
};
}

View File

@@ -0,0 +1,9 @@
{ pkgs, ... }: {
environment.systemPackages = with pkgs; [ blueman ];
hardware.bluetooth = {
enable = true;
powerOnBoot = true;
};
services.blueman.enable = true;
}

View File

@@ -28,7 +28,6 @@
enableDefaultPackages = false; enableDefaultPackages = false;
# this fixes emoji stuff
fontconfig = { fontconfig = {
defaultFonts = { defaultFonts = {
monospace = [ "FiraCode Nerd Font Mono" "Noto Color Emoji" ]; monospace = [ "FiraCode Nerd Font Mono" "Noto Color Emoji" ];
@@ -37,6 +36,5 @@
emoji = [ "Noto Color Emoji" ]; emoji = [ "Noto Color Emoji" ];
}; };
}; };
}; };
} }

View File

@@ -0,0 +1,7 @@
{ inputs, ... }: {
home-manager = {
useGlobalPkgs = true;
useUserPackages = true;
extraSpecialArgs = { inherit inputs; };
};
}

View File

@@ -0,0 +1,6 @@
{ pkgs, ... }: {
networking.networkmanager.enable = true;
systemd.services.NetworkManager-wait-online.enable = false;
environment.systemPackages = with pkgs; [ networkmanagerapplet ];
}

22
hosts/modules/nix.nix Normal file
View File

@@ -0,0 +1,22 @@
{ config, ... }: {
nixpkgs.config.allowUnfree = true;
nix = {
extraOptions = ''
warn-dirty = false
'';
settings = {
auto-optimise-store = true;
experimental-features = [ "nix-command" "flakes" ];
substituters = [ "https://hyprland.cachix.org" ];
trusted-public-keys = [
"hyprland.cachix.org-1:a7pgxzMz7+chwVL3/pzj6jIBMioiJM7ypFP8PwtkuGc="
];
};
gc = {
automatic = config.var.autoGarbageCollector;
persistent = true;
dates = "weekly";
options = "--delete-older-than 7d";
};
};
}

View File

@@ -1,7 +1,7 @@
{ lib, pkgs, config, ... }: { lib, pkgs, config, ... }:
let let
nvidiaDriverChannel = nvidiaDriverChannel =
config.boot.kernelPackages.nvidiaPackages.beta; # stable, latest, etc. config.boot.kernelPackages.nvidiaPackages.beta; # stable, latest, beta, etc.
in { in {
# Load nvidia driver for Xorg and Wayland # Load nvidia driver for Xorg and Wayland
services.xserver.videoDrivers = services.xserver.videoDrivers =
@@ -14,7 +14,6 @@ in {
]; ];
environment.variables = { environment.variables = {
GBM_BACKEND = "nvidia-drm"; GBM_BACKEND = "nvidia-drm";
WLR_NO_HARDWARE_CURSORS = "1";
LIBVA_DRIVER_NAME = "nvidia"; # hardware acceleration LIBVA_DRIVER_NAME = "nvidia"; # hardware acceleration
__GLX_VENDOR_LIBRARY_NAME = "nvidia"; __GLX_VENDOR_LIBRARY_NAME = "nvidia";
}; };

View File

@@ -0,0 +1,12 @@
{ pkgs, ... }: {
boot = {
loader.efi.canTouchEfiVariables = true;
loader.systemd-boot = {
enable = true;
consoleMode = "auto";
};
tmp.cleanOnBoot = true;
kernelPackages =
pkgs.linuxPackages_latest; # _zen, _hardened, _rt, _rt_latest, etc.
};
}

View File

@@ -0,0 +1 @@
{ config, ... }: { services.tailscale.enable = config.var.tailscale; }

View File

@@ -0,0 +1,15 @@
{ config, ... }: {
time.timeZone = config.var.timeZone;
i18n.defaultLocale = config.var.defaultLocale;
i18n.extraLocaleSettings = {
LC_ADDRESS = config.var.extraLocale;
LC_IDENTIFICATION = config.var.extraLocale;
LC_MEASUREMENT = config.var.extraLocale;
LC_MONETARY = config.var.extraLocale;
LC_NAME = config.var.extraLocale;
LC_NUMERIC = config.var.extraLocale;
LC_PAPER = config.var.extraLocale;
LC_TELEPHONE = config.var.extraLocale;
LC_TIME = config.var.extraLocale;
};
}

View File

@@ -1,4 +1,4 @@
{ pkgs, ... }: { pkgs, config, ... }:
{ {
# USB Automounting # USB Automounting
@@ -7,16 +7,12 @@
# services.devmon.enable = true; # services.devmon.enable = true;
# Enable USB Guard # Enable USB Guard
# services.usbguard = { services.usbguard = {
# enable = true; enable = config.var.usbguard;
# dbus.enable = true; dbus.enable = true;
# implicitPolicyTarget = "block"; implicitPolicyTarget = "block";
# # FIXME: set yours pref USB devices (change {id} to your trusted USB device), use `lsusb` command (from usbutils package) to get list of all connected USB devices including integrated devices like camera, bluetooth, wifi, etc. with their IDs or just disable `usbguard` rules = config.var.usbguardRules;
# rules = '' };
# allow id {id} # device 1
# allow id {id} # device 2
# '';
# };
# Enable USB-specific packages # Enable USB-specific packages
environment.systemPackages = with pkgs; [ usbutils ]; environment.systemPackages = with pkgs; [ usbutils ];

10
hosts/modules/users.nix Normal file
View File

@@ -0,0 +1,10 @@
{ config, pkgs, ... }: {
users = {
defaultUserShell = pkgs.zsh;
users.${config.var.username} = {
isNormalUser = true;
description = "${config.var.username} account";
extraGroups = [ "networkmanager" "wheel" ];
};
};
}

42
hosts/modules/utils.nix Normal file
View File

@@ -0,0 +1,42 @@
{ pkgs, config, ... }: {
networking.hostName = config.var.hostname;
services = {
xserver = {
enable = true;
xkb.layout = config.var.keyboardLayout;
xkb.variant = "";
};
gnome.gnome-keyring.enable = true;
};
console.keyMap = config.var.keyboardLayout;
environment.variables = {
XDG_DATA_HOME = "$HOME/.local/share";
PASSWORD_STORE_DIR = "$HOME/.local/share/password-store";
EDITOR = "nvim";
};
services.libinput.enable = true;
programs.dconf.enable = true;
services.dbus.enable = true;
# Faster rebuilding
documentation = {
enable = true;
doc.enable = false;
man.enable = true;
dev.enable = false;
};
environment.systemPackages = with pkgs; [
fd
bc
gcc
git-ignore
xdg-utils
wget
curl
];
}

View File

@@ -1,167 +0,0 @@
{ lib, ... }: {
options = {
var = {
hostname = lib.mkOption {
type = lib.types.string;
default = "nixy";
description = "Hostname";
};
username = lib.mkOption {
type = lib.types.string;
default = "user";
description = "Username";
};
homeDirectory = lib.mkOption {
type = lib.types.string;
default = "/home/user";
description = "Home directory (/home/user)";
};
configDirectory = lib.mkOption {
type = lib.types.string;
default = "/home/user/.config/nixos";
description = "NixOS config directory (/home/user/.config/nixos)";
};
keyboardLayout = lib.mkOption {
type = lib.types.string;
default = "en";
description = "Keyboard layout (en/fr/...)";
};
timeZone = lib.mkOption {
type = lib.types.string;
default = "America/New_York";
description = "Time Zone";
};
defaultLocale = lib.mkOption {
type = lib.types.string;
default = "en_US.UTF-8";
description = "Default Locale";
};
extraLocale = lib.mkOption {
type = lib.types.string;
default = "fr_FR.UTF-8";
description = "Extra Locale";
};
stateVersion = lib.mkOption {
type = lib.types.string;
default = "24.05";
description = "State Version: Shouldn't be changed once set.";
};
autoUpgrade = lib.mkOption {
type = lib.types.bool;
default = false;
description = "Enable auto upgrades";
};
autoGarbageCollector = lib.mkOption {
type = lib.types.bool;
default = false;
description = "Enable garbage collector";
};
sops = lib.mkOption {
type = lib.types.bool;
default = false;
description =
"Enable sops (You should set up sops for your own config)";
};
obsidian = lib.mkOption {
type = lib.types.bool;
default = false;
description =
"Enable obsidian.nvim (You should set up obsidian.nvim for your own config)";
};
tailscale = lib.mkOption {
type = lib.types.bool;
default = false;
description = "Enable tailscale";
};
git = {
username = lib.mkOption {
type = lib.types.string;
default = "user";
description = "Git Username";
};
email = lib.mkOption {
type = lib.types.string;
default = "youremail@gmail.com";
description = "Git Email";
};
};
theme = {
wallpaper = lib.mkOption {
type = lib.types.string;
default = "magma.png";
description = "Wallpaper (Should be in /home/$USER/wallpapers)";
};
font = lib.mkOption {
type = lib.types.string;
default = "SFProDisplay Nerd Font";
description = "Font";
};
font-mono = lib.mkOption {
type = lib.types.string;
default = "FiraCode Nerd Font Mono";
description = "Monospace Font";
};
font-size = lib.mkOption {
type = lib.types.int;
default = 14;
description = "Font Size";
};
rounding = lib.mkOption {
type = lib.types.int;
default = 8;
description = "Border radius";
};
gaps-in = lib.mkOption {
type = lib.types.int;
default = 8;
description = "Gaps In";
};
gaps-out = lib.mkOption {
type = lib.types.int;
default = 16;
description = "Gaps Out";
};
border-size = lib.mkOption {
type = lib.types.int;
default = 2;
description = "Border Size";
};
animation-speed = lib.mkOption {
type = lib.types.string;
default = "medium";
description = "Animation Speed (slow/medium/fast)";
};
fetch = lib.mkOption {
type = lib.types.string;
default = "neofetch";
description = "Fetch (neofetch/nerdfetch/pfetch/none)";
};
waybar = {
transparent = lib.mkOption {
type = lib.types.bool;
default = true;
description = "Transparent Bar";
};
float = lib.mkOption {
type = lib.types.bool;
default = true;
description = "Floating Bar";
};
position = lib.mkOption {
type = lib.types.string;
default = "top";
description = "Bar's Position";
};
font-size = lib.mkOption {
type = lib.types.int;
default = 16;
description = "Waybar text font size";
};
};
colors = {
# TODO
};
};
};
};
}

8
hosts/modules/zsh.nix Normal file
View File

@@ -0,0 +1,8 @@
{
programs.zsh = {
enable = true;
loginShellInit = ''
dbus-update-activation-environment --systemd DISPLAY
'';
};
}

View File

@@ -9,7 +9,6 @@
./modules/internal/openssh.nix ./modules/internal/openssh.nix
./modules/internal/adguard.nix ./modules/internal/adguard.nix
./modules/internal/cockpit.nix ./modules/internal/cockpit.nix
# ./modules/internal/unifi.nix # FIXME: unifi5 is deprecated
# exposed # exposed
./modules/exposed/ntfy-sh.nix ./modules/exposed/ntfy-sh.nix
@@ -19,7 +18,6 @@
./modules/exposed/nginx.nix ./modules/exposed/nginx.nix
./modules/exposed/nextcloud.nix ./modules/exposed/nextcloud.nix
./modules/exposed/vaultwarden.nix ./modules/exposed/vaultwarden.nix
# ./modules/exposed/bitcoin-git.nix # FIXME: bitcoin-git is deprecated
./modules/www ./modules/www
# jackflix # jackflix

View File

@@ -1,4 +1,19 @@
{ pkgs, ... }: { { pkgs, ... }:
let
bitcoin-price = pkgs.writeShellScriptBin "bitcoin-price" ''
[ ! -d "/home/hadi/btcprice" ] && ${pkgs.git}/bin/git clone git@github.com:anotherhadi/btcprice /home/hadi/btcprice
cd "/home/hadi/btcprice"
price=$(${pkgs.curl}/bin/curl eur.rate.sx/1BTC)
echo "# Bitcoin Price in EURO" >README.md
echo "" >>README.md
echo "1 Bitcoin = $price" >>README.md
echo "" >>README.md
echo "Date: $(date)" >>README.md
${pkgs.git}/bin/git add .
${pkgs.git}/bin/git commit -m "Update price (hadi)"
${pkgs.git}/bin/git push -u origin main
'';
in {
systemd.timers."bitcoin-git" = { systemd.timers."bitcoin-git" = {
wantedBy = [ "timers.target" ]; wantedBy = [ "timers.target" ];
timerConfig = { timerConfig = {
@@ -10,17 +25,7 @@
systemd.services."bitcoin-git" = { systemd.services."bitcoin-git" = {
script = '' script = ''
[ ! -d "/home/hadi/btcprice" ] && ${pkgs.git}/bin/git clone git@github.com:anotherhadi/btcprice /home/hadi/btcprice ${bitcoin-price}
cd "/home/hadi/btcprice"
price=$(${pkgs.curl}/bin/curl eur.rate.sx/1BTC)
echo "# Bitcoin Price in EURO" >README.md
echo "" >>README.md
echo "1 Bitcoin = $price" >>README.md
echo "" >>README.md
echo "Date: $(date)" >>README.md
${pkgs.git}/bin/git add .
${pkgs.git}/bin/git commit -m "Update price (hadi)"
${pkgs.git}/bin/git push -u origin main
exit 0 exit 0
''; '';
serviceConfig = { serviceConfig = {

View File

@@ -1,7 +0,0 @@
# unifi controller service
{
services.unifi = {
enable = true;
openFirewall = true; # 8443(webui) and other port use by AP
};
}

View File

@@ -17,7 +17,6 @@
# haugene/transmission-openvpn # haugene/transmission-openvpn
# ''; # '';
# }; # };
# TODO: launch the container at boot
networking.firewall.allowedTCPPorts = [ 9091 ]; networking.firewall.allowedTCPPorts = [ 9091 ];
} }

View File

@@ -2,7 +2,7 @@
sops = { sops = {
age.keyFile = "/home/hadi/.config/sops/age/keys.txt"; age.keyFile = "/home/hadi/.config/sops/age/keys.txt";
defaultSopsFile = ./server.yaml; defaultSopsFile = ./secrets.yaml;
defaultSopsFormat = "yaml"; defaultSopsFormat = "yaml";
secrets = { secrets = {
sshconfig = { sshconfig = {
@@ -14,15 +14,15 @@
owner = "hadi"; owner = "hadi";
}; };
nextcloud-adminpass = { nextcloud-adminpass = {
mode = "0444"; # FIXME mode = "0444";
path = "/etc/nextcloud/adminpassFile"; path = "/etc/nextcloud/adminpassFile";
}; };
cloudflare-apitoken = { cloudflare-apitoken = {
mode = "0444"; # FIXME mode = "0444";
path = "/etc/cloudflare/apiToken"; path = "/etc/cloudflare/apiToken";
}; };
tailscaled-authKey = { tailscaled-authKey = {
mode = "0444"; # FIXME mode = "0444";
path = "/etc/tailscale/authKey"; path = "/etc/tailscale/authKey";
}; };
transmission-script = { transmission-script = {

View File

@@ -1,52 +0,0 @@
{
wallpaper = "dark.png";
font = "SFProDisplay Nerd Font";
font-mono = "FiraCode Nerd Font Mono";
font-size = 14;
rounding = 15;
gaps-in = 10;
gaps-out = 10 * 2;
border-size = 3;
animation-speed = "fast"; # "fast" | "medium" | "slow"
fetch = "nerdfetch"; # "nerdfetch" | "neofetch" | "pfetch" | "none"
waybar = {
transparent = true;
float = true;
position = "top";
font-size = 15;
};
colors = {
c0 = "1e1e2e"; # black
c1 = "dea2bd"; # red
c2 = "a6e3a1"; # green
c3 = "fab387"; # yellow
c4 = "89b4fa"; # blue
c5 = "A594FD"; # magenta
c6 = "74c7ec"; # cyan
c7 = "cdd6f4"; # white
c8 = "313244"; # bright black
c9 = "dea2bd"; # bright red
c10 = "94e2d5"; # bright green
c11 = "f9e2af"; # bright yellow
c12 = "b4befe"; # bright blue
c13 = "f5c2e7"; # bright magenta
c14 = "94e2d5"; # bright cyan
c15 = "bac2de"; # bright white
bg = "0B0B0B";
fg = "EAF0F5";
bgalt = "121212";
fgalt = "EAF0F5";
accent = "dea2bd";
accentFg = "0B0B0B";
# Should make those automtic
accentName = "red";
accentNumber = "9";
};
}