Files
OqeeRewind/README.fr.md
√(noham)² ed52e470cc Add MPD manifest generation mode to CLI
Introduces a new --manifest flag and --manifest-output option to main.py, allowing users to generate and save an MPD manifest file without downloading segments. Updates argument parsing, documentation, and usage examples in both English and French READMEs to reflect the new feature.
2026-01-11 11:49:06 +01:00

6.9 KiB

OqeeRewind
Téléchargeur Oqee TV Live

Licence Gestionnaire: uv Demandez à DeepWiki
Français | English

Avertissement Légal

Cette application n'est pas affiliée à Oqee. Cette application vous permet de télécharger des vidéos pour une visualisation hors ligne, ce qui peut être interdit par la loi dans votre pays. L'utilisation de cette application peut également entraîner une violation des Conditions d'utilisation entre vous et le fournisseur de flux. Cet outil n'est pas responsable de vos actions ; veuillez prendre une décision éclairée avant d'utiliser cette application.

Installation

Prérequis

go install github.com/Eyevinn/mp4ff/cmd/mp4ff-decrypt@latest

Étapes

Clonez le dépôt et installez les dépendances :

git clone https://github.com/NohamR/OqeeRewind && cd OqeeRewind
uv sync

Configuration

Créez un fichier .env dans le répertoire racine et ajoutez vos identifiants Oqee (sinon le script essaiera d'abord d'utiliser la connexion par IP) :

OQEE_USERNAME=votre_nom_utilisateur
OQEE_PASSWORD=votre_mot_de_passe

Optionnellement, vous pouvez définir les variables d'environnement suivantes dans le fichier .env :

OUTPUT_DIR=./downloads
API_KEY=votre_cle_api_ici
API_URL=https://example.com/get-cached-keys

Utilisation

Mode Interactif

Si vous exécutez le script sans arguments, il vous guidera à travers la sélection des chaînes et le choix des dates.

uv run main.py

https://github.com/user-attachments/assets/54a50828-c0e9-4a29-81c7-e188c238a998

Mode CLI

Vous pouvez automatiser le téléchargement en fournissant des arguments.

usage: main.py [-h] [--start-date START_DATE] [--end-date END_DATE]
               [--duration DURATION] [--channel-id CHANNEL_ID] [--video VIDEO]
               [--audio AUDIO] [--title TITLE] [--username USERNAME]
               [--password PASSWORD] [--key KEY] [--output-dir OUTPUT_DIR]
               [--widevine-device WIDEVINE_DEVICE]
               [--bruteforce-batch-size BRUTEFORCE_BATCH_SIZE]
               [--segment-batch-size SEGMENT_BATCH_SIZE] [--manifest]
               [--manifest-output MANIFEST_OUTPUT]
               [--log-level {DEBUG,INFO,WARNING,ERROR,CRITICAL}]
options:
  -h, --help            show this help message and exit
  --start-date START_DATE
                        Start date and time in YYYY-MM-DD HH:MM:SS format
  --end-date END_DATE   End date and time in YYYY-MM-DD HH:MM:SS format
  --duration DURATION   Duration in HH:MM:SS format (alternative to --end-date)
  --channel-id CHANNEL_ID
                        Channel ID to download from
  --video VIDEO         Video quality selection (e.g., 'best', '1080p', '720p', '1080p+best', '720p+worst')
  --audio AUDIO         Audio track selection (e.g., 'best', 'fra_main')
  --title TITLE         Title for the download (default: channel_id_start_date)
  --username USERNAME   Oqee username for authentication
  --password PASSWORD   Oqee password for authentication
  --key KEY             DRM key for decryption (can be specified multiple times)
  --output-dir OUTPUT_DIR
                        Output directory for downloaded files (default: ./downloads)
  --widevine-device WIDEVINE_DEVICE
                        Path to Widevine device file (default: ./widevine/device.wvd)
  --bruteforce-batch-size BRUTEFORCE_BATCH_SIZE
                        Batch size for bruteforce (default: 20000)
  --segment-batch-size SEGMENT_BATCH_SIZE
                        Batch size for segment downloads (default: 64)
  --manifest            Generate an MPD manifest file instead of downloading
  --manifest-output MANIFEST_OUTPUT
                        Output path for the generated manifest file (default: ./downloads/manifest.mpd)
  --log-level {DEBUG,INFO,WARNING,ERROR,CRITICAL}
                        Set the logging level (default: INFO)

https://github.com/user-attachments/assets/cc76990a-3d13-4be1-bb3c-ba8d87e6eaba

Exemples

Télécharger un programme spécifique avec une durée :

uv run main.py --channel-id 536 --start-date "2025-12-19 12:00:00" --duration "01:30:00" --video "1080p+best" --audio "best" --title "Enregistrement"

Télécharger avec des clés DRM manuelles :

uv run main.py --channel-id 536 --start-date "2025-12-19 12:00:00" --duration "00:05:00" --key "KID:KEY" --key "KID2:KEY2"

Générer uniquement le manifeste MPD (sans téléchargement) :

uv run main.py --channel-id 536 --start-date "2025-01-01 12:00:00" --manifest --manifest-output "./downloads/my_manifest.mpd"

Déchiffrement DRM

Instructions (Widevine)

Afin de déchiffrer le contenu DRM, vous devrez disposer d'un CDM dumpé, après quoi vous devrez placer les fichiers CDM dans le répertoire ./widevine/. Pour des raisons légales, nous n'incluons pas le CDM avec le logiciel, et vous devrez vous en procurer un vous-même.

À faire

Terminé

  • Implémentation du bruteforce
  • Support des informations EPG
  • Licence
  • Linting du code
  • Implémentation de la licence Oqee Widevine (.wvd)
  • Implémentation complète
  • Vérification de l'installation de mp4ff
  • Implémentation des arguments CLI + documentation
  • Traduction complète Français/Anglais
  • Ajout de plus de commentaires dans le code
  • Système de journalisation
  • Améliorations du README :
    • Bibliothèques utilisées
    • Instructions d'utilisation
    • Exigences d'installation (pip + mp4ff + ffmpeg)
    • GIF de démonstration

En cours

  • Meilleur système de sortie
  • Support du restream direct en direct

Bibliothèques Utilisées