- restart_verify() now async via spawn_future_local (was blocking main thread) - stop() uses 3s timeout instead of unbounded - load_strings() caches locale detection in OnceLock (was reading /etc/locale.conf on every call) - child_get() replaced with child_value().get() for graceful D-Bus type mismatch handling - Eliminate redundant password clone in auth path (direct move into spawn_blocking) - Add on_exhausted callback: hides fp_label after MAX_FP_ATTEMPTS - Set running=false before on_success callback (prevent double-unlock) - Add 4 unit tests for on_verify_status state machine - Document GLib-GString/CString zeroize limitation in CLAUDE.md
74 lines
1.7 KiB
Markdown
74 lines
1.7 KiB
Markdown
# Moonlock
|
|
|
|
A secure Wayland lockscreen with GTK4, PAM authentication and fingerprint support.
|
|
Part of the Moonarch ecosystem.
|
|
|
|
## Features
|
|
|
|
- **ext-session-lock-v1** — Protocol-guaranteed screen locking (compositor keeps screen locked on crash)
|
|
- **PAM authentication** — Uses system PAM stack (`/etc/pam.d/moonlock`)
|
|
- **Fingerprint unlock** — fprintd D-Bus integration, async init (optional, window appears instantly)
|
|
- **Multi-monitor** — Lockscreen on every monitor, single shared fingerprint listener
|
|
- **i18n** — German and English (auto-detected)
|
|
- **Faillock warning** — UI counter + system pam_faillock
|
|
- **Panic safety** — Panic hook logs but never unlocks
|
|
- **Password wiping** — Zeroize on drop
|
|
|
|
## Requirements
|
|
|
|
- GTK 4
|
|
- gtk4-session-lock (ext-session-lock-v1 support)
|
|
- PAM (`/etc/pam.d/moonlock`)
|
|
- Optional: fprintd for fingerprint support
|
|
|
|
## Building
|
|
|
|
```bash
|
|
cargo build --release
|
|
```
|
|
|
|
## Installation
|
|
|
|
```bash
|
|
# Install binary
|
|
sudo install -Dm755 target/release/moonlock /usr/bin/moonlock
|
|
|
|
# Install PAM config
|
|
sudo install -Dm644 config/moonlock-pam /etc/pam.d/moonlock
|
|
|
|
# Optional: Install example config
|
|
sudo install -Dm644 config/moonlock.toml.example /etc/moonlock/moonlock.toml.example
|
|
```
|
|
|
|
## Configuration
|
|
|
|
Create `/etc/moonlock/moonlock.toml` or `~/.config/moonlock/moonlock.toml`:
|
|
|
|
```toml
|
|
background_path = "/usr/share/wallpapers/moon.jpg"
|
|
fingerprint_enabled = true
|
|
```
|
|
|
|
## Usage
|
|
|
|
Typically launched via keybind in your Wayland compositor:
|
|
|
|
```
|
|
# Niri keybind example
|
|
binds {
|
|
Mod+L { spawn "moonlock"; }
|
|
}
|
|
```
|
|
|
|
## Development
|
|
|
|
```bash
|
|
cargo test
|
|
cargo build --release
|
|
LD_PRELOAD=/usr/lib/libgtk4-layer-shell.so ./target/release/moonlock
|
|
```
|
|
|
|
## License
|
|
|
|
MIT
|