Files
setup-hibernate/README.md

135 lines
2.7 KiB
Markdown
Raw Permalink Normal View History

# Hibernate Setup
2025-04-02 16:21:03 +02:00
A Python-based utility for configuring hibernation on Linux systems using a swap file.
This tool automates resume configuration for GRUB and initramfs and optionally creates a swap file of configurable size.
Designed for Arch-based systems (Arch Linux, Manjaro) and intended for automation and reproducible system setup.
2025-04-02 16:21:03 +02:00
---
## 🛠 Features
* Optionally create and activate a swap file
* Automatically detect UUID and resume offset
* Inject `resume` and `resume_offset` into GRUB config
* Regenerate initramfs via `mkinitcpio`
* Interactive confirmation before file changes
* Preview mode for dry-run without changes
* Non-interactive mode for automation
* Root permission required
2025-04-02 16:21:03 +02:00
---
## 📦 Installation
### Using pip (recommended)
Install directly from PyPI:
```bash
pip install setup-hibernate
```
Or system-wide:
```bash
sudo pip install setup-hibernate
```
Or isolated using pipx:
2025-04-02 16:21:03 +02:00
```bash
pipx install setup-hibernate
```
---
### From source
```bash
git clone https://github.com/kevinveenbirkenbach/setup-hibernate.git
cd setup-hibernate
pip install .
2025-04-02 16:21:03 +02:00
```
---
## 🚀 Usage
Run the tool as root:
2025-04-02 16:21:03 +02:00
```bash
sudo setup-hibernate [OPTIONS]
2025-04-02 16:21:03 +02:00
```
Or via Python module:
```bash
sudo python -m setup_hibernate [OPTIONS]
```
---
2025-04-02 16:21:03 +02:00
## ⚙ Options
2025-04-02 16:21:03 +02:00
| Option | Description |
| ------------------- | -------------------------------------------------------------------- |
| `--create-swapfile` | Create and configure a swap file at `/swapfile` |
| `--swap-size <int>` | Set the swap file size in GB (default: `32`) |
| `-p`, `--preview` | Show what would be done without executing any changes (dry-run mode) |
| `--non-interactive` | Apply all changes automatically without prompting for confirmation |
---
## 🧪 Examples
2025-04-02 16:45:35 +02:00
Create a 40GB swapfile and configure hibernation interactively:
2025-04-02 16:21:03 +02:00
```bash
sudo setup-hibernate --create-swapfile --swap-size 40
2025-04-02 16:21:03 +02:00
```
2025-04-02 16:45:35 +02:00
Preview what would happen without actually doing anything:
```bash
sudo setup-hibernate --create-swapfile --swap-size 40 --preview
2025-04-02 16:45:35 +02:00
```
Non-interactive, suitable for automation:
```bash
sudo setup-hibernate --create-swapfile --swap-size 40 --non-interactive
2025-04-02 16:45:35 +02:00
```
2025-04-02 16:21:03 +02:00
---
## ✅ Requirements
* Python 3.8+
* Tools:
2025-04-02 16:21:03 +02:00
* `fallocate`
* `mkswap`
* `swapon`
* `filefrag`
* `findmnt`
* `mkinitcpio`
* `update-grub`
* Root privileges
2025-04-02 16:21:03 +02:00
No external Python packages are required.
2025-04-02 16:21:03 +02:00
---
## 👤 Author
Developed by **Kevin Veen-Birkenbach**
🌐 [https://www.veen.world](https://www.veen.world)
2025-04-02 16:21:03 +02:00
---
## 📄 License
This project is licensed under the **MIT License**.
See [LICENSE](./LICENSE) for details.