mirror of
https://github.com/anotherhadi/nixy.git
synced 2026-04-02 11:12:09 +02:00
v4.0.0
Signed-off-by: Hadi <112569860+anotherhadi@users.noreply.github.com>
This commit is contained in:
@@ -1,46 +0,0 @@
|
||||
[//]: # (This file is autogenerated)
|
||||
# Keybindings for Hyprland
|
||||
|
||||
> [!NOTE]
|
||||
> SUPER is the windows key by default
|
||||
|
||||
| Description | Keybinding |
|
||||
| -- | -- |
|
||||
| Switch Workspace | SUPER + {Number} |
|
||||
| Move app to Workspace | SHIFT + SUPER + {Number} |
|
||||
| Proton VPN | SUPER + V |
|
||||
| Proton Authenticator | SUPER + A |
|
||||
| Lock | SUPER + L |
|
||||
| Launcher | SUPER + SPACE |
|
||||
| "$mod,SPACE, exec, menu" | |
|
||||
| Powermenu | SUPER + X |
|
||||
| Toggle HyprFocus | SHIFT + SUPER + SPACE |
|
||||
| Close window | SUPER + Q |
|
||||
| Toggle Floating | SUPER + T |
|
||||
| Toggle Fullscreen | SUPER + F |
|
||||
| Move focus left | SUPER + left |
|
||||
| Move focus Right | SUPER + right |
|
||||
| Move focus Up | SUPER + up |
|
||||
| Move focus Down | SUPER + down |
|
||||
| Focus previous monitor | SHIFT + SUPER + up |
|
||||
| Focus next monitor | SHIFT + SUPER + down |
|
||||
| Add to master | SHIFT + SUPER + left |
|
||||
| Remove from master | SHIFT + SUPER + right |
|
||||
| Screenshot region | SUPER + PRINT |
|
||||
| Screenshot monitor | PRINT |
|
||||
| Screenshot window | SHIFT + SUPER + PRINT |
|
||||
| Screenshot region then edit | ALTPRINT |
|
||||
| Toggle hyprpanel | SHIFT + SUPER + T |
|
||||
| Toggle night shift | SHIFT + SUPER + F2 |
|
||||
| Toggle night shift | SHIFT + SUPER + F3 |
|
||||
| Move Window (mouse) | SUPER + mouse:272 |
|
||||
| Resize Window (mouse) | SUPER + R |
|
||||
| Toggle Mute | XF86AudioMute |
|
||||
| Play/Pause Song | XF86AudioPlay |
|
||||
| Next Song | XF86AudioNext |
|
||||
| Previous Song | XF86AudioPrev |
|
||||
| Lock when closing Lid | switch:Lid Switch |
|
||||
| Sound Up | XF86AudioRaiseVolume |
|
||||
| Sound Down | XF86AudioLowerVolume |
|
||||
| Brightness Up | XF86MonBrightnessUp |
|
||||
| Brightness Down | XF86MonBrightnessDown |
|
||||
@@ -1,92 +0,0 @@
|
||||
[//]: # (This file is autogenerated)
|
||||
# Scripts
|
||||
|
||||
Scripts are located in the 'home/scripts' folder. Home-manager add those in the user's path.
|
||||
|
||||
## Brightness
|
||||
|
||||
This module provides a set of scripts to control the brightness of the screen.
|
||||
|
||||
- `brightness-up` increases the brightness by 5%.
|
||||
- `brightness-down` decreases the brightness by 5%.
|
||||
- `brightness-set [value]` sets the brightness to the given value.
|
||||
- `brightness-change [up|down] [value]` increases or decreases the brightness by the given value.
|
||||
|
||||
## Caffeine
|
||||
|
||||
Caffeine is a simple script that toggles hypridle (disable suspend & screenlock).
|
||||
|
||||
- `caffeine-status` - Check if hypridle is running. (0/1)
|
||||
- `caffeine-status-icon` - Check if hypridle is running. (icon)
|
||||
- `caffeine` - Toggle hypridle.
|
||||
|
||||
## Hyprfocus
|
||||
|
||||
A simple script to toggle focus on few windows in Hyprland.
|
||||
(disable gaps, border, shadow, opacity, etc.)
|
||||
|
||||
- `hyprfocus-on` - Enable hyprfocus.
|
||||
- `hyprfocus-off` - Disable hyprfocus.
|
||||
- `hyprfocus-toggle` - Toggle hyprfocus.
|
||||
|
||||
## Hyprpanel
|
||||
|
||||
Quick scripts to toggle, reload, hide & show hyprpanel.
|
||||
|
||||
- `hyprpanel-toggle` - Toggle hyprpanel (hide/show).
|
||||
- `hyprpanel-show` - Show hyprpanel.
|
||||
- `hyprpanel-hide` - Hide hyprpanel.
|
||||
- `hyprpanel-reload` - Reload hyprpanel.
|
||||
|
||||
## Nerdfont FZF
|
||||
|
||||
This module provides a script to search for Nerd Fonts icons using fzf.
|
||||
|
||||
- `nerdfont-fzf` - Search for Nerd Fonts icons using fzf.
|
||||
|
||||
## Night-Shift
|
||||
|
||||
Night-Shift is a feature that reduces the amount of blue light emitted by your screen, which can help reduce eye strain and improve sleep quality. This module provides a set of scripts to control Night-Shift on your system.
|
||||
It use hyprsunset to control the screen temperature.
|
||||
|
||||
- `night-shift-on` activates Night-Shift.
|
||||
- `night-shift-off` deactivates Night-Shift.
|
||||
- `night-shift` toggles Night-Shift.
|
||||
- `night-shift-status` checks if Night-Shift is active. (0/1)
|
||||
- `night-shift-status-icon` checks if Night-Shift is active. (icon)
|
||||
|
||||
## Nixy
|
||||
|
||||
Nixy is a simple script that I use to manage my NixOS system. It's a simple script that provides a menu to rebuild, test, update, collect garbage, clean boot menu, etc.
|
||||
|
||||
- `nixy` - UI wizard to manage the system.
|
||||
- `nixy rebuild` - Rebuild the system.
|
||||
- `nixy ...` - ... see the script for more commands.
|
||||
|
||||
## Notif
|
||||
|
||||
|
||||
- `notif {id} {title} {description}` - Sends a notification
|
||||
|
||||
## Screenshot
|
||||
|
||||
This module provides a script to take screenshots using `grimblast` and `swappy`.
|
||||
|
||||
- `screenshot [region|window|monitor] [swappy]` - Take a screenshot of the region, window, or monitor. Optionally, use `swappy` to copy the screenshot to the clipboard.
|
||||
|
||||
## Sound
|
||||
|
||||
This module provides a set of scripts to control the volume of the default audio sink using `wpctl`.
|
||||
|
||||
- `sound-up` increases the volume by 5%.
|
||||
- `sound-down` decreases the volume by 5%.
|
||||
- `sound-set [value]` sets the volume to the given value.
|
||||
- `sound-toggle` toggles the mute state of the default audio sink.
|
||||
|
||||
## System
|
||||
|
||||
Usefull quick scripts
|
||||
|
||||
- `lock` - Lock the screen. (hyprlock)
|
||||
- `powermode-toggle` - Toggle between performance and balanced power mode. (powerprofilesctl)
|
||||
|
||||
@@ -1,62 +1,53 @@
|
||||
# SERVER
|
||||
|
||||
## Overview
|
||||
> Update in comming. Early 2026
|
||||
|
||||
## Overview
|
||||
|
||||
This document describes the architecture and setup of the self-hosted **NixOS server**, which is securely accessible via **Tailscale**. The server is designed for private, secure, and easily manageable self-hosting of various services.
|
||||
|
||||

|
||||
|
||||
## **Why This Setup?**
|
||||
## **Why This Setup?**
|
||||
|
||||
- **Private & Secure**: Services are only accessible through Tailscale, preventing exposure to the public internet.
|
||||
- **Domain-based Access**: A custom domain (`example.org`) maps to the server's Tailscale IP, making service access simple and consistent.
|
||||
- **Automatic SSL Certificates**: Using DNS-01 challenges, valid SSL certificates are generated even though the services are not publicly exposed.
|
||||
- **Modular & Declarative**: Everything is managed through NixOS modules, ensuring reproducibility and easy configuration.
|
||||
- **Private & Secure**: Services are only accessible through Tailscale, preventing exposure to the public internet.
|
||||
- **Domain-based Access**: A custom domain (`example.org`) maps to the server's Tailscale IP, making service access simple and consistent.
|
||||
- **Automatic SSL Certificates**: Using DNS-01 challenges, valid SSL certificates are generated even though the services are not publicly exposed.
|
||||
- **Modular & Declarative**: Everything is managed through NixOS modules, ensuring reproducibility and easy configuration.
|
||||
|
||||
## **Self-Hosted Services**
|
||||
## **Self-Hosted Services**
|
||||
|
||||
The server hosts several key applications:
|
||||
The server hosts several key applications:
|
||||
|
||||
### **Core Infrastructure**
|
||||
### **Core Infrastructure**
|
||||
|
||||
- **NGINX**: Reverse proxy for routing traffic to services via `example.org`.
|
||||
- **Bitwarden**: A self-hosted password manager for secure credential storage.
|
||||
- **Nextcloud**: A private cloud solution for file synchronization and collaboration.
|
||||
- **NGINX**: Reverse proxy for routing traffic to services via `example.org`.
|
||||
|
||||
### **Networking & Security**
|
||||
### **Networking & Security**
|
||||
|
||||
- **AdGuard Home**: A self-hosted DNS ad blocker for network-wide ad and tracker filtering.
|
||||
- **AdGuard Home**: A self-hosted DNS ad blocker for network-wide ad and tracker filtering.
|
||||
|
||||
### **Monitoring & Storage**
|
||||
### **Monitoring & Storage**
|
||||
|
||||
- **Glance**: An awesome dashboard! (See the screenshot above)
|
||||
- **Hoarder**: A self-hostable bookmark-everything app (links, notes and images)
|
||||
|
||||
### **Media & Content Management**
|
||||
### **Media & Content Management**
|
||||
|
||||
- **Arr Stack (Radarr, Sonarr, etc.)**: Automated media management tools for handling movies and TV shows. (legaly ofc)
|
||||
|
||||
## **How It Works**
|
||||
## **How It Works**
|
||||
|
||||
1. **Domain Configuration**
|
||||
1. **Domain Configuration**
|
||||
- `example.org` is pointed to the Tailscale IP of the server. (cloudflare A record, not proxied)
|
||||
- This allows for easy access without exposing services to the internet.
|
||||
- This allows for easy access without exposing services to the internet.
|
||||
|
||||
2. **SSL Certificate Generation**
|
||||
2. **SSL Certificate Generation**
|
||||
- Certificates are obtained using a **DNS-01 challenge**, verifying domain ownership without requiring public access.
|
||||
|
||||
3. **NGINX Reverse Proxy**
|
||||
- Routes incoming requests from `*.example.org` to the correct internal service.
|
||||
- Ensures SSL termination and secure connections.
|
||||
3. **NGINX Reverse Proxy**
|
||||
- Routes incoming requests from `*.example.org` to the correct internal service.
|
||||
- Ensures SSL termination and secure connections.
|
||||
|
||||
4. **Access Control**
|
||||
- Only devices within the Tailscale network can reach the services.
|
||||
4. **Access Control**
|
||||
- Only devices within the Tailscale network can reach the services.
|
||||
- Firewall rules restrict access further based on necessity.
|
||||
|
||||
## What's Next?
|
||||
|
||||
I want to self-host:
|
||||
|
||||
- **A great todolist app**: One that is compatible with markdown & IOS
|
||||
- **Cyberchef**
|
||||
- **Maybe**: An app to manage finances
|
||||
|
||||
@@ -3,19 +3,15 @@
|
||||
Themes are defined in `themes`. Those themes define the colors, fonts, icons, etc, used by Hyprland and the apps/programs installed.
|
||||
You can change the selected theme by changing the import statement of your host's variables.nix file.
|
||||
|
||||
> [!TIP]
|
||||
> To apply the theme to DuckDuckGo, follow the instructions in `$HOME/.duckduckgo-colorscheme.js`
|
||||
|
||||
## Create your theme
|
||||
|
||||
Create a copy of one of the existing themes and change the variables.
|
||||
Wallpapers are loaded from the [nixy-wallpapers](https://github.com/anotherhadi/nixy-wallpapers) repo.
|
||||
Wallpapers are loaded from the [hadi's awesome-wallpapers](https://github.com/anotherhadi/awesome-wallpapers) repo.
|
||||
|
||||
## Gallery
|
||||
|
||||
### Nixy
|
||||
### Rose-pine
|
||||
|
||||

|
||||

|
||||

|
||||

|
||||

|
||||

|
||||

|
||||
|
||||
Reference in New Issue
Block a user