Skip to main content

Ferramenta CLI para upload automatizado em Usenet com RAR, PAR2 e nyuu

Project description

UpaPasta

Português (pt-BR)

Automated Usenet Uploader. One command, full pipeline: PAR2 → upload → NZB ready.

upapasta /tv/Night.of.the.Living.Dead.S01/

PyPI CI Python License: MIT


What it does

  • Generates PAR2 with redundancy profiles (5 / 10 / 20%)
  • Uploads via nyuu without staging in /tmp (direct paths)
  • Delivers NZB + NFO with video metadata
  • (Optional) Creates RAR5 with password before upload
  • Logs everything in ~/.config/upapasta/history.jsonl

Zero Python dependencies — system binaries only.


Installation

pip install upapasta

System dependencies:

Binary Function Install
nyuu NNTP Upload npm install -g nyuu
parpar PAR2 Generation (recommended) pip install parpar
par2 parpar alternative apt install par2
rar RAR5 (only with --rar) apt install rar
ffprobe Video metadata in NFO apt install ffmpeg
mediainfo Technical media info in NFO apt install mediainfo

See INSTALL.md for detailed instructions per platform.


Configuration

On the first run, an interactive wizard creates ~/.config/upapasta/.env:

upapasta --config

To configure failover with multiple NNTP servers, edit .env directly — see DOCS.md § Multiple NNTP servers.


Use cases

Case Command
Entire folder upapasta Folder/
Single file upapasta Episode.S01E01.mkv
Multiple inputs upapasta A/ B/ C/
Parallel upapasta A/ B/ C/ --jobs 3
Reversible obfuscation upapasta Folder/ --obfuscate
Maximum privacy upapasta Folder/ --strong-obfuscate
RAR Password upapasta Folder/ --password "abc123"
Each file = release upapasta /tv/Show.S04/ --each
Season + Single NZB upapasta /tv/Show.S04/ --season
Daemon (watch folder) upapasta /downloads/ --watch
No upload (files only) upapasta Folder/ --skip-upload
Dry run (simulate) upapasta Folder/ --dry-run
Resume interrupted upload upapasta Folder/ --resume

Recommended Workflow 2026

RAR is no longer necessary for most cases. parpar stores the folder hierarchy in .par2 files, and recent SABnzbd/NZBGet versions rebuild the tree upon download:

upapasta Folder/ --obfuscate --backend parpar \
    --filepath-format common --par-profile safe

Use --rar only when you need a password (legacy cases) or when the downloader does not support reconstruction via PAR2.

Obfuscation levels

Flag What is obfuscated NZB shows original name?
(none) nothing yes
--obfuscate files + PAR2 yes (reversible)
--strong-obfuscate files + PAR2 + NZB subjects no

Main options

--rar                    Create RAR5 before upload
--obfuscate              Random names; NZB restores original names
--strong-obfuscate       Maximum privacy: random names for everything
--password PASSWORD      RAR password (automatically implies --rar)
--par-profile PROFILE    fast (5%) · balanced (10%) · safe (20%)
--jobs N                 Parallel uploads for multiple inputs
--resume                 Resume interrupted upload
--dry-run                Simulate without sending
--skip-upload            Generate RAR/PAR2/NFO without uploading
--each                   Each file in folder = separate release
--season                 Like --each + single season NZB
--watch                  Daemon: automatically process new items

upapasta --help lists all options with full descriptions.


History and statistics

# Last 5 uploads
tail -5 ~/.config/upapasta/history.jsonl | python3 -m json.tool

# Aggregated statistics
upapasta --stats

# Archived NZBs (hardlinks by timestamp)
ls -la ~/.config/upapasta/nzb/

Webhooks and hooks

Configure post-upload notifications in .env:

# Discord, Slack, Telegram or any endpoint accepting POST JSON
WEBHOOK_URL=https://discord.com/api/webhooks/...

# External script (receives UPAPASTA_* variables)
POST_UPLOAD_SCRIPT=/home/user/notify.sh

See DOCS.md § Hooks and webhooks for the full list of variables.


Documentation


License

MIT — see LICENSE.

Developed by franzopl.

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

upapasta-0.26.1.tar.gz (153.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

upapasta-0.26.1-py3-none-any.whl (111.2 kB view details)

Uploaded Python 3

File details

Details for the file upapasta-0.26.1.tar.gz.

File metadata

  • Download URL: upapasta-0.26.1.tar.gz
  • Upload date:
  • Size: 153.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for upapasta-0.26.1.tar.gz
Algorithm Hash digest
SHA256 920046087278bf8a383721c9e59c1691ed0de8c4a108c3b745050458e5e988df
MD5 06a86308eb0faea11e82504dd762735d
BLAKE2b-256 20b159c42fad0a890dae99ba5c106cc401635b0ef8a37a0f56dfa2f2ce85e7a6

See more details on using hashes here.

Provenance

The following attestation bundles were made for upapasta-0.26.1.tar.gz:

Publisher: publish.yml on franzopl/upapasta

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file upapasta-0.26.1-py3-none-any.whl.

File metadata

  • Download URL: upapasta-0.26.1-py3-none-any.whl
  • Upload date:
  • Size: 111.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for upapasta-0.26.1-py3-none-any.whl
Algorithm Hash digest
SHA256 40b1a1058e157899b546993d30bb36185017d1f9d0d941e3d1cea1d4e9f73c05
MD5 dd8d9939b092a00ae9146c604e102f6d
BLAKE2b-256 840290fe71d9dce3468deb0da8795bce6994ef2bec570f4f173f669cd9668863

See more details on using hashes here.

Provenance

The following attestation bundles were made for upapasta-0.26.1-py3-none-any.whl:

Publisher: publish.yml on franzopl/upapasta

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page