Skip to content

Latest commit

 

History

History
executable file
·
288 lines (203 loc) · 9.25 KB

README.md

File metadata and controls

executable file
·
288 lines (203 loc) · 9.25 KB

makerelease

License: MIT Ruff Discord

makerelease è un comodo script per velocizzare la pubblicazione di film e serie tv sui forum P2P italiani.

⚠️ ATTENZIONE: Questo repository è pubblicato a scopo informativo e didattico.

🚩 Indice

✨ Funzionalità

  • Ottiene i dati di film e serie tv da TheMovieDB
  • Crea il report con MediaInfo o AVInaptic
  • Crea il file .torrent e genera il link magnet
  • Estrae gli screenshot
  • Genera il grafico del bitrate
  • Carica tutte le immagini su Imgur, ImgBB o Imgbly
  • Prepara il testo del post da pubblicare sul forum con template completamente personalizzabili
  • Formatta il titolo della release seguendo un formato consigliato

Sono supportati diversi tipi di release:

  • Film
    1. Film: seleziona un singolo file mkv, mp4 o avi
    2. Film + Extra: seleziona una directory contenente un file video e un numero arbitrario di cartelle Extra, Featurettes, ecc. La procedura è identica al caso precedente, l'unica differenza è l'aggiunta della directory nel torrent.
  • Serie TV
    1. Stagione singola: seleziona una directory contenente più file video. Lo script identifica la serie dal nome della cartella.
    2. Serie completa: seleziona una directory contenente più cartelle. Lo script identifica la serie dal nome della cartella principale.

📦 Requisiti

⚒️ Installazione

🪟 Windows

  1. Installa Python

    winget install Python.Python.3.12
  2. Installa Git

    winget install Git.Git
  3. Installa FFmpeg

    winget install Gyan.FFmpeg
  4. Clona il repository

    git clone https://github.com/c137ricksanchez/makerelease.git
  5. Entra nella directory

    cd makerelease
  6. Installa il pacchetto e le dipendenze

    ⚠️ Installa le dipendenze all'interno di un ambiente virtuale (venv) per evitare conflitti con altri script.

    pip install -e .

🍎 macOS

  1. Installa Homebrew

    /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"
  2. Installa Python

    brew install python
  3. Installa Git

    brew install git
  4. Installa FFmpeg

    brew install ffmpeg
  5. Clona il repository

    git clone https://github.com/c137ricksanchez/makerelease.git
  6. Entra nella directory

    cd makerelease
  7. Installa il pacchetto e le dipendenze

    ⚠️ Installa le dipendenze all'interno di un ambiente virtuale (venv) per evitare conflitti con altri script.

    pip install -e .

🐧 Linux

  1. Installa Git, FFmpeg e MediaInfo

  2. Clona il repository

    git clone https://github.com/c137ricksanchez/makerelease.git
  3. Entra nella directory

    cd makerelease
  4. Installa il pacchetto e le dipendenze

    ⚠️ Installa le dipendenze all'interno di un ambiente virtuale (venv) per evitare conflitti con altri script.

    pip install -e .

🔄 Aggiornamento

  1. Aggiorna il repository

    git pull
  2. Aggiorna eventuali dipendenze

    pip install -e .

⚙️ Configurazione

Crea una copia della cartella config_example chiamandola config e modifica i file all'interno per configurare lo script.

keys.json

  • imgbb: Se desideri caricare le immagini su ImgBB, ottieni la chiave API e inseriscila qui. Lascia vuoto per utilizzare Imgur!
  • tmdb: Inserisci la chiave delle API di TheMovieDB (se non ne hai una, registrati e ottienila qui)
  • imgbly: Il caricamento su ImgBly è disattivato di default, attivandolo verrà utilizzato come scelta primaria. ImgBly verrà sempre utilizzato in caso di fallimento nel caricamento delle immagini su Imgur o su ImgBB, o in caso di screenshot troppo grandi (Imgur supporta al max. 20 MB mentre ImgBB 32 MB)

screenshots.txt

Inserisci i timestamp dove lo script andrà ad estrarre gli screenshot (nel formato HH:MM:SS).

template.jinja

Modifica il template del post in base alle tue preferenze. Le variabili verranno sostituite in automatico con i dati del film o della serie tv.

Variabili supportate

  • {{ TITLE }} - Titolo
  • {{ ORIGINAL_TITLE }} - Titolo originale
  • {{ YEAR }} - Anno di uscita
  • {{ RUNTIME }} - Durata
  • {{ PLOT }} - Trama
  • {{ GENRE }} - Genere
  • {{ DIRECTOR }} - Regista
  • Il CAST è una lista di persone, ciascuna con due attributi: actor, cioè il nome dell'attore, e character, cioè il nome del suo personaggio, e va mostrato con una formula di questo tipo che consente flessibilità nel come si vuole la lista di output:
    [list]
    {% for person in CAST %}
    [*] {{ person.actor }}: {{ person.character }}
    {% endfor %}
    [/list]
  • {{ COUNTRY }} - Paese di produzione
  • {{ POSTER_URL }} - URL del poster
  • {{ TMDB_URL }} - URL della pagina TheMovieDB
  • {{ TRAILER }} - URL al trailer su YouTube
  • {{ SCREENSHOTS }} - URL degli screenshot
  • {{ BITRATE_GRAPH }} - URL del grafico del bitrate (se non presente, la generazione del grafico verrà saltata)
  • {{ REPORT_MEDIAINFO }} - Report generato con MediaInfo
  • {{ REPORT_AVINAPTIC }} - Report generato con AVInaptic
  • {{ SIZE }} - Dimensione del torrent
  • {{ MAGNET }} - Link magnet
  • {{ TREE }} - Elenco dei file, di default è incluso in una formula che lo stampa solo se la release è di tipo movie_folder, tv_single oppure tv_multi
    {% if TREE is defined %}
    [b][size=150]CONTENUTO[/size][/b]
    
    [code]
    {{ TREE }}
    [/code]
    {% endif %}
  • {{ EP_COUNT }} - Numero degli episodi, di default è incluso in una formula che lo stampa solo se la release è di tipo tv_single oppure tv_multi
    {% if EP_COUNT is defined %}
    Numero episodi: [b]{{ EP_COUNT }}[/b]
    {% endif %}

Multi-template

Puoi creare molteplici file template, sarà sufficiente differenziarli utilizzando il carattere underscore (_). Esempio: template_a.jinja oppure template_b.jinja. Il risultato sarà un file post.txt differente per ciascun template, nominato come il file template, quindi post_a.txt oppure post_b.txt.

trackers.txt

Inserisci la trackers list da usare durante la creazione del torrent.

🚀 Utilizzo

GUI

Apri il terminale ed esegui:

python gui.py

Screenshot

Linea di comando

Apri il terminale ed esegui il comando utilizzando i flag riportati sotto per scegliere le opzioni:

python makerelease.py [PATH] -t [TYPE]
Long Short Default Descrizione
--type -t movie Tipo di release, a scelta tra: movie, movie_folder, tv_single, tv_multi
--id -i ID del titolo su TheMovieDB (facoltativo - se non passato, verrà fatta una ricerca e chiesto quale risultato utilizzare)
--crew -c Nome della crew da inserire alla fine del nome del file (facoltativo)
--rename -r False Rinomina in automatico il file seguendo il formato consigliato
--help -h Mostra il messaggio di aiuto con le informazioni su come usare il comando

🧑‍💻 Autori

❤️ Contributors

📜 Licenza

MIT