Skip to main content

A script to upload folders to Usenet with RAR, PAR2, and nyuu.

Project description

UpaPasta

UpaPasta é uma ferramenta de linha de comando (CLI) em Python para automatizar o processo de upload de pastas para a Usenet. O script orquestra um fluxo de trabalho completo, que inclui:

  1. Compactação: Cria um arquivo .rar a partir da pasta de origem.
  2. Geração de Paridade: Gera arquivos de paridade .par2 para garantir a integridade dos dados.
  3. Upload: Faz o upload dos arquivos .rar e .par2 para o grupo de notícias Usenet especificado.

A ferramenta foi projetada para ser simples, eficiente e exibir barras de progresso em cada etapa do processo.

Funcionalidades

  • Workflow Automatizado: Orquestra a compactação, geração de paridade e upload com um único comando.
  • Flexibilidade: Permite pular etapas individuais (--skip-rar, --skip-par, --skip-upload).
  • Customização: Opções para configurar a redundância dos arquivos PAR2, o tamanho dos posts e o assunto da postagem.
  • Segurança: Carrega as credenciais da Usenet a partir de um arquivo .env para não expor informações sensíveis.
  • Limpeza Automática: Remove os arquivos .rar e .par2 gerados após o upload (pode ser desativado com --keep-files).
  • Dry Run: Permite simular a execução sem criar ou enviar arquivos (--dry-run).

Instalação

Via PyPI (Recomendado)

pip install upapasta

Para Desenvolvimento

  1. Clone o repositório:

    git clone https://github.com/franzopl/upapasta.git
    cd upapasta
    
  2. Instale em modo editável: Recomenda-se o uso de um ambiente virtual (venv).

    python3 -m venv .venv
    source .venv/bin/activate
    pip install -e .
    
  3. Dependências Externas: Além das dependências do Python (nenhuma adicional), certifique-se de ter o rar, parpar (ou par2) e nyuu instalados e disponíveis no seu PATH.

Configuração de Credenciais

O script usa um arquivo de configuração global em ~/.config/upapasta/.env por padrão. Na primeira execução, será solicitado que você forneça as credenciais, que serão salvas automaticamente.

Para configurar manualmente:

  • Copie o arquivo de exemplo .env.example para ~/.config/upapasta/.env e edite:
    mkdir -p ~/.config/upapasta
    cp .env.example ~/.config/upapasta/.env
    
  • Edite o arquivo ~/.config/upapasta/.env:
    NNTP_HOST=news.your-provider.com
    NNTP_PORT=563
    NNTP_USER=your-username
    NNTP_PASS=your-password
    USENET_GROUP=alt.binaries.test
    NNTP_SSL=true
    

Como Usar

O uso básico do upapasta envolve a execução do script main.py, passando o caminho da pasta que você deseja enviar.

Sintaxe:

python3 -m upapasta.main /caminho/para/sua/pasta [OPÇÕES]

Exemplo básico:

python3 -m upapasta.main /home/user/documentos/meu-arquivo-importante

Opções de Linha de Comando

Opção Descrição Padrão
folder (Obrigatório) A pasta que será enviada. N/A
--dry-run Simula a execução sem criar ou enviar arquivos. Desativado
-r, --redundancy Define a porcentagem de redundância para os arquivos PAR2. 15
--backend Escolhe o backend para a geração de paridade (parpar ou par2). parpar
--post-size Define o tamanho alvo para cada post na Usenet (ex: 20M, 700k). 20M
-s, --subject Define o assunto da postagem na Usenet. Nome da pasta
-g, --group Define o grupo de notícias (newsgroup) para o upload. Valor definido no arquivo .env
--skip-rar Pula a etapa de criação do arquivo .rar. Desativado
--skip-par Pula a etapa de geração dos arquivos de paridade .par2. Desativado
--skip-upload Pula a etapa de upload para a Usenet. Desativado
-f, --force Força a sobrescrita de arquivos .rar ou .par2 que já existam. Desativado
--env-file Especifica um caminho alternativo para o arquivo .env. .env
--keep-files Mantém os arquivos .rar e .par2 no disco após o upload. Desativado

Estrutura do Projeto

upapasta/
├── upapasta/
│   ├── main.py        # Orquestrador principal
│   ├── makerar.py     # Lógica para criar arquivos .rar
│   ├── makepar.py     # Lógica para gerar arquivos .par2
│   └── upfolder.py    # Lógica para fazer o upload
├── .env.example       # Exemplo de arquivo de configuração
├── requirements.txt   # Dependências do Python
└── README.md          # Este arquivo

Contribuição

Contribuições são bem-vindas! Se você encontrar um bug ou tiver uma sugestão de melhoria, sinta-se à vontade para abrir uma issue ou enviar um pull request.

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.1.1.tar.gz (19.8 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.1.1-py3-none-any.whl (18.4 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: upapasta-0.1.1.tar.gz
  • Upload date:
  • Size: 19.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.0

File hashes

Hashes for upapasta-0.1.1.tar.gz
Algorithm Hash digest
SHA256 10db85b903ca5bd7138e7ff63ae6ba5cc2ebc798d1050b06c4f5b9b56d88e20f
MD5 3a7574159a32e92c0fcb865a71b74b68
BLAKE2b-256 1608beca0f9a8cd6a74417bedbdd081992c666366abcc4dec225b4ff51057b83

See more details on using hashes here.

File details

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

File metadata

  • Download URL: upapasta-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 18.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.0

File hashes

Hashes for upapasta-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 913ebdbd314cf3723436f17cbf5347c0bd0ea2503248c1da1884d50309e739cc
MD5 59f14b413975985bac45861bf22553ab
BLAKE2b-256 245719395cd3846e8393e4a4db35b0d31995002e4c9c352a9667e06575e67154

See more details on using hashes here.

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