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.
  • Geração de NZB: Cria automaticamente um arquivo .nzb na pasta de execução para facilitar downloads.
  • 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: 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

Após a instalação via PyPI, use o comando upapasta diretamente.

Sintaxe:

upapasta /caminho/para/sua/pasta [OPÇÕES]

Exemplo básico:

upapasta /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. ~/.config/upapasta/.env
--keep-files Mantém os arquivos .rar e .par2 no disco após o upload. Desativado

Estrutura do Projeto

upapasta/
├── upapasta/
│   ├── __init__.py    # Inicialização do pacote
│   ├── 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
├── LICENSE            # Licença MIT
├── MANIFEST.in        # Arquivos extras para incluir no pacote
├── pyproject.toml     # Configuração do pacote
├── tests/
│   └── test_upapasta.py # Testes unitários
├── INSTALL.md         # Instruções de instalação detalhadas
└── README.md          # Este arquivo

Licença

Este projeto está licenciado sob a Licença MIT. Veja o arquivo LICENSE para mais detalhes.

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.4.tar.gz (20.2 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.4-py3-none-any.whl (18.6 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: upapasta-0.1.4.tar.gz
  • Upload date:
  • Size: 20.2 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.4.tar.gz
Algorithm Hash digest
SHA256 425912a9f9a17f4eb4dc375abd63bae1cb83d26c017b6565f5e7322c3c457488
MD5 0e8270acf97dab4272209e9fb4451267
BLAKE2b-256 3b4c5c0bbc6579523423ef87605cd10acdb6834732e30e816e7d6222588209fb

See more details on using hashes here.

File details

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

File metadata

  • Download URL: upapasta-0.1.4-py3-none-any.whl
  • Upload date:
  • Size: 18.6 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.4-py3-none-any.whl
Algorithm Hash digest
SHA256 f6f2175c46580558983b1343fd483a589f43571be95bcd6899386ed75447f10a
MD5 47831ba31ca818e2e6edf2c2f795c2f5
BLAKE2b-256 74aa3062576a092a899d15030892896fe34076cb63df4ce822c49fbfa0203ef0

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