Simple File Transfer CLI
Project description
Glitter is a cross‑platform, terminal‑based tool for sending files over a local network. It discovers peers automatically, confirms transfers on the receiver, and supports English/Chinese UIs.
- OS support: Linux, macOS, Windows
- Bilingual UI: English, 中文 (switchable in settings)
- Peer discovery via UDP broadcast + smart replies (or manual IP entry)
- Encrypted transfer (DH key exchange + stream cipher)
- Device fingerprint verification (TOFU) to flag impersonation attempts
- Integrity check (SHA-256) after receive
- Directory transfer: send entire folders (auto-zipped, zero compression)
- Transfer progress and live throughput (e.g. 1.2 MB/s)
- Transfer history (JSONL) stored under user home
- Settings for language & device name & encryption, clear history
Why Glitter?
Glitter provides a simple, terminal-based alternative to GUI tools and complex protocols:
| Tool | Pros | Cons | Glitter Advantage |
|---|---|---|---|
| LocalSend | Beautiful GUI, cross-platform | Requires GUI environment, ~100MB+ install | CLI-first: works via SSH, lightweight (~50KB), scriptable |
| Magic Wormhole | Simple one-time codes | Requires relay server, single-file only | LAN-direct: no internet needed, auto-discovery, no codes to type |
| SFTP/SCP | Universal, encrypted | Needs SSH server setup, manual IP entry | Zero-config: auto-discovers peers, no server setup |
| rsync | Powerful sync engine | Complex syntax, requires remote shell access | Interactive: menu-driven, progress bars, history tracking |
| HTTP file server | Simple python -m http.server |
No encryption, manual URL sharing | Secure: DH key exchange + encryption, peer selection UI |
| croc | End-to-end encryption, relay servers, cross-platform | Requires typing codes, internet relay by default | LAN-native: auto-discovery on local network, no codes needed, works offline |
Use Glitter when you want:
- Quick file sharing on LAN without leaving the terminal
- Auto-discovery instead of typing IPs
- Encrypted transfers without complex SSH setup
- Minimal dependencies (pure Python, no external binaries)
- Transfer history and bilingual UI
Quick Start
On first run, Glitter asks for language and device name and saves them. Next runs go straight to the main menu.
- Compilation: binary
- Firewall: Allow UDP 45845 and TCP 45846 (transfer port) for the app if discovery/transfer is blocked.
Installation
Recommended to install and run via pipx:
apt install pipx# Debian/Ubuntupipx install glitter-cliglitterpipx upgrade glitter-cli# to update
Alternative: install via pip (not recommended)
pip install glitter-cliglitterpip install --upgrade glitter-cli# to update
From source
Requirements: install deps
- Linux/macOS/WSL/Windows (PowerShell/CMD) Run:
git clone https://github.com/scarletkc/glitter.gitpip install -r requirements.txtpython3 -m glittergit pull# to update
Usage
glitter— Launch the interactive menu (list peers, send/receive requests, view history, configure download/encryption/auto-accept modes, etc.).glitter send <peer|IP[:port]> <path>— Send a file or directory directly without the menu (peer ID or manual IP).glitter peers— List peers currently discovered on the LAN.glitter history [--clear]— Print recent transfer history records, or clear them instantly.glitter settings [--language CODE] [--device-name NAME] [--clear-trust]— Jump straight into the settings menu or apply specific changes (language, device name, trust reset) in one go.glitter update— Check the latest available Glitter version.glitter receive [--mode trusted|all] [--dir PATH] [--port PORT] [--no-encryption]— Run in auto-receive mode (trusted/all) without opening the menu.
Tip: once the initial setup is complete, you can keep Glitter running headlessly with your favourite process manager (uv run, systemd, pm2, ...).
Files & Persistence
- Config:
~/.glitter/config.json(language, device name, transfer port, encryption, default receive directory, auto-accept mode) - Trusted fingerprints:
~/.glitter/known_peers.json(peer IDs and fingerprints stored after first approval) - History:
~/.glitter/history.jsonl(one JSON per line) - Default receive folder: configurable; defaults to
~/Downloads/GlitterDownloadson Windows,~/GlitterDownloadselsewhere
Debugging
- Enable verbose IDs in lists by setting env var
GLITTER_DEBUG=1before launch.
License
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file glitter_cli-0.6.1.tar.gz.
File metadata
- Download URL: glitter_cli-0.6.1.tar.gz
- Upload date:
- Size: 40.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4a623a0d093f6c70be364f120081a8b42076e992e22aca18d4d6315d29b9c6ce
|
|
| MD5 |
f93a8efcc035482c5af542269f46aaef
|
|
| BLAKE2b-256 |
f3f5c5bb5c9dc23164f5aeda747ce12264dee3d2d4a99ba891afd46abc9300e1
|
Provenance
The following attestation bundles were made for glitter_cli-0.6.1.tar.gz:
Publisher:
publish.yml on scarletkc/glitter
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
glitter_cli-0.6.1.tar.gz -
Subject digest:
4a623a0d093f6c70be364f120081a8b42076e992e22aca18d4d6315d29b9c6ce - Sigstore transparency entry: 675906280
- Sigstore integration time:
-
Permalink:
scarletkc/glitter@329c4044676f7dfb5e1b3c4e11413f7140862349 -
Branch / Tag:
refs/heads/main - Owner: https://github.com/scarletkc
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@329c4044676f7dfb5e1b3c4e11413f7140862349 -
Trigger Event:
push
-
Statement type:
File details
Details for the file glitter_cli-0.6.1-py3-none-any.whl.
File metadata
- Download URL: glitter_cli-0.6.1-py3-none-any.whl
- Upload date:
- Size: 45.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7f535b6aa6b8511e0b835cc17a5ef6331a654e1d75055f5b7eea7ec45864c298
|
|
| MD5 |
a107c38550c472318ac7010573bdbee7
|
|
| BLAKE2b-256 |
af76b26ea1a901b857359fbba6ee586a9077c15a041d4dcaab82cc1c34d9622a
|
Provenance
The following attestation bundles were made for glitter_cli-0.6.1-py3-none-any.whl:
Publisher:
publish.yml on scarletkc/glitter
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
glitter_cli-0.6.1-py3-none-any.whl -
Subject digest:
7f535b6aa6b8511e0b835cc17a5ef6331a654e1d75055f5b7eea7ec45864c298 - Sigstore transparency entry: 675906288
- Sigstore integration time:
-
Permalink:
scarletkc/glitter@329c4044676f7dfb5e1b3c4e11413f7140862349 -
Branch / Tag:
refs/heads/main - Owner: https://github.com/scarletkc
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@329c4044676f7dfb5e1b3c4e11413f7140862349 -
Trigger Event:
push
-
Statement type: