VideoHelp Forum




+ Reply to Thread
Page 1 of 18
1 2 3 11 ... LastLast
Results 1 to 30 of 528
  1. Feels Good Man 2nHxWW6GkN1l916N3ayz8HQoi's Avatar
    Join Date
    Jan 2024
    Location
    Pepe Island
    Search Comp PM
    Hello. I was inspired by Freevine (great program by the way @stabbedbybrick) and Devine so I wrote my own downloader from scratch, one that mostly ignores any metadata since I don't care about it and will be centered around unpopular/niche/weird/dubious sites that may not receive the same level of attention as other popular websites.

    1. Introduction

    To use the downloader a certain basic level of tech knowledge is required so if you lack experience in any of those fields, I advise you to not use this tool until you researched and learned:
    - python, pip, package management, venv (venv is optional for Windows)[*]
    - running Python scripts or executables from the command line
    - N_m3u8DL-RE and its proper arguments[*]
    - dumping a CDM (either emulated or real), generating a CDM in WVD format
    If you're going to use the release version, you can ignore any Python knowledge requirements. If you're happy with the default N_m3u8DL-RE parameters you don't need to know anything else about that tool.

    The current version of the python downloader can be found here:
    https://files.videohelp.com/u/308780/widefrog_v3_2_0_python_source_code.zip

    The current version of the release can be found here:
    - Windows (from W10 onwards):
    https://files.videohelp.com/u/308780/widefrog_v3_2_0_windows.zip
    - Linux:
    https://files.videohelp.com/u/308780/widefrog_v2_1_0_linux.zip
    - MacOS:
    https://files.videohelp.com/u/308780/widefrog_v2_1_0_macos.zip

    Please download only what you intend/need to use (I'd like to see some real statistics regarding the use of specific versions/OS). The release executable for Windows is going to be updated once in a while. The Linux/MacOS one even more rarely and after many source code updates because I really don't wanna waste time setting up virtual machines every time I make a small change. If the MacOS release is too slow (pyinstaller --onefile issue), just use the Python version. Also if you're worried about detected viruses for the release versions that issue is discussed later on so don't panic. If the release version for your OS is outdated when compared to the Python version, just go for the Python one.

    Before I continue I should say that the program is mostly "what you see is what you get". If at any point you find yourself disapproving of the way I developed/designed it or even with the way I run/maintain things or something else that may be a dealbreaker, just use another downloader. No paid content is supported for any service and I won't add it even if someone gives me access to an account.

    If you find yourself having some questions at some point, make sure you read this entire post at least once before asking or PM-ing me directly. It is highly possible that your issue was addressed at some point during this post.

    Since the tool is tied to N_m3u8DL-RE, it was designed for 64-bit architectures (Windows/Linux/MacOS). It can work on other architectures (32-bit) but you'll be able to use it just to generate download commands on a text file. I won't extend it for 32-bit full download support since that would mean I'd have to ditch N_m3u8DL-RE and replace it with something else. The program is focused mainly on Widevine DRM content. Non-DRM support was added as well when it was easy to extend. HLS AES services are supported as well but there won't be many services focused on this.

    For each service, it will search for the manifest with the highest available quality that is only available through the browser web API (endpoints that are used by other devices/TVs/etc. will be ignored even if they can provide higher quality). If someone wants a low quality like 360p but the best browser manifest is 720p minimum, then tough luck I guess (even if you might find lower ones from the site's API).

    As features, the tool will focus on downloading 3 things: individual content (including livestreams), lists, and series. All services support individual content downloading since it's the most basic feature, however not all sites may offer support for livestreams. The difference between lists and series is about how they're structured. In this context, I consider a series to be composed of seasons and episodes (*generally since it depends on the site).

    A list is just a set of videos that don't belong to an indexed collection (think of a YouTube playlist, liked videos, or videos that may result from a keyword search, etc). A collection can be queried only through the use of an interval (a union of intervals won't be supported). For example, one may request the content from season 1, episode 2, to season 3, episode 4. Or the content of a list between element 1 and element 4.

    That being said, the currently supported services (sorted alphabetically) and corresponding features are:
    - 35mm.online (series)
    - adtv.ae (series)
    - adultswim.com (series)
    - aloula.sa (series)
    - app.nzrplus.com (list, series)
    - auvio.rtbf.be (livestream, list, series)
    - canalplus.com (livestream, series)
    - cda.pl (series)
    - channel4.com (livestream, series)
    - cineverse.com (livestream, series)
    - docplus.com (list)
    - eurovisionsport.com (series)
    - fifa.com (series)
    - filmzie.com (series)
    - france.tv (list, series)
    - goplay.be (series)
    - joyn.de (livestream, list, series)
    - kanopy.com (series)
    - kijk.nl (series)
    - m6.fr (series)
    - maoriplus.co.nz (livestream, series)
    - mediasetinfinity.mediaset.it (list)
    - midnightpulp.com (livestream, series)
    - mtv.fi (list, series)
    - nba.com (list)
    - nemzetiarchivum.hu (series)
    - netflix.com [*only /tudum/ section*] (list)
    - ninateka.pl (series)
    - npo.nl (list, series)
    - pianogroove.com (list)
    - play.tv3.lt (list, series)
    - play.tv3.lv (series)
    - play.virginmediatelevision.ie (series)
    - play.xumo.com (series)
    - player.pl (series)
    - plus.fifa.com (list, series)
    - plus.rtl.de (livestream, list, series)
    - ptvflix.org (series)
    - rakuten.tv (livestream, series)
    - rmcbfmplay.com (list, series)
    - rsi.ch (livestream, list, series)
    - rtlplay.be (livestream, list, series)
    - rtp.pt (livestream, series)
    - rts.ch (list, series)
    - rtve.es (series)
    - rugbypass.tv (list, series)
    - shahid.mbc.net (livestream, series)
    - stirr.com (livestream, series)
    - tf1.fr (list, series)
    - tg4.ie (series)
    - threenow.co.nz (series)
    - tv5mondeplus.com (list, series)
    - uefa.tv (list, series)
    - veeps.com (series)
    - video.telequebec.tv (series)
    - viki.com (series)
    - viu.com (list)
    - vix.com (series)
    - vrt.be (livestream, list, series)
    - vtmgo.be (livestream, list, series)
    - watch.blaze.tv (livestream, list, series)
    - watch.globaltv.com (livestream, list, series)
    - watch.shortly.film (list)
    - watch.tbn.uk (livestream, series)
    - wittytv.it (list)
    - zee5.com (list)

    Some services don't work on specific operating systems because some Python packages are incompatible there. Some services can't be included in the release version because of package issues (regardless of OS). If a service doesn't work for an OS, then obviously it can't be included only in that OS release.

    The output is always MKV, regardless if someone wants to download only video, only audio, or even only subtitles. The output location is also fixed (in the same directory from where the user is running the tool). The output name will be extracted from the content's URL and will be barely enough just to distinguish and recognize the downloaded content. A template for the output won't ever be a feature of this program.

    For the services that don't use subtitles in their manifests, all additional subtitles will always be downloaded (the user won't be able to select which subtitles to download unless they are provided by the manifest, however, the user can choose to ignore any extra subtitles). The additional downloaded subtitles will always be in their original format that is provided by their site. So if they can't be muxed because of dubious formats, you'll have to manually convert them to something else.

    2. Installation

    The following additional tools are needed (use Google if you're confused):
    - Python (3+ version necessary, 3.12+ version optional but recommended)
    - Firefox (only necessary for services that use browser cookies)
    ------------------------------------------------------------------------------------------------------------------------------------------------
    - N_m3u8DL-RE
    - mp4decrypt
    - shaka-packager (don't forget to rename it to shaka-packager)
    - ffmpeg
    - mkvmerge

    Place the last 5 in a folder and add that to the system environment variables for Windows. For Linux/Macos you have to do its equivalent. The basic idea is that you need to be able to call any of the last 5 tools from any directory just by using the tool's name in the terminal. The zip has the requirements.txt file included. If you want to install the packages using virtualenv, then run (it may vary for your OS):
    Code:
    pip install virtualenv
    virtualenv venv
    venv\Scripts\activate
    After doing it correctly, you should see the (venv) prefix in your terminal. DO NOT attempt to install the Python dependencies using the command: pip install -r requirements.txt

    It will fail because there are version conflicts among some packages. Luckily this can be ignored if you install manually all packages. Or if you want to speed things up, you can just run in the terminal:
    Code:
    #windows
    FOR /F %k in (requirements.txt) DO ( if NOT # == %k ( pip install %k ) )
    #linux
    grep -v '^#' requirements.txt | xargs -n 1 pip install
    #macos
    grep -v '^#' requirements.txt | xargs -n 1 pip3 install
    In addition to the packages from the requirements.txt file, make sure these are updated:
    Code:
    pip install urllib3 --upgrade
    If you're not using MacOS, then also run (this is only for cda.pl):
    Code:
    playwright install
    Don't worry about any version conflicts, they aren't relevant. For Linux/Macos, make sure the small scripts from the terminal folder have enough privileges otherwise you'll receive warnings. You can run this command to grant them:
    Code:
    sudo chmod +x "terminal/*"
    For those of you who aren't big fans of Python, you can use the executable corresponding to your OS. It comes with everything prepackaged. Always keep that file in the same place as the "terminal" folder. The executable was generated using the following command (in the base folder, hence why the paths are relative):
    Code:
    pip install pyinstaller
    #windows
    pyinstaller --noconfirm --onefile --console --add-data "services;services/" --add-data "utils;utils/" --add-data "utils/tools;tools/" --hidden-import "browser_cookie3" --hidden-import "bs4" --hidden-import "xmltodict" --hidden-import "pycountry" --hidden-import "isodate" --hidden-import "slugify" --hidden-import "html5lib" --hidden-import "curl_cffi.requests" --hidden-import "cryptography.hazmat.primitives.padding" --hidden-import "m3u8" --hidden-import "chompjs" "widefrog.py"
    #linux
    pyinstaller --noconfirm --onefile --console --add-data "services:services/" --add-data "utils:utils/" --add-data "utils/tools:tools/" --hidden-import "browser_cookie3" --hidden-import "bs4" --hidden-import "xmltodict" --hidden-import "pycountry" --hidden-import "isodate" --hidden-import "slugify" --hidden-import "html5lib" --hidden-import "curl_cffi.requests" --hidden-import "cryptography.hazmat.primitives.padding" --hidden-import "m3u8" --hidden-import "chompjs" "widefrog.py"
    #macos
    python3 -m PyInstaller --noconfirm --onefile --console --add-data "services:services/" --add-data "utils:utils/" --add-data "utils/tools:tools/" --hidden-import "browser_cookie3" --hidden-import "bs4" --hidden-import "xmltodict" --hidden-import "pycountry" --hidden-import "isodate" --hidden-import "slugify" --hidden-import "html5lib" --hidden-import "curl_cffi.requests" --hidden-import "cryptography.hazmat.primitives.padding" --hidden-import "m3u8" "widefrog.py"
    The previous command is meant only to explain how the executable was generated so don't run it. It's worth noting that the release doesn't contain the following services (couldn't include some modules):
    - cda.pl (cf_clearance, playwright)

    Also on MacOS, the following services don't work (because of Python packages that aren't supported):
    - cda.pl (cf_clearance, playwright)
    - veeps.com (chompjs)

    I scanned the release executable using VirusTotal and this is the result:
    - Windows:
    https://www.virustotal.com/gui/file/5dc740b191fe034fc600fab42fb70526f3a8c5b407cc730d6ac9837f2f85ab3b
    - Linux:
    https://www.virustotal.com/gui/file/da20aed98e9b6f24a662c2f1225fef1e9df0d9506bf55ec09f0d426c82b23eb4
    - MacOS:
    https://www.virustotal.com/gui/file/df1d6faed7aa2fdc4f2d717db0557c0e5ebbdb210cb912eed53db3ec8d2e07f9

    The reason why it is detected by some antiviruses is that pyinstaller was used with the argument --onefile. I've read a little about pyinstaller and it was used before by quite a few bad actors to send hidden malware. It's not because pyinstaller is malware itself. So that's why it's instantly detected as a false positive. I tested it even with a simple "Hello World" script and it's still detected.

    It's understandable if you have doubts about using the executable now. I placed it there for people who don't care at all. You will however have to figure out Python if you want to use the program. The same applies if your antivirus falsely detects it and you aren't willing to whitelist it. For those of you that are going to use the release, you can call it from the terminal using: widefrog instead of: python widefrog.py

    If you still have any issues with the installation even now, you can read this.

    For any Linux Termux problems you can read this.

    3. Usage

    If you intend to use DRM services, you will need a CDM in WVD format. It's up to you to figure out how to get one so read the forum. If you're getting license call errors with a CDM that wasn't obtained by you, then you have to learn how to extract one. You need a fresh CDM since the one you're using is either banned or wasn't correctly generated.

    I advise using an emulated CDM. If you use the program excessively (a ridiculous amount) with your CDM, in theory, there's a small chance (< 1%) that it can get toasted. So just to be safe, use one that is emulated because you don't care if you lose it since you can just get a new one. After obtaining a valid WVD file, you can place it directly in the main folder to speed things up.

    If everything was set up right, run it for the first time and you will see:
    Code:
    python widefrog.py
    [INFO] The app_files\config.json file was created. Edit the file and run the program.
    Do not delete any file from that folder unless you see a message specifically telling you to. An exception is when you update the downloader to a new version. In that case make sure you deleted the old config file before generating a new one, especially if new services that require credentials were added. Before starting editing the config file, run
    Code:
    python widefrog.py --help
    python widefrog.py --config
    And read everything that's there and understand how it works. It should take around 2 minutes. Then you can edit the config file. In summary, that JSON file allows you to:
    - set the number of threads used by the tool (don't use too many or some services will block you temporarily)
    - set the parameters for N_m3u8DL-RE (it is highly recommended for you to be familiar with N_m3u8DL-RE because you'll have to provide the right parameters if you want anything else in particular than what the default mode provides)
    - set the service credentials
    - set the output download path (don't set a path too long, otherwise N_m3u8DL-RE might fail for long paths)

    If you don't feel comfortable using your credentials with the program, then just make a burner account. Most of these sites let you use a fake email and since the downloader is centered around free content, using a paid account is useless. Whenever I mention that a service uses browser cookies, I always mean Firefox.

    Also whenever email/password credentials are mentioned, I mean the classic non-Gmail/non-Facebook/non-Apple/non-etc. email/password. I prefer to implement the login flow from scratch but if a site keeps changing it, I'll just go the lazy route and use cookies. If a service has an optional account login feature (email/password), you can opt out of it by leaving at least one of the 2 credential fields empty.

    Regarding geographic restrictions, I won't implement any proxy features so that is entirely up to the user how he fixes this problem (VPNs are one solution and if you use the program correctly, you can use a free VPN without wasting data on downloading, only on basic information scraping which is considerably less). If I mention that a specific country IP is needed for a service that doesn't mean that it's the only country that can be used, it just means it's the first country that worked for me.

    For some services, if you download lots of videos, you can be blocked temporarily due to "429 too many requests". Therefore, it is strongly advised to modify the config JSON file: set MEDIA_DOWNLOADER to 1, and also remove -mt from N_m3u8DL-RE parameters. If you encountered this issue before modifying the config file, then wait a specific amount of time (should be displayed in the error message).

    For some services, the higher quality levels are blocked by L1. Because of this if you use "-sv best" as a N_m3u8DL-RE parameter in the config JSON file, it will get automatically switched with the highest decryptable quality with the currently obtained keys (thanks @karoolus for explaining a way that achieves that). Otherwise, I'll just assume you know what you're doing. On the rare chance that you get an encrypted video, that's because I couldn't deduce the highest decryptable quality. In that case, remove the parameters that auto-pick and select manually your decryptable wanted track.

    Now I will showcase some commands for each service. For most services when it comes to individual content, you can use directly the updated URL after you press play on a video. Feel free to skip any service that isn't relevant to you.

    - 35mm.online
    Some content can't be viewed on the browser unless you're using an account but luckily they don't enforce this for downloading. A series for this site is represented by the result pages of a filter search from https://35mm.online/search
    You need to have at least one filter applied and you can copy the updated URL as valid input.

    A series can also be represented by the rails of a show. Each rail represents a season and the order is top-down, left-right. Only the rails relevant to the show are counted. The others are ignored (for example: "GALERIA", "PODOBNE").
    Code:
    #video
    python widefrog.py "https://35mm.online/vod/animacja/pani-twardowska"
    python widefrog.py "https://35mm.online/vod/dla-dzieci/porwanie-baltazara-gabki/porwanie-baltazara-gabki/porwanie-baltazara-gabki-w-krainie-krola-sloneczko"
    python widefrog.py "https://35mm.online/fonoteka/muzyka/muzyka-ludowa/radosny-poranek"
    #series
    python widefrog.py "https://35mm.online/search?page=1&searchPhrase.3=polska&__NodeTypeAlias.2=asset%2Cseries&__productionYear.4=1940%2C2024" --query=5:40:6:4
    python widefrog.py "https://35mm.online/vod/dla-dzieci/basnie-i-wasnie" --query=1:3:1:5
    - adtv.ae
    Because the Arabic names were kinda bugged for both N_m3u8DL-RE and the OS, I used the content ID as the output name (even if some content may have had English names available). To download a specific series, click on a show from that site and a popup window will appear. The new URL is the series URL. Some episodes from specific series may be shown to be there, but the actual content is not available in some cases.
    Code:
    #video
    python widefrog.py "https://adtv.ae/en/watch?video_external_id=28870325&externalContentId=28870325&type=Movie&media=%D8%A8%D9%8A%D9%86-%D8%A7%D9%84%D8%A3%D8%B7%D9%84%D8%A7%D9%84"
    #series
    python widefrog.py "https://adtv.ae/en/shows?media=%D8%A7%D9%84%D8%A5%D8%AE%D8%AA%D9%8A%D8%A7%D8%B1&video_external_id=216884_page&externalContentId=216884_page&externalSeriesId=216884&type=Series" --query=1:15:2:15
    - adultswim.com
    Read this.

    - aloula.sa
    Same problem with Arabic names.
    Code:
    #video
    python widefrog.py "https://www.aloula.sa/en/episode/19934"
    #series
    python widefrog.py "https://www.aloula.sa/en/title/32" --query=1:25:1:28
    - app.nzrplus.com
    Read this.

    - auvio.rtbf.be
    Read this.

    - canalplus.com
    Read this.

    - cda.pl
    The service doesn't work for MacOS because of a Python package that's not supported for that OS. An optional account can be provided through browser cookies. Make sure that in the config file, you set the user agent value to a real one that you use to access this site. It may help you to obtain 4K content for some videos.

    Some premium content is free if you use a Polish IP. Cloudflare will time you out temporarily if you request large amounts of content. A series in this context isn't made up of seasons and episodes as usual, but rather pages and videos. You can query many videos from a random category of the "Wideo użytkowników" section or a folder of a random user.

    It was kinda fun to use N_m3u8DL-RE on mp4 URLs of various resolutions. Credit goes to @divadsn for figuring out how to decrypt the mp4 URL. It's funny that the devs from this site spent more time defending their non-DRM content, rather than DRM, against automation.
    Code:
    #video
    python widefrog.py "https://www.cda.pl/video/684622bc/vfilm"
    python widefrog.py "https://www.cda.pl/video/75382667f"
    #series
    python widefrog.py "https://www.cda.pl/video/komedia" --query=2:7:3:2
    python widefrog.py "https://www.cda.pl/WojnaIdei/folder-glowny" --query=2:30:3:5
    - channel4.com
    Read this.

    - cineverse.com
    Read this.

    - docplus.com
    Read this.

    - eurovisionsport.com
    Read this.

    - fifa.com
    Read this.

    - filmzie.com
    Read this.

    - france.tv
    Read this.

    - goplay.be
    Read this.

    - joyn.de
    Read this.

    - kanopy.com
    Read this.

    - kijk.nl
    Dutch IP is needed for most content. Most shows have the sections "Afleveringen" and "Clips" which are the focus. The first section contains all of the show's seasons. In the right drop-down list, the seasons are sorted from down to top. In some cases, the seasons may have years as an index. The second section, "Clips", may have different names for other shows, for example, "Hoogtepunten" (it depends on the show). A section can be identified as "Clips" if it contains videos that aren't related to other shows.

    The "Clips" section is considered to be next season following the last one from the "Afleveringen" section. The other sections that contain videos tied to other shows are ignored. If you want to download them, go to their respective shows. Regardless of section, all videos are numbered from top to down, left to right, in the same order they are displayed, regardless of what's written in their name.
    Code:
    #video
    python widefrog.py "https://www.kijk.nl/programmas/10-voor-taal/BPSOLHDAwPp"
    python widefrog.py "https://www.kijk.nl/films/lock-stock-and-two-smoking-barrels/qw9q3GjAQu7"
    #series
    python widefrog.py "https://www.kijk.nl/programmas/het-jachtseizoen" --query=8:7:9:2
    python widefrog.py "https://www.kijk.nl/programmas/lang-leve-de-liefde" --query=5:217:6:2
    python widefrog.py "https://www.kijk.nl/programmas/de-538-ochtend-met-wietze-en-klaas-eindejaarsgesprek" --query=2021:1:2022:1
    python widefrog.py "https://www.kijk.nl/programmas/de-laatste" --query=2019:10:2020:2
    python widefrog.py "https://www.kijk.nl/programmas/dwars-door" --query=1:2:1:4
    - m6.fr
    Read this.

    - maoriplus.co.nz
    Read this.

    - mediasetinfinity.mediaset.it
    Some videos need Italian IP. I don't use good paid VPNs so I have no way of testing if the geographically restricted videos work but they should in theory. When you click on a random video, you'll have the button "Vai alla serie". Click on it and you'll have multiple separate horizontal sections filled with videos (for example Puntate, Servizi, etc.). Each section is followed by a small arrow. Click on the section title and you'll be redirected to a collection of videos. That collection is interpreted as a list by the tool and can be downloaded.

    The manifest with the highest quality isn't always available directly through the browser but the tool finds it through URL editing. Credit goes to @white_snake for explaining this trick.
    Code:
    #video
    python widefrog.py "https://mediasetinfinity.mediaset.it/video/studioapertomag/gustosi-piatti-da-palermo_F312329301352C01"
    #list
    python widefrog.py "https://mediasetinfinity.mediaset.it/programmi-tv/superpartes/puntate_SE000000001278,ST000000004154,sb100025733" --query=:2::5
    python widefrog.py "https://mediasetinfinity.mediaset.it/browse/regione-piemonte_e6538f0b2a0e845001909118d" --query=:3::7
    - midnightpulp.com
    Read this.

    - mtv.fi
    Read this.

    - nba.com
    Browser cookies are needed for some content only. A list of videos for this site means the page that you access when you click "See More" on the right side of a horizontal grid of videos. The default order is top-down.
    Code:
    #video
    python widefrog.py "https://www.nba.com/watch/video/the-fast-break-mar-10-2"
    python widefrog.py "https://www.nba.com/game/ind-vs-orl-0022300928?watchRecap=true"
    #list
    python widefrog.py "https://www.nba.com/watch/list/collection/g-league-ignite-fcc-highlights" --query=:2::5
    - nemzetiarchivum.hu
    Read this.

    - netflix.com
    Read this.

    - ninateka.pl
    Read this.

    - npo.nl
    Read this.

    - pianogroove.com
    I added this service just to see how an HLS AES service would fit into this program. Since most of the content is locked behind a paywall, only the free preview will be downloaded. For this site, a list means the set of videos that belong to a specific course (numbered from top to down starting with the small intro video as the first index).
    Code:
    #video
    python widefrog.py "https://www.pianogroove.com/blues-piano-lessons/minor-blues-introduction/"
    #list
    python widefrog.py "https://www.pianogroove.com/jazz-piano-lessons/jazz-piano-foundations/" --query=:2::4
    - play.tv3.lt
    Read this.

    - play.tv3.lv
    Read this.

    - play.virginmediatelevision.ie
    Read this.

    - play.xumo.com
    Read this.

    - player.pl
    Read this.

    - plus.fifa.com
    A list for this site means the page where the showcases are displayed. The order of that page is considered to be the default one (by popularity) and the videos are indexed from top-down to left-right. A list can also mean the results from a filter search after accessing:
    https://www.plus.fifa.com/en/archive
    Make sure you aren't using the default filters (the empty ones). You have to select at least one filter from the left side.

    The series URL needs to be a URL that points to all seasons for a specific series. It doesn't work if you use a season URL. If you don't know how to obtain the series URL, click on a random season URL, then click the main title. Regarding the audio tracks of a video from this site. Multiple audio languages are available and each one is on a different mpd URL. The downloader is looking for all of them and it merges them in a single mpd file.
    Code:
    #video
    python widefrog.py "https://www.plus.fifa.com/en/player/0227a034-a0c7-405d-897a-aaa103809e88?catalogId=6339b79e-5a0b-41a7-ba30-8c37d042e065"
    #list
    python widefrog.py "https://www.plus.fifa.com/en/showcase/1994-fifa-world-cup-usa-highlights/abc35ac9-0859-48b7-88aa-2ed8936290e7" --query=:2::4
    python widefrog.py "https://www.plus.fifa.com/en/archive?filters=video-type%3Aplayer-awards-fifa-plus-archive-project-collections%2Cseason%3Afifa-u-17-world-cup-indonesia-2023tm%2Ccompetition%3Afifa-women-s-world-cuptm%2Ccompetition%3Afifa-u-17-world-cup" --query=:3::5
    #series
    python widefrog.py "https://www.plus.fifa.com/en/content/when-the-world-watched/3f3a5286-32e7-4587-a094-0edb473d3ed2" --query=1:2:2:2
    - plus.rtl.de
    Read this.

    - ptvflix.org
    Email/password needed. This site was weird. I dunno what triggers this scenario, but sometimes all the free content will get temporarily locked (a little lock icon will appear on each show thumbnail). Either from too much downloading, too much viewing, or anything else. Maybe it happens if you aren't from Pakistan, really don't know what to say. Regardless, this block is temporary and will go away in 30 min / 1 hour. If you're worried about this, just use a burner account. For all show URLs, the section "Other episodes " is considered to be Season 0 as an index.
    Code:
    #video
    python widefrog.py "https://ptvflix.org/player/4185"
    #series
    python widefrog.py "https://ptvflix.org/category/843" --query=0:2:0:3
    python widefrog.py "https://ptvflix.org/category/646" --query=1:5:1:11
    - rakuten.tv
    Read this.

    - rmcbfmplay.com
    Email/password needed, as well as French IP. A list in this context means a show page where there aren't any sections labeled "Saison" (the order is left-right).
    Code:
    #video
    python widefrog.py "https://www.rmcbfmplay.com/video/rmc-bfm-play/alexandre-le-grand-la-vraie-histoire-dun-conquerant-de-legende?contentId=Product::NEUF_BFMAVOD_BAV984224866527&universe=PROVIDER"
    #list
    python widefrog.py "https://www.rmcbfmplay.com/info-programme/rmc-story/retour-a-linstinct-primaire?contentId=Product::NEUF_NUM23_N23_934016897527&universe=PROVIDER" --query=:2::4
    #series
    python widefrog.py "https://www.rmcbfmplay.com/info-programme/rmc-bfm-play/australie-la-ruee-vers-lor?contentId=Product::NEUF_BFMAVOD_BAV_623218986527&universe=PROVIDER" --query=2:4:3:4
    - rsi.ch
    Read this.

    - rtlplay.be
    Read this.

    - rtp.pt
    Read this.

    - rts.ch
    Read this.

    - rtve.es
    Read this.

    - rugbypass.tv
    Read this.

    - shahid.mbc.net
    Read this.

    - stirr.com
    Read this.

    - tf1.fr
    Email/password needed, as well as French IP. A list in this context means the sections of a show page that aren't labeled as "Tout". Examples: "Extrait", "Exclu", "Bonus", etc.
    Code:
    #video
    python widefrog.py "https://www.tf1.fr/tf1-series-films/le-chacal/videos/le-chacal-50497079.html"
    #list
    python widefrog.py "https://www.tf1.fr/tf1/les-feux-de-l-amour/videos/bonus" --query=:5::10 
    #series
    python widefrog.py "https://www.tf1.fr/tmc/les-mysteres-de-l-amour/videos" --query=18:5:19:20
    - tg4.ie
    Read this.

    - threenow.co.nz
    New Zealander IP is needed. For some reason, you need an account to watch their content on the browser but you don't need one for downloading. If a show with multiple seasons contains as well the "Extras" section, the index of that section is considered to be the next one after the last season. For some episodes, their index starts at 0 (very rare though). So make sure what you're attempting to download is correct by checking the generated commands.
    Code:
    #video
    python widefrog.py "https://www.threenow.co.nz/shows/married-at-first-sight-nz/season-4-ep-1/1713735158325/M85501-832"
    #series
    python widefrog.py "https://www.threenow.co.nz/shows/high-country/1712093997956" --query=1:5:2:1
    python widefrog.py "https://www.threenow.co.nz/shows/7-days/61183" --query=2023:5:2024:2
    python widefrog.py "https://www.threenow.co.nz/shows/below-deck/S1647-006" --query=7:2:11:4
    python widefrog.py "https://www.threenow.co.nz/shows/toke/S2279-908" --query=1:0:1:0
    - tv5mondeplus.com
    Read this.

    - uefa.tv
    Read this.

    - veeps.com
    Read this.

    - video.telequebec.tv
    Read this.

    - viki.com
    An optional account can be provided through browser cookies. If you download lots of videos, you can be blocked temporarily due to "429 too many requests".

    All shows from this site have exactly one season with all the episodes. Additionally, a show may have 2 other sections, clips, and trailers. Those are considered "seasons" (2 and 3) and can be downloaded as collections similarly. The site can display the clips and trailers in 2 ways: one big section where they are both present or 2 small separated sections. Regardless of the display method, they are still considered separated seasons as structures. Their order is top to down and left to right.
    Code:
    #video
    python widefrog.py "https://www.viki.com/videos/1250242v-bitter-sweet-hell-episode-2"
    python widefrog.py "https://www.viki.com/videos/1249260v"
    #series
    python widefrog.py "https://www.viki.com/tv/36367c-joy-of-life" --query=1:45:3:1
    python widefrog.py "https://www.viki.com/tv/35630c-because-this-is-my-first-life" --query=2:20:3:2
    python widefrog.py "https://www.viki.com/movies/37657c-project-gutenberg" --query=3:2:3:3
    - viu.com
    Read this.

    - vix.com
    Read this.

    - vrt.be
    Read this.

    - vtmgo.be
    Browser cookies are needed. I didn't manage to figure out the refresh mechanism so once in a while you're gonna have to manually refresh them by playing a random video in your browser. For some videos, Belgian IP is needed or you can configure your vtmgo account to work outside Belgium in settings (it's up to you how you solve it). A list is represented by the livestreams from the URL https://www.vtmgo.be/vtmgo/live-kijken . The order for that is left-right, up-down.
    Code:
    #video
    python widefrog.py "https://www.vtmgo.be/vtmgo/afspelen/2d6b57a5-c129-45a2-95dc-ba5e06f32716"
    #livestream
    python widefrog.py "https://www.vtmgo.be/vtmgo/live-kijken/qmusic"
    #list
    python widefrog.py "https://www.vtmgo.be/vtmgo/live-kijken" --query=:2::3
    #series
    python widefrog.py "https://www.vtmgo.be/vtmgo/familie~96a49148-59f6-420c-9b90-8b058760c467" --query=5:200:6:3
    - watch.blaze.tv
    Read this.

    - watch.globaltv.com
    Canadian IP is needed. The content that needs a provider account is not supported. To get the right URL for a collection of videos, click on a random show and you will see multiple sections for that content: Episodes, Extras, Deleted Scenes, etc. (it depends on the show). When you click on a section from those, the URL changes and that is your valid input. If the chosen section is "Episodes" and contains other subsections labeled as "Season" the input will be considered a series. In any other case, it is considered a list.
    Code:
    #video
    python widefrog.py "https://watch.globaltv.com/movie/WNET0056532040000500"
    #livestream
    python widefrog.py "https://watch.globaltv.com/channel/215422c9-d1b9-4009-aaca-32e403f22b01"
    #list
    python widefrog.py "https://watch.globaltv.com/series/32666602/collection/1054443075512/" --query=:2::4
    python widefrog.py "https://watch.globaltv.com/series/411617347723/collection/902261827613/" --query=:5::7
    #series
    python widefrog.py "https://watch.globaltv.com/series/f7a04c78-c1ff-11ee-ac50-0242ac110005/collection/4f809a02-caa1-11ee-abe3-0242ac110004/" --query=2:5:3:6
    - watch.shortly.film
    Read this.

    - watch.tbn.uk
    Read this.

    - wittytv.it
    A list in this context means the videos from a page after you press "Scopri di piu". The URL needs to have the query parameters "transmissioni" and "category_name". The manifest with the highest quality is hidden but the tool searches for it by using some simple URL editing (same as mediasetinfinity).
    Code:
    #video
    python widefrog.py "https://www.wittytv.it/uomini-e-donne/lunedi-11-marzo-2"
    #list
    python widefrog.py "https://www.wittytv.it/?trasmissioni=cat-originals&category_name=google-bar" --query=:2::4
    - zee5.com
    Even though the shows from this site have Episodes, I haven't seen any Seasons in their data structures. To get to the main URL of a show, click on a random episode, then click on the show's title. The hidden manifest with the highest quality is obtained through URL editing (thanks again @white_snake for explaining how).
    Code:
    #video
    python widefrog.py "https://www.zee5.com/global/movies/details/kaagaz/0-0-1z536625"
    python widefrog.py "https://www.zee5.com/global/tv-shows/details/navri-mile-hitlerla/0-6-4z5521328/latest"
    #list
    python widefrog.py "https://www.zee5.com/global/tv-shows/details/pavitra-rishta/0-6-133" --query=:1390::1410
    ------------------------------------------------------------------------------------------------------------------------------------------------

    After the download commands are generated and saved to a txt file, you can edit them right before launching the download commands. The benefit to this is that you can validate what the downloader generated and remove any unwanted media files right before downloading them by deleting their download commands.

    For all these services, the --query parameter is optional. It is completely ignored if it's used with individual content, and for collections, if it's missing, it will just grab the entire set. The tool allows for a txt file input as well. The file can contain a list of URLs (each URL on a newline). The advantage to this is that you can download at the same time N URLs spread across M services (provided you don't have 2 conflicting services with different geographic restrictions). So basically you can do something like this:
    Code:
    python widefrog.py "urls.txt" --query=1:2:3:4
    Where the content of "urls.txt" can be:
    Code:
    https://35mm.online/vod/animacja/pani-twardowska
    https://www.aloula.sa/en/episode/19934
    https://www.pianogroove.com/blues-piano-lessons/minor-blues-introduction/
    https://www.plus.fifa.com/en/content/when-the-world-watched/3f3a5286-32e7-4587-a094-0edb473d3ed2
    https://ptvflix.org/category/646
    Additionally, the input txt file can also contain terminal commands. If a line doesn't begin with http:// or https:// then it's not considered a URL and is passed directly to the terminal. I may extend some of these services if there are a lot of requests. For example: I may add livestream support for some sites if there's interest in it.

    N_m3u8DL-RE as a tool is great. However, it can have problems with muxing and syncing for special videos and scenarios. If you ever get a video that isn't synced perfectly with its audio, go to the config JSON file and set "ADDITIONAL_SUBS" to false. If it still doesn't work, then go to the generated commands text file and see what option of muxing was chosen (related to -M format). Using Notepad++ with find all + replace, try one of the following:
    a. -M format=mkv
    b. -M format=mkv:muxer=mkvmerge
    c. simply remove the -M format parameter entirely

    The video will get synced properly with one of these choices.

    4. Conclusion

    Do let me know if:
    - I missed some hidden subtitles.
    - Some collection queries are not working as expected (either wrong season, wrong episode, etc.).
    - A service is broken for a specific URL because no amount of testing will get rid of all bugs after all. I don't have any personal interest in any of those services so unless someone notifies me that a service is broken, I will have no way of knowing (don't expect a quick fix though).

    It would be nice if:
    - You wouldn't request a specific service to be added. When it comes to adding new services, I just cherrypick once in a while a random site based on some personal criteria when I'm bored. You can always write your own mass downloader by following this guide.
    - You wouldn't spam this post asking for download links for any of these services. You should learn to use the program since it's better in the long run or just make a separate forum post for your issue.
    - In the eventual case that you don't know how to use a specific service, just Ctrl+F search for your site and look at the example commands.
    - You wouldn't talk about paid content. Even if the program might allow for paid content downloading on the rare chance. That is entirely by accident and it's because their site is badly designed.

    Regarding errors, a message is always displayed. In any scenario, first, you check if what you want to download can be played on your browser currently. If it can be played, check the current version of your program and see if it's the latest version. If not, then update and maybe you get lucky. If the error still happens, then check the message. If it has the prefix [USER_ERROR] that's something that can be fixed by you. If instead, it has the [APP_ERROR] prefix, you should leave a message on this post with the full error. You should also add the parameter --debug to your command and write what's displayed there as well.

    For Linux, if a terminal isn't launching properly the download commands (either too many at once, or too few), then let me know of this issue. A temporary solution is modifying the config.json file and changing the number of threads for "MEDIA_DOWNLOADER" to 1.

    I'd really appreciate it if this post remains only a support thread for any eventual relevant issues. For Python-related issues, you can see Stackoverflow, and for CDM issues the sticky threads of this forum are useful. If anyone is interested in porting these services to Devine or anything else so more people can use it, then you have my full approval if you want to use this tool as a reference.

    I may drop support for a service if a random dev from their site makes it obvious that they lurk around or if their VPN restrictions increase. I'll edit this post and change the zip URLs at the top if a new version appears.

    Finally, I'd like to thank @white_snake for his testing and amazing feedback. You're awesome man.

    Edit: If you have any relevant questions, you can ask them here. Don't PM me strictly about this program. After all, this is a support thread for a reason.
    Last edited by 2nHxWW6GkN1l916N3ayz8HQoi; 24th Mar 2025 at 06:01. Reason: typos, grammar, spelling, clarifications, new services, version release, etc.
    Quote Quote  
  2. Search, Learn, Download! Karoolus's Avatar
    Join Date
    Oct 2022
    Location
    Belgium
    Search Comp PM
    Very nice share! Well done

    Btw, I could share the way the token refresh works in VTMGo if you're interested?
    Last edited by Karoolus; 14th May 2024 at 07:57.
    Quote Quote  
  3. Feels Good Man 2nHxWW6GkN1l916N3ayz8HQoi's Avatar
    Join Date
    Jan 2024
    Location
    Pepe Island
    Search Comp PM
    I'll be using this post as the next part of the first main post because of text length limitations.

    3. Usage

    - app.nzrplus.com
    Email/password are needed. A list is represented by the vods from a playlist. The order for that is top-down, regardless of the content title. A series is made up of rails and videos that are found on section pages. Any type of media is counted but only vods can be downloaded. The order is top-down and left-right.
    Code:
    #video
    python widefrog.py "https://app.nzrplus.com/video/697742"
    python widefrog.py "https://app.nzrplus.com/video/693862?playlistId=25138"
    #list
    python widefrog.py "https://app.nzrplus.com/playlist/25136" --query=:11::13
    #series
    python widefrog.py "https://app.nzrplus.com/section/BlackFerns" --query=3:7:4:1
    - auvio.rtbf.be
    Belgian IP is needed (for most content) and email/password are needed as well. If you're making an account from outside Belgium, using a VPN isn't sufficient. You need to edit your account information to fool them that you're from Belgium. Only then using a VPN is enough.

    Usually, the content that has "/media/" in its URL is considered to be individual. If you click on a show and you want a specific video, find it and click the button "Details" near the video. You will be redirected to a "/media/" URL and you can use that as input. If the show doesn't have a list of videos and you can't find the "Details" button (that usually happens for some movies), then just take the current URL that contains "/emission/" and use it as input. The default video from that page will be downloaded.

    To access the main show page, when you click on a random video, you'll see the button "Tous les episodes". Click it and you'll be redirected to a page that has "/emission/" in the URL. Regarding collections, when you click on a show with multiple videos, it can be structured in 4 ways. By year, by season, a single big section labeled as "Tous les episodes" or by multiple horizontal widget rails. In the first 2 cases, the URL is considered to be a series. The season index can be the specified year or the season itself. If there is only one section labeled "Tous les episodes" that URL will be treated like a list with top-down numbering.

    Shows with horizontal widgets are ignored and only the default video is downloaded as individual content. If you want to download the list of videos from a specific widget rail, click the button "Voir tout" on the right side and you'll be redirected to a URL that contains "/widget/". That URL is the valid input and will be treated like a list with the order top-down, left-right (default unsorted/unfiltered order). Some shows have the additional button "Extraits & bonus". Click on it and you'll be redirected to a URL that ends in "/bonus". You can download that as well and it will be considered a list with the same defined numbering.

    You can also download audio content. Go to the podcasts section and select a show or a specific podcast. The same rules that were defined previously for videos, apply here as well. Also, livestream videos and livestream audio can be downloaded as well. Unfortunately, a livestream audio can only be downloaded through the use of collections since the site doesn't offer a URL for that content.
    Code:
    #video
    python widefrog.py "https://auvio.rtbf.be/media/attraction-attraction-s01-3018437"
    python widefrog.py "https://auvio.rtbf.be/emission/titane-27377"
    #audio
    python widefrog.py "https://auvio.rtbf.be/media/un-jour-dans-le-sport-14-aout-2004-3164197"
    #livestream video
    python widefrog.py "https://auvio.rtbf.be/live/roland-garros-2024-31-mai-direct-tipik-526661"
    #livestream audio
    python widefrog.py "https://auvio.rtbf.be/chaine/classic-21-5" --query=:2::2
    #list
    python widefrog.py "https://auvio.rtbf.be/widget/19164" --query=:5::7
    python widefrog.py "https://auvio.rtbf.be/widget/22508?context%5BprogramId%5D=8340" --query=:2::4
    python widefrog.py "https://auvio.rtbf.be/emission/la-theorie-du-y-11043/bonus" --query=:6::7
    python widefrog.py "https://auvio.rtbf.be/emission/pandore-20618" --query=:5::8
    python widefrog.py "https://auvio.rtbf.be/chaine/musiq3-7" --query=:2::3
    #series
    python widefrog.py "https://auvio.rtbf.be/emission/le-cactus-4043" --query=2017:180:2018:5
    python widefrog.py "https://auvio.rtbf.be/emission/l-art-du-crime-27164" --query=3:2:4:2
    - canalplus.com
    A majority of this site is paid but there are free shows once in a while. For most content, you need L1 for the higher quality levels (720p+). There is rare content where you can get 720p+ with an L3 and for some reason, you can get 1080p with L3 for some content from the /pl/ section. You can download a livestream from the section
    https://www.canalplus.com/live/ or from
    https://www.canalplus.com/chaines/ (this one only works with URLs that contain "/h/").

    A series for this site is usually made up of seasons and episodes. For this, make sure you take the URL of the show, not the URL of a content category (episodes, bonus, extra, etc.). The mentioned content categories can be downloaded as well. In this case, a series is made up of horizontal rails and videos. Some rails may contain articles or other non-video elements. Those elements are counted but they can't be downloaded in any way. If 2 categories share the same modified URL, then their rails are counted together.

    For individual content, make sure you use the URL that contains "/h/". If you can't obtain that URL for a specific episode of a show, then use the show's URL with the query option. Credit goes to @brick for explaining the playready pssh pywidevine trick.
    Code:
    #video
    python widefrog.py "https://www.canalplus.com/sport/xander-schauffele-double-la-mise-the-open-2024/h/25935800_50001"
    python widefrog.py "https://www.canalplus.com/divertissement/hot-ones-jerome-niel-vrille-completement/h/21582462_50001"
    python widefrog.py "https://www.canalplus.com/pl/film/wszystkie-kryminalne-tropy/h/14119895_70033"
    #livestream
    python widefrog.py "https://www.canalplus.com/live/?channel=480"
    python widefrog.py "https://www.canalplus.com/divertissement/la-piscine-de-jordan-de-luxe/h/26012262_50013"
    #series
    python widefrog.py "https://www.canalplus.com/jeunesse/les-kassos/h/12456299_50001" --query=3:15:5:3
    python widefrog.py "https://www.canalplus.com/pl/seria/the-office-pl/h/11800604_70026/explorer/bonus/" --query=2:2:5:2
    python widefrog.py "https://www.canalplus.com/series/d-argent-et-de-sang/h/22860111_50001/bonus/" --query=5:3:7:4
    python widefrog.py "https://www.canalplus.com/series/la-fievre/h/24268578_50001/bandes-annonces/" --query=1:1:1:1
    - channel4.com
    British IP is needed. For some reason, you can also download livestreams that are off-air. The shows for this site are structured in seasons and episodes. If a show doesn't have a dropdown list that lets you select the season, that show is still structured in the same way. Even if its episodes are displayed chaotically. In that case, look at the episode's name to determine its season and index. For the special episodes that don't have an index in their name, I take their index straight from the API so it's completely random from the user's point of view. Nothing I can do about that. Credit goes to @angela for her default kid to pssh formula from the hell noob pack code.
    Code:
    #video
    python widefrog.py "https://www.channel4.com/programmes/infinite/on-demand/74802-001"
    #livestream
    python widefrog.py "https://www.channel4.com/now/C4"
    #series
    python widefrog.py "https://www.channel4.com/programmes/ramsays-kitchen-nightmares-usa" --query=5:14:6:3
    python widefrog.py "https://www.channel4.com/programmes/8-out-of-10-cats-does-countdown" --query=10:3:11:2
    - cineverse.com
    American IP is needed. An optional account can be provided through browser cookies. For some livestreams you need an American IP for downloading as well.
    Code:
    #video
    python widefrog.py "https://www.cineverse.com/watch/CEG10033956/Bigfoot-Vs-The-Illuminati?vod_type="
    python widefrog.py "https://www.cineverse.com/watch/1000000025139/Big-Freaking-Snake?vod_type=trailer"
    #livestream
    python widefrog.py "https://www.cineverse.com/livetv?q=ComedyDynamics"
    #series
    python widefrog.py "https://www.cineverse.com/details/YUGIOH/Yu-Gi-Oh" --query=3:46:4:2
    python widefrog.py "https://www.cineverse.com/details/1000000004517/Judge-Roy-Bean-Collection" --query=1:4:1:6
    - docplus.com
    A list is represented by the videos from a category. The order is left-right, top-down.
    Code:
    #video
    python widefrog.py "https://www.docplus.com/details/this-is-not-financial-advice/pPa7OWPd/"
    #list
    python widefrog.py "https://www.docplus.com/category/pop-culture/WWsdRNPJ/" --query=:18::21
    - eurovisionsport.com
    Email/password are needed. The manifests from this site are kinda broken and you'll get 500 internal errors for random fragments. Luckily, you can ignore this and the video can still be played. A series in this context is structured in rails/videos. A rail is always horizontal and can be found in a sport category or federation category.

    A series can also mean a past competition that took place on multiple days. If a day has at least one video, then it's considered a "season", otherwise it's ignored. The season numbering starts from 1 regardless of the day number. One minor problem with this feature is that the API sorting method for videos on a specific day isn't consistent. So their index position might be wrong in some cases (+ or - 1). If you applied a query on a particular episode range, make sure what you download is good. But if you're interested in downloading a full day of videos, there won't be any problems.
    Code:
    #video
    python widefrog.py "https://eurovisionsport.com/mediacard/EVS_240429_LEC_25261_"
    #series
    python widefrog.py "https://eurovisionsport.com/explore/sport?id=EBU-Home-Racket" --query=1:3:2:2
    python widefrog.py "https://eurovisionsport.com/explore/federation?id=LandingPage-CJR" --query=2:2:3:1
    python widefrog.py "https://eurovisionsport.com/explore/competition?id=Generic-Schedule-Landing-Page&cId=20240229IBUHolmenkollen" --query=2:3:3:2
    - fifa.com
    Embedded /watch/ fifa URLs that redirect to plus.fifa.com and other /watch/ URLs that don't redirect can be downloaded. The ones that redirect to plus.fifa.com can be downloaded in 2 video versions: with and without the burned-in Fifa logo. Credit goes to @lzaa and @larley for giving hints about how to download the encrypted MPD version when the m3u8 media isn't working. If you want the free-logo version make sure the plus.fifa.com service isn't present in the services folder (move it somewhere else or delete it if you don't need it).

    If you're using the release version, then you can't choose what version you want downloaded. A series for this site is represented by the URL of a fifa.com episode. It's structured in seasons and episodes. A series can also be structured in pages and videos that are the result of a search query. A page is always made up of 25 elements and can contain non-video elements as well (such as text articles). Elements of this kind are counted but can't be downloaded in any way. Make sure that you search for content only from "FIFA" (not "INSIDE FIFA"), thus the "source=FIFA" parameter has to be present in the URL.
    Code:
    #video
    python widefrog.py "https://www.fifa.com/en/watch/7wST4MTAbpXRAAmufEpCbx"
    python widefrog.py "https://www.fifa.com/en/watch/f4fca463-7321-4019-b0ca-96a221608c28"
    python widefrog.py "https://www.fifa.com/en/watch/movie/5U5nbmAEMkCR2NsL3yeKkM"
    #series
    python widefrog.py "https://www.fifa.com/en/watch/series/3to1B8QAwfphSKO7TO5fz/243cTtTU0bNJcnRzHXhWuu/p4cFrSmlPcV2Eq9QHEHTH" --query=1:2:1:4
    python widefrog.py "https://www.fifa.com/en/search?q=ronaldo+and+messi&source=FIFA&ftype=video&fdateFrom=1900-01-01&fsortBy=dateDesc&fpage=3" --query=4:20:5:2
    - filmzie.com
    Pages that are structured in seasons are considered series. The episodes of a show's season are always numbered from left to right and starting from 1, regardless of their name.
    Code:
    #video
    python widefrog.py "https://filmzie.com/content/raven?sourceId=613744175971e8001d714cdc"
    python widefrog.py "https://filmzie.com/content/stop-at-nothing-the-lance-armstrong-story-2014"
    #series
    python widefrog.py "https://filmzie.com/content/rally-north-america-2018" --query=2:5:3:2
    - france.tv
    French IP is needed for most content, as well as for downloading. All video URLs end in html. Text article URLs also end in html but aren't supported. Each season contains the "Voir toute la saison" button. The videos from that page will be downloaded, including the bonus videos. As an episode index, the one in their title is taken into account.

    If a video doesn't contain an index, then it's considered a bonus video, and their index is randomly assigned. The extra video indexes start from the last official episode index. A list for this site is made up of videos from /collection/ URLs and also from /toutes-les-videos/ for any show. The order for that is top-down, left-right.
    Code:
    #video
    python widefrog.py "https://www.france.tv/spectacles-et-culture/festival-rock-en-seine/6428750-gossip-en-concert-a-rock-en-seine-2024.html"
    python widefrog.py "https://www.france.tv/enfants/six-huit-ans/tortues-ninja-les-chevaliers-d-ecaille/saison-1/6137135-a-la-recherche-du-technodrome.html"
    python widefrog.py "https://www.france.tv/films/6096218-butch-cassidy-et-le-kid.html"
    #list
    python widefrog.py "https://www.france.tv/collection/4503166-l-abc-de-bertrand-chameroy/" --query=:10::15
    python widefrog.py "https://www.france.tv/france-3/ouija-un-ete-meurtrier/toutes-les-videos/" --query=:3::6
    #series
    python widefrog.py "https://www.france.tv/france-2/dix-pour-cent/" --query=2:5:3:2
    python widefrog.py "https://www.france.tv/slash/skam-france/" --query=2:12:3:2
    - m6.fr
    French IP (for most content) and email/password are needed. Make sure your account has at least one profile that is adult (not kids). If you ever edit the account profiles (especially if you ever delete one), delete the service's corresponding cache and run the script after that. Audio podcasts can be downloaded as well but unfortunately only in collections because the site doesn't offer easily an individual URL for a specific podcast.

    A series in this context is structured in rails of videos. Each horizontal rail (with little arrows on the left/right side) represents a season. The numbering is top-down and left to right. Doesn't matter how the rails are called (even if they are named "Saison <number>"). Videos that aren't released yet and are locked, aren't counted in the series collection. In the rare cases of podcasts, the rail of contents is considered to be vertical.
    Code:
    #video
    python widefrog.py "https://www.m6.fr/below-deck-mediterranee-p_26014/s4-e1-pardonnez-mon-francais-c_13075174"
    #audio
    python widefrog.py "https://www.m6.fr/les-voix-du-crime-p_25750" --query=1:2:1:2
    #series
    python widefrog.py "https://www.m6.fr/lois-et-clark-les-nouvelles-aventures-de-supe-p_25720" --query=3:17:4:2
    python widefrog.py "https://www.m6.fr/6play/top-5-series-realite-6play-5-f_887" --query=1:5:2:1
    python widefrog.py "https://www.m6.fr/lis-moi-une-histoire-p_25892" --query=1:3:1:5
    - maoriplus.co.nz
    New Zealander IP is needed for most content. A show is made up of multiple seasons and episodes. The show's seasons are always ordered left-right and are numbered from 1, regardless of their name. The episodes keep their original index that is displayed on the page.
    Code:
    #video
    python widefrog.py "https://www.maoriplus.co.nz/movie/luis-and-the-aliens/play"
    python widefrog.py "https://www.maoriplus.co.nz/show/head-start/play/2587370536001"
    #livestream
    python widefrog.py "https://www.maoriplus.co.nz/live-tv/whakaata-maori"
    python widefrog.py "https://www.maoriplus.co.nz/live-tv/te-reo"
    #series
    python widefrog.py "https://www.maoriplus.co.nz/show/marae-diy" --query=1:8:2:2
    python widefrog.py "https://www.maoriplus.co.nz/show/nga-manu-korero-2024" --query=1:30:2:2
    - midnightpulp.com
    For most content, you need an American IP (except livestreams) and also an account. The account is provided through browser cookies. A series is made up of seasons and episodes.
    Code:
    #video
    python widefrog.py "https://www.midnightpulp.com/watch/CEG10033897/Notzilla?vod_type="
    python widefrog.py "https://www.midnightpulp.com/watch/1000000012025/Til-Death-Do-Us-Part?vod_type=trailer"
    #livestream
    python widefrog.py "https://www.midnightpulp.com/livetv?q=RetroCrush"
    #series
    python widefrog.py "https://www.midnightpulp.com/details/1000000013236/Monster-Squad" --query=1:103:1:105
    - mtv.fi
    For most content, you need a Finnish IP and also an account. The account is provided through browser cookies. A series is made up of seasons and episodes. The order of the seasons is left-right, regardless of name, and for episodes, it is from top to down. The clips of a series are ignored. A list is made up of clips from a search query at
    https://www.mtv.fi/hae
    The order of those clips is also top to down.
    Code:
    #video
    python widefrog.py "https://www.mtv.fi/lyhyet/44bcae898220984417b4/video-suomen-vanhin-salatut-elamat-fani-leo-rautanen-96-ei-jata-jaksoakaan-valiin"
    python widefrog.py "https://www.mtv.fi/video/17e4c6f4ffe2371423cb/jakso-1-pikkujoulu"
    #list
    python widefrog.py "https://www.mtv.fi/hae/fin%20vids" --query=:15::16
    #series
    python widefrog.py "https://www.mtv.fi/ohjelma/970e8c6279e5cf05de1a/hautalehto" --query=1:3:1:4
    - nemzetiarchivum.hu
    Only the "tevemusorok" section is allowed (urls containing /m3/open). A series is represented by pages and videos. The videos are numbered from up to down regardless of their name.
    Code:
    #video
    python widefrog.py "https://nemzetiarchivum.hu/m3/open?id=M3-bi9rWWdUWnVrV2hqbndzZzVXY0xBRE8yV2ZFN3QyRmlYTG52aVdVTHlnUT0"
    #series
    python widefrog.py "https://nemzetiarchivum.hu/m3/open?series=U3rDoXphZHVuaw%3D%3D" --query=2:19:3:1
    - netflix.com
    As mentioned previously, only the /tudum/ section is allowed. From what I've seen, only non-DRM videos are present there. Due to the way the pages are structured, you can only download an individual video by querying it using its index. A list for this site means the list of videos found on any /tudum/ page. The order is top-down. The site doesn't use srt/vtt as subtitles.
    Code:
    #video
    python widefrog.py "https://www.netflix.com/tudum/articles/baby-reindeer-ending-analysis" --query=:2::2
    #list
    python widefrog.py "https://www.netflix.com/tudum/articles/squid-game-the-challenge-where-are-they-now" --query=:5::8
    - ninateka.pl
    Only the audio, series, and movies contents are allowed.
    Code:
    #video
    python widefrog.py "https://ninateka.pl/movies,1/katarzyna-nosowska--made-in-polska,9141"
    python widefrog.py "https://ninateka.pl/series,2/to-sie-nie-miesci-w-glowie--renata-piatkowska-odcinki,39420/odcinek-4,S01E04,4932"
    python widefrog.py "https://ninateka.pl/audio,153683/20-lat-po-upadku-muru-odcinki,51360/odcinek-2,S01E02,6251"
    #series
    python widefrog.py "https://ninateka.pl/series,2/dziwny-swiat-kota-filemona-odcinki,21900" --query=1:5:1:7
    python widefrog.py "https://ninateka.pl/audio,153683/szpital-przemienienia--stanislaw-lem-odcinki,23820" --query=1:10:1:13
    - play.tv3.lt
    The service has support for h265 content. The h265 manifest will be merged with the default h264 one and can be downloaded at the same time. Lithuanian IP is needed if you want to watch some content on the browser, but you don't need a VPN at all when it's about downloading. The site has some livestreams but unfortunately, they can't be downloaded. The service has support for live streams built in just in case but I haven't found any live content that uses Widevine on their site to test it.

    A list for this site means the page of videos that you access when you click "Žiūrėti viską >" on a horizontal grid of videos or after you choose a category from "Kategorija >". Only the default unsorted order is considered and the numbering is left-right, top-down. The shows of this site can be found in the "Serialai", "Laidos" and "Vaikams" sections. If you click a random episode, you can access its show by clicking the main show's title.

    The episodes of a show's season are usually numbered from right to left if proper numbering is missing (like S02E02). Some seasons may have an additional grid of videos called "Klipai". Those are short clips related only to that specific season. That grid can be downloaded as a collection as well and is considered to be an additional season. The "Klipai" videos are numbered from left to right instead. If a show has the numbered seasons 1, 10, and 100 then their corresponding "Klipai" seasons are numbered 101, 102, and 103 (in the same order, 1<=>101, 10<=>102, and 100<=>103).

    The script will take a long time if you're trying to download many videos at once for this site due to their security. If it takes too long for a single video then make sure you can watch it in your browser.
    Code:
    #video
    python widefrog.py "https://play.tv3.lt/series/nenugalima-meile,serial-6053655/serija-13,episode-6053757"
    python widefrog.py "https://play.tv3.lt/shows/starkus-stato-,serial-3535772/serija-6,episode-4853188"
    python widefrog.py "https://play.tv3.lt/news/dienos-pjuvis,serial-2941600/dienos-pjuvis-is-ko-atims-ir-kam-prides--is-kur-valdzia-paims-pinigu-gynybai,episode-7577486"
    python widefrog.py "https://play.tv3.lt/clip/tv3-zinios-ukraina-rusijai-kur-yra-zuvusiu-karo-belaisviu-kunai,clip-6831718"
    python widefrog.py "https://play.tv3.lt/Sports/ilgoji-pertrauka,serial-6858901/ilgoji-pertrauka-pao-triumfas-kaip-trauma-keicia-kevanso-situacija-ir-grubi-teiseju-klaida-panevezyje-,episode-7491244"
    python widefrog.py "https://play.tv3.lt/lives/tv3-lt,live-2831094/tv3-zinios,programme-7547429"
    python widefrog.py "https://play.tv3.lt/kids_series/ar-zinai-kaip-as-tave-myliu,serial-1601493/serija-49,episode-1601570"
    #list
    python widefrog.py "https://play.tv3.lt/news/sections/tv3-zinios-1600,2870499" --query=:5::10
    python widefrog.py "https://play.tv3.lt/shows/slocaltvshowslt,4197901" --query=:7::9
    python widefrog.py "https://play.tv3.lt/news/tv3_zinios,4198085" --query=:3::7
    #series
    python widefrog.py "https://play.tv3.lt/shows/tevai-paprastai,serial-4654553" --query=3:10:4:2
    python widefrog.py "https://play.tv3.lt/series/cesapiko-krantai,serial-5649152" --query=3:2:4:2
    python widefrog.py "https://play.tv3.lt/news/dienos-pjuvis,serial-2941600" --query=2022:700:2023:2
    python widefrog.py "https://play.tv3.lt/movies/madagaskaro-pingvinai,serial-3187159" --query=3:5:3:7
    - play.virginmediatelevision.ie
    Irish IP is needed only when querying series. A series is made up of seasons and episodes. The episodes keep their original index. A series can also be represented by rails and videos from the catch-up pages (order is top-down, left-right). All types of content are counted, but only "/watch/" links can be downloaded.
    Code:
    #video
    python widefrog.py "https://play.virginmediatelevision.ie/watch/vod/52666453/a-trip-to-kenmare"
    python widefrog.py "https://play.virginmediatelevision.ie/watch/replay/19084759/irelands-education-crisis"
    #series
    python widefrog.py "https://play.virginmediatelevision.ie/shows/44082036-3212-11ef-bd6d-020f80c0527e/coronation-street" --query=65:11409:65:11410
    python widefrog.py "https://play.virginmediatelevision.ie/shows/9ff258f5-2a5d-11ef-b7e3-0276c1f87d2f/heartbeat" --query=4:15:5:2
    python widefrog.py "https://play.virginmediatelevision.ie/vod/34806/virgin-media-one" --query=3:9:4:2
    - play.xumo.com
    American IP is needed only for accessing series content. Only the "/free-movies/" and "/tv-shows/" sections are allowed.
    Code:
    #video
    python widefrog.py "https://play.xumo.com/free-movies/seraphim-falls/XM00R7QW73DXD6"
    python widefrog.py "https://play.xumo.com/free-movies/dracula-reborn/XM06AQW9B5G0D9"
    #series
    python widefrog.py "https://play.xumo.com/tv-shows/anger-management/XM0QSM8FBW0SM4" --query=3:20:4:2
    python widefrog.py "https://play.xumo.com/tv-shows/the-mothers-in-law/XM0U6K557JDBPH" --query=1:5:1:8
    - player.pl
    In the browser, you may need a Polish IP and also a free account to view multiple free videos, but luckily they don't enforce this at all for downloading. A series is made up of seasons and episodes. Sometimes a show may have a dropdown list made up of episode intervals instead of seasons. It doesn't matter. The videos are still structured in seasons/episodes, just look at their URLs (for example S01E01).
    Code:
    #video
    python widefrog.py "https://player.pl/filmy-online/1800-gramow,169874"
    python widefrog.py "https://player.pl/seriale-online/receptura-odcinki,32759/odcinek-3,S01E03,216097"
    python widefrog.py "https://player.pl/programy-online/projekt-lady-odcinki,4554/odcinek-10,S06E10,219192"
    python widefrog.py "https://player.pl/strefa-sport/motocyklicznie-odcinki,120/odcinek-3,S03E03,2062"
    #series
    python widefrog.py "https://player.pl/seriale-online/lekarze-odcinki,981" --query=2:10:3:2
    python widefrog.py "https://player.pl/seriale-online/19--odcinki,4814" --query=4:399:5:402
    python widefrog.py "https://player.pl/programy-online/one-night-squad-odcinki,31426" --query=1:4:1:6
    python widefrog.py "https://player.pl/strefa-sport/motocyklicznie-odcinki,120" --query=3:3:3:5
    - rakuten.tv
    I don't know how relevant is this but I advise you to use an emulated cdm that's from Google Pixel. If you use a different CDM and the tool is not working, I'm gonna have to take a look in private at that CDM and how the downloader is behaving. The site is weird when it comes to manifests. A video with multiple audio tracks in different languages has multiple different manifest mpd URLs. So to get all the audio tracks you need to request all the mpd URLs. To include them all in one single download, I merged them. I don't know how good is this fix so let me know if the tool crashes for a specific video with multiple audio tracks.

    You can download trailers for any content. When you click on a movie/show, you'll see a button called "Trailer". Click on it and take the updated URL if you want that trailer. If you want to download a show with series/episodes click on one of them and a popup window will appear. The URL will change and you can take that as valid input (regardless of where the show was found). Some seasons may not be numbered properly (some can use years as an index) so the default order is top-down regardless of what's written there.

    The livestream subtitles are kinda weird for some content. Some of the subtitles are longer than the live content itself when you download a portion of it so it is advised to skip any captions/additional subtitles when dealing with livestreams. Credit goes to @stabbedbybrick for explaining in forum posts why you can't use the browser requests when dealing with this site and some possible solutions. For the following commands, GLOBAL was used to replace the country because it shouldn't be relevant.
    Code:
    #video
    python widefrog.py "https://www.rakuten.tv/GLOBAL/player/movies/stream/bojan-beyond-the-smile"
    python widefrog.py "https://www.rakuten.tv/GLOBAL/player/movies/trailer/rumeysa-walking-tall"
    python widefrog.py "https://www.rakuten.tv/GLOBAL/player/episodes/stream/fast-forward-1/fast-forward-1-2"
    python widefrog.py "https://www.rakuten.tv/GLOBAL/player/seasons/trailer/champions-1"
    #livestream
    python widefrog.py "https://www.rakuten.tv/GLOBAL/live_channels/gusto-tv-new"
    #series
    python widefrog.py "https://www.rakuten.tv/GLOBAL/gardens/avod-fast?content_type=tv_shows&tv_show_id=discovering-canary-islands&content_id=discovering-canary-islands-1" --query=1:3:2:2
    python widefrog.py "https://www.rakuten.tv/GLOBAL/search?q=fast&content_type=tv_shows&tv_show_id=fast-forward&content_id=fast-forward-1" --query=1:2:1:4
    - rsi.ch
    This site doesn't use DRM at all. Only the /play/ section is supported. Swiss IP is needed for most content (not for the downloading stage though). The only livestreams that are allowed are the ones that contain the query parameter "urn" in their URL. A list for this site means the collection of URLs that are the result of a filtered search. After pressing the search button ("Cerca"), select at least one filter, click apply, and take the updated URL as input.

    A series for this site is represented by the page of a show. If you can't find it, then click on a random video, scroll down, and click "Pagina del programma". Each section of videos represents a season. Some extra videos (like trailers), may appear before the rails and their group is considered a "season" as well. The order is top-down, left-right, regardless of the section's name. A series can also mean the videos from a URL that contains the path /detail/ in it. If you see a group of videos with a little arrow, you can click on it and you'll be redirected to a "/detail/" URL.

    A weird bug happens rarely on their front end and sometimes you get some videos appearing multiple times on specific collections. So the index of downloaded videos may not match with what is shown on the page. Not my fault since it's a bug on their side. Credit goes to @aqzs for explaining the forward IP trick.
    Code:
    #video
    python widefrog.py "https://www.rsi.ch/play/tv/-/video/euro-2024-lunico-precedente-agli-europei-tra-svizzera-e-italia-e-lultima-vittoria-rossocrociata-27-06-2024?urn=urn:rsi:video:2188754"
    #livestream
    python widefrog.py "https://www.rsi.ch/play/tv/-/video/euro-2024-la-rete-dell1-1-di-mattia-zaccagni-in-croazia-italia-24-06-2024?urn=urn:rsi:video:2186168"
    #list
    python widefrog.py "https://www.rsi.ch/play/ricerca?query=oggi&shows=urn%3Arsi%3Ashow%3Atv%3A703571&topics=urn%3Arsi%3Atopic%3Atv%3A7&properties=playableAbroad" --query=:5::7
    #series
    python widefrog.py "https://www.rsi.ch/play/tv/programma/hudson-e-rex?id=2138198" --query=2:20:3:1
    python widefrog.py "https://www.rsi.ch/play/tv/programma/la-strategia-dellacqua?id=702315" --query=1:1:2:2
    python widefrog.py "https://www.rsi.ch/play/tv/programma/a-tutta-champions?id=703950" --query=1:4:1:6
    python widefrog.py "https://www.rsi.ch/play/tv/detail/i-video-piu-recenti?id=cf7aa4e9-b234-41de-ac6c-84bf50e1bcc7" --query=1:5:1:10
    - rtp.pt
    Only the /play/ section is allowed. Some videos require Portuguese IP for running the script and also downloading. Any video can be made up of multiple parts. That's why a video's index will always be represented by a number with a decimal of 2 digits. For example, the fifth video will have the index 5.01, 5.02, 5.03, ..., or 5.99, depending on what part of the video is wanted. If a video doesn't have parts, it is still considered to be made up of only one part, so a decimal is still used.

    The seasons of a show are numbered from top to down (or left to right, depending on the case) and starting from 1, regardless of the season name. The episodes are numbered left to right, and top-down, regardless of the episode's name. To query a series, a show's main URL must be used. To obtain it, use the search function of the site with the show's name and copy the obtained URL. If a show doesn't have a dropdown list from where you can pick a specific season, the season's default index is 1. The same applies to podcasts.
    Code:
    #video
    python widefrog.py "https://www.rtp.pt/play/p13934/e797189/grandiosa-enciclopedia-do-ludopedio"
    python widefrog.py "https://www.rtp.pt/play/p13966/e800022/eleicoes-mocambique-2024/1275407"
    python widefrog.py "https://www.rtp.pt/play/zigzag/p9815/e799964/a-experiencia-do-becas"
    python widefrog.py "https://www.rtp.pt/play/palco/p12410/e725039/simao-solis"
    python widefrog.py "https://www.rtp.pt/play/estudoemcasa/p7907/e508323/portugues-12-ano"
    #audio
    python widefrog.py "https://www.rtp.pt/play/p13339/e798838/avenidas-novas"
    python widefrog.py "https://www.rtp.pt/play/zigzag/p10990/e669853/isso-e-dartista"
    python widefrog.py "https://www.rtp.pt/play/palco/p12895/e755110/quis-saber-quem-sou-podcast"
    #livestream video
    python widefrog.py "https://www.rtp.pt/play/direto/rtpmadeira"
    #livestream audio
    python widefrog.py "https://www.rtp.pt/play/direto/radiolusitania"
    python widefrog.py "https://www.rtp.pt/play/zigzag/direto/radio"
    #series
    python widefrog.py "https://www.rtp.pt/play/p12834/bem-vindos-tarde" --query=3:213.02:4:1.01
    python widefrog.py "https://www.rtp.pt/play/p13922/os-relogios-do-diabo" --query=1:2.01:1:4.01
    python widefrog.py "https://www.rtp.pt/play/p12832/um-proverbio-por-dia-nao-sabe-o-bem-que-lhe-fazia" --query=1:4.01:1:5.01
    python widefrog.py "https://www.rtp.pt/play/zigzag/p11477/a-ovelha-chone" --query=2:20.01:3:1.01
    python widefrog.py "https://www.rtp.pt/play/zigzag/p12588/dinoster-os-herois-quanticos" --query=1:8.01:1:9.01
    python widefrog.py "https://www.rtp.pt/play/zigzag/p8686/as-tres-pancadas" --query=1:10.01:1:12.01
    python widefrog.py "https://www.rtp.pt/play/palco/p8687/integral-dos-concertos-para-piano-de-beethoven" --query=1:3.01:1:4.01
    python widefrog.py "https://www.rtp.pt/play/palco/p12895/quis-saber-quem-sou-podcast" --query=1:6.01:1:7.01
    python widefrog.py "https://www.rtp.pt/play/estudoemcasa/p7866/leitura-e-escrita-10-ao-12-ano" --query=1:18.01:1:19.01
    - rtve.es
    Only the section /play/ is allowed. Spanish IP is needed to extract video information (not needed for downloading, however). From a series, only the episodes and clips tabs can be downloaded. The seasons are numbered from 1 starting from top to down, left to right, regardless of the "temporada" index. If no temporada is visible, then the default season is 1.

    The clips category is considered to be the next one after the last temporada season index. The episodes are numbered from 1, starting from left to right, top to down, regardless of the episode name.
    Code:
    #video
    python widefrog.py "https://www.rtve.es/play/videos/cine-de-siempre/cine-siempre-zampo-yo/16428861/"
    #series
    python widefrog.py "https://www.rtve.es/play/videos/lazos-de-sangre/" --query=7:6:8:2
    python widefrog.py "https://www.rtve.es/play/videos/esto-no-es-suecia/" --query=1:7:2:2
    - rugbypass.tv
    Email/password are needed. A list is represented by the vods from a playlist. The order for that is top-down, regardless of the content title. A series is represented by shows made up of seasons/episodes. The seasons/episodes are always numbered top-down and starting from 1, regardless of their name. To access the main URL of a show, you can use the search function of the site.

    A series can also be made up of rails and videos that are found on section pages. Similarly, any type of media is counted but only vods can be downloaded. The order is top-down and left-right.
    Code:
    #video
    python widefrog.py "https://rugbypass.tv/video/685791?t=0"
    python widefrog.py "https://rugbypass.tv/video/647253?playlistId=24170"
    #list
    python widefrog.py "https://rugbypass.tv/playlist/24241" --query=:5::7
    #series
    python widefrog.py "https://rugbypass.tv/series/984" --query=2:4:3:1
    python widefrog.py "https://rugbypass.tv/section/Rugby%20World%20Cup" --query=9:6:10:1
    - shahid.mbc.net
    When running the service for the first time, the initialization stage will take around 30 seconds (after that, the cache is used). There is some premium content that becomes free if you use an Emirati IP. Because Arabic names are bugged, some of the URLs will have the content ID as the output name. All shows have an episode section. Some can have additional sections like "Trailers", "Clips", etc. Those can be downloaded as collections. For each season, those extra videos are all grouped (in the same order as the original sections).

    If you have seasons 3, 7, and 9, then their corresponding extra seasons are 10, 11, and 12 (same order 3 <=> 10, 7 <=> 11, 9 <=> 12). Because a show doesn't have a main page, it doesn't matter which season URL you're using as input. The only thing that matters is the query range. Credit goes to @aqzs for explaining the MPD trick so you can obtain the highest quality available.
    Code:
    #video
    python widefrog.py "https://shahid.mbc.net/en/player/episodes/Cloud-Kitchen-season-1-episode-1/id-1008736"
    python widefrog.py "https://shahid.mbc.net/en/player/movies/Special-Interview/id-979254"
    #livestream
    python widefrog.py "https://shahid.mbc.net/en/livestream/MBC1/livechannel-387238"
    #series
    python widefrog.py "https://shahid.mbc.net/fr/series/Leh-Laa%3F!-season-1/season-413520-413521" --query=3:10:4:2
    python widefrog.py "https://shahid.mbc.net/ar/shows/%D9%85%D8%B9-%D8%A7%D9%84%D9%85%D8%B3%D8%AA%D9%83%D8%A7%D9%88%D9%8A/show-88548" --query=1:1:1:4
    - stirr.com
    Some content is region-locked. The site is an American streaming service so I guess you need an American IP but I didn't manage to find one that works. Also if someone finds some DRM content on this site, let me know. For livestreams, some /watch/ URLs can also be live. For series, when clicking on a show, a popup window will appear. Near the play button, there's a button that says "Copy URL". Use that URL as input for the series.
    Code:
    #video
    python widefrog.py "https://stirr.com/watch/6417/beetlejuice-beetlejuice-official-trailer"
    python widefrog.py "https://stirr.com/watch/5935/independence-day-4th-of-july-a-fireworks-celebration"
    python widefrog.py "https://stirr.com/watch/4140?type=series&series_id=170&season_id=231"
    #livestream
    python widefrog.py "https://stirr.com/live?channel_id=5274"
    python widefrog.py "https://stirr.com/watch/5726/nautical-channel"
    #series
    python widefrog.py "https://stirr.com/tv-shows/170" --query=1:6:2:2
    - tg4.ie
    The language used by the site doesn't matter. To query a series, make sure you're using the show URL and not the episode URL. To find the show URL, use URL editing, the site's search function, or even Google.
    Code:
    #video
    python widefrog.py "https://www.tg4.ie/en/player/categories/sport-tv-player/play/?pid=6362689964112&title=GAA%202024&series=GAA%202024&genre=Sport"
    python widefrog.py "https://www.tg4.ie/ga/player/catagoir/dramaiocht/seinn/?pid=5833836741001&title=F%C3%ADorghael&series=Oscailt&genre=Drama"
    #series
    python widefrog.py "https://www.tg4.ie/en/player/categories/irish-music-series/?series=Sl%C3%AD%20na%20mBeaglaoich&genre=Ceol" --query=2:3:3:2
    python widefrog.py "https://www.tg4.ie/ga/player/catagoir/faisneis/?series=Bailte&genre=Faisneis" --query=3:8:4:1
    - tv5mondeplus.com
    The site may redirect to other websites if accessed in specific countries. In that case, use a VPN. You can download shows, movies, and podcasts. A list in the context of this site, means the list of podcasts from a podcast page. The order for that is down to top.
    Code:
    #video
    python widefrog.py "https://www.tv5mondeplus.com/en/series-et-films-tv/drame/double-faute-s-1-e4-revers/play"
    python widefrog.py "https://www.tv5mondeplus.com/en/cinema/policier-et-suspense/solo"
    #audio
    python widefrog.py "https://www.tv5mondeplus.com/en/podcast/subcategory/truc-culte-13840647_74079A/play"
    #list
    python widefrog.py "https://www.tv5mondeplus.com/en/podcast/subcategory/pour-que-nature-vive_74079A" --query=:5::15
    #series
    python widefrog.py "https://www.tv5mondeplus.com/en/series-et-films-tv/policier-et-suspense/nicolas-le-floch" --query=3:2:5:2
    - uefa.tv
    Browser cookies are needed for this service. A list is represented by the vods from a playlist. Any type of media is counted but only vods can be downloaded from that playlist. The order is top-down. A list can also be represented by the vods from a search result (only the videos category). The order for that is top-down, left-right. A series is made up of rails and videos that are found on competition pages. The first big rail that takes the whole screen doesn't count. Similarly, any type of media is counted but only vods can be downloaded. The order is top-down and left-right. If someone finds a video with subtitles, let me know.

    Code:
    #video
    python widefrog.py "https://www.uefa.tv/video/vod/644523/?playlistId=23974"
    python widefrog.py "https://www.uefa.tv/video/vod/686274/?bucketExId=m3ce&lastSeen=0%3A686274&section=home"
    python widefrog.py "https://www.uefa.tv/match/vod/596575/2039928"
    python widefrog.py "https://www.uefa.tv/video/vod/181493/"
    #list
    python widefrog.py "https://www.uefa.tv/playlist/8177" --query=:43::47
    python widefrog.py "https://www.uefa.tv/search/videos?q=europe%20champion" --query=:25::27
    #series
    python widefrog.py "https://www.uefa.tv/competition/U-17" --query=2:20:3:2
    - veeps.com
    The service doesn't work for MacOS.

    Browser cookies are needed for all videos. A series for this site is made up of rails and videos. Each horizontal rail is considered a "season" and each card that has a title/subtitle is a video. The order is left-right. Pretty much any URL that contains rails can be sent as input for this. The big wide videos aren't considered to be either rails or videos so they aren't counted. For video make sure you click on play and take the updated URL.
    Code:
    #video
    python widefrog.py "https://veeps.com/e/artistfriendly/6da4a3b9-6f05-400b-a1f2-16209bc70a6c/312347b6-2345-1111-1111-234562972866"
    #series
    python widefrog.py "https://veeps.com/browse/folk" --query=1:5:2:2
    python widefrog.py "https://veeps.com/jazzopen" --query=1:2:2:3
    python widefrog.py "https://veeps.com/on-demand" --query=2:3:2:5
    - video.telequebec.tv
    Code:
    #video
    python widefrog.py "https://video.telequebec.tv/player/42311/stream?assetType=movies&playlist_id=266"
    python widefrog.py "https://video.telequebec.tv/player/41988/stream?assetType=episodes&playlist_id=411"
    #series
    python widefrog.py "https://video.telequebec.tv/details/29548?playlist_id=411" --query=4:5:6:7
    python widefrog.py "https://video.telequebec.tv/jeunesse/details/40201?playlist_id=441" --query=2:5:3:7
    - viu.com
    Only the /ott/ section is allowed. The site is available only for specific countries, so a VPN may be needed (even during the actual download). Use Google and find out which countries are allowed. Before downloading something, just make sure that you can play it in your browser. If you can, then you're good to go. Unfortunately, I didn't manage to find a specific URL that is only for a show's episodes. So to query an individual video you need to pass the query parameter most of the time.

    For naming, if a video doesn't have Latin characters, then its ID is used instead. A list is represented by the videos on the "episodes" tab on the right side of a show. Their order is according to their original index. The "recommended" videos are ignored.
    Code:
    #video
    python widefrog.py "https://www.viu.com/ott/za/en/vod/2397133/Skeem-Saam-S13" --query=:1::1
    python widefrog.py "https://www.viu.com/ott/za/en/vod/2290069/Love-Under-New-Management-The-Miki-Howard-Story"
    python widefrog.py "https://www.viu.com/ott/hk/zh/vod/2560203/%E4%B8%AD%E5%B9%B4%E5%A4%A7%E5%8F%94%E8%BD%89%E7%94%9F%E5%8F%8D%E6%B4%BE%E5%8D%83%E9%87%91" --query=:3::3
    #list
    python widefrog.py "https://www.viu.com/ott/za/en/vod/2579439/Generations-The-Legacy" --query=:198::199
    python widefrog.py "https://www.viu.com/ott/hk/zh/vod/2580815/Viu-Food" --query=:400::401
    - vix.com
    Colombian IP is needed. A series is made up of seasons and episodes. The seasons are found in the dropdown list and are numbered from 1 (top-down), regardless of what their name is. The episodes keep their original number.
    Code:
    #video
    python widefrog.py "https://vix.com/es-es/video/video-4466362"
    #series
    python widefrog.py "https://vix.com/es-es/detail/series-4715" --query=3:60:4:61
    python widefrog.py "https://vix.com/es-es/detail/series-2334" --query=2:13:3:1
    python widefrog.py "https://vix.com/es-es/detail/series-502" --query=2:168:3:169
    - vrt.be
    Only the section /vrtmax/ is allowed. Belgian IP is needed (for most content). Browser cookies are needed (for most content as well). When clicking on a show, if on the left side there are multiple sections always click on the one that you want to download from and take the updated URL since that is the valid input. If a show doesn't have sections then the show URL is the proper input.

    If you want the seasons of a show, you're gonna have to select the section that offers that content. If that section has a drop-down list (on the right side) from where you can select a specific season, the ones that aren't labeled properly as "Seizoen <number>" will be ignored. If you want the non-season ones downloaded as well, you're going to have to click on one of them and take the updated URL that will now contain a query parameter (for example: ?seizoen=extra). The input will be processed as a list and the numbering starts from top to down.

    If you select any other left-side section that isn't responsible for seasons (for example: bloopers, extras, etc.), each horizontal rail that contains videos is considered to be an indexed collection (equivalent to "season"), and the numbering is left to right. Similar to how the shows were managed, you can also download podcasts (in batch as well). Go to a random podcast and click "Meer van dit programma" to go to the main URL. The same previous explanations from the classic shows apply here in the same way.

    In addition, you can also download radio and livestream audio/video. Go to the main page of a radio channel and select the "Uitzendingen" section. That will be treated as a list (numbered from top to down).
    Code:
    #video
    python widefrog.py "https://www.vrt.be/vrtmax/a-z/de-gruffalo/2009/de-gruffalo/"
    #audio
    python widefrog.py "https://www.vrt.be/vrtmax/podcasts/mnm/0/22-minuten-stomme-vragen-/3/frances-lefebure/"
    python widefrog.py "https://www.vrt.be/vrtmax/luister/radio/d/de-mnm-weekendploeg~55-278/de-mnm-weekendploeg~55-39614-0/"
    #livestream
    python widefrog.py "https://www.vrt.be/vrtmax/livestream/audio/studio-brussel/"
    python widefrog.py "https://www.vrt.be/vrtmax/livestream/video/vrt-canvas/"
    #list
    python widefrog.py "https://www.vrt.be/vrtmax/a-z/-likeme/?seizoen=surprise#reeksen" --query=:4::8
    python widefrog.py "https://www.vrt.be/vrtmax/luister/radio/u/ultratop50~55-26/#uitzendingen" --query=:2::4
    #series
    python widefrog.py "https://www.vrt.be/vrtmax/a-z/doc-martin/#afleveringen" --query=1:5:2:8
    python widefrog.py "https://www.vrt.be/vrtmax/a-z/thuis/#podcasts" --query=1:10:2:2
    python widefrog.py "https://www.vrt.be/vrtmax/a-z/postbus-x/" --query=1989:6:1989:12
    python widefrog.py "https://www.vrt.be/vrtmax/podcasts/radio-1/v/voorproevers/#afleveringen" --query=1:155:2:5
    - watch.blaze.tv
    British IP is needed, not only for accessing the content but also for downloading it. I didn't manage to find any DRM content. When you select a livestream URL, make sure you hover over the "Watch Live" button and pick a channel. A series is made up of seasons and episodes. A list for this site is applied only for the URL:
    https://watch.blaze.tv/page/catchup
    and the order for that is top-down and left-right.
    Code:
    #video
    python widefrog.py "https://watch.blaze.tv/watch/replay/52561476"
    python widefrog.py "https://watch.blaze.tv/watch/replay/375173/worst-best-man-ever"
    #livestream
    python widefrog.py "https://watch.blaze.tv/live/1229"
    #list
    python widefrog.py "https://watch.blaze.tv/page/catchup" --query=:5::15
    #series
    python widefrog.py "https://watch.blaze.tv/shows/59960b0d-baf5-11ea-9b31-0626f8704156/pawn-stars" --query=22:9:22:12
    python widefrog.py "https://watch.blaze.tv/series/Hardcore+Pawn" --query=11:8:12:6
    - watch.shortly.film
    Email/password are needed. A list for this site is represented by the videos from a tag search or a query search. The order is top-down and left-right.
    Code:
    #video
    python widefrog.py "https://watch.shortly.film/play/ten-with-a-flag"
    #list
    python widefrog.py "https://watch.shortly.film/tag/uk-gb_23192C" --query=:5::7
    python widefrog.py "https://watch.shortly.film/search?q=gabriel" --query=:3::5
    - watch.tbn.uk
    Vods and replays can be downloaded. An account is needed to watch in the browser but not for downloading. To access the main URL of a show, you can use the site's search function.
    Code:
    #video
    python widefrog.py "https://watch.tbn.uk/watch/replay/19120484/episode-465"
    python widefrog.py "https://watch.tbn.uk/watch/vod/52049659/standing-together"
    #livestream
    python widefrog.py "https://watch.tbn.uk/live/1197"
    #series
    python widefrog.py "https://watch.tbn.uk/shows/b3195549-4b6e-4391-97a0-5830b3e7514e/a-moment-with-kika" --query=1:29:2:2
    python widefrog.py "https://watch.tbn.uk/shows/906eb770-23de-4fc7-a369-e87167a5256d/praise-uk" --query=2021:13:2022:1
    ------------------------------------------------------------------------------------------------------------------------------------------------
    Originally Posted by Karoolus View Post
    Very nice share! Well done Btw, I could share the way the token refresh works in VTMGo if you're interested?
    Thank you @Karoolus If you don't mind me adding it to the tool, sure why not. I figured out the endpoint used for it, just the flow remained a mystery to me (headers and all that).
    Last edited by 2nHxWW6GkN1l916N3ayz8HQoi; 24th Mar 2025 at 03:11. Reason: typos, grammar, spelling, clarifications, new services, version release, etc.
    --[----->+<]>.++++++++++++.---.--------.
    [*drm mass downloader: widefrog*]~~~~~~~~~~~[*how to make your own mass downloader: guide*]
    Quote Quote  
  4. Great job!. Thanks for sharing.
    Quote Quote  
  5. I said it once and I'll say it again, great job mate! And thanks for the shoutout!
    Quote Quote  
  6. Member aqzs's Avatar
    Join Date
    Mar 2024
    Location
    Paris
    Search Comp PM
    As the others said : great job !!
    Quote Quote  
  7. Great job may have found a possible bug ?

    py widefrog.py https://watch.globaltv.com/series/65a52acc-5777-11ec-b478-0242ac110003 --query=1

    for example, I can download individually but doesn't like the query unless it's just me ?
    Quote Quote  
  8. Feels Good Man 2nHxWW6GkN1l916N3ayz8HQoi's Avatar
    Join Date
    Jan 2024
    Location
    Pepe Island
    Search Comp PM
    I'll be using this post as the next part of the second main post because of text length limitations.

    3. Usage

    - adultswim.com
    American IP is needed for most content. A series is represented by rails and videos. The videos keep their original index which might be even zero in some weird cases. Regardless of their original name, the rails start from 1 and they're numbered from up to down, or down to up, depending on the case. You can look at their original names and deduce the direction.

    Any show might have the following special rails: extras and clips. The extras are considered the next rail after the last official one. And the clips follow after the extras. The clips section can be separated into other tabs and each tab represents another rail. Credit goes to @larley for explaining what the problem was with the DRM manifest.
    Code:
    #video
    python widefrog.py "https://www.adultswim.com/videos/toonami/dead-cells-return-to-castlevania-game-review"
    python widefrog.py "https://www.adultswim.com/videos/attack-on-titan/the-final-chapters-special-1"
    python widefrog.py "https://www.adultswim.com/videos/dragon-ball-z-kai/the-final-trump-card-gokus-ultimate-spirit-bomb"
    #series
    python widefrog.py "https://www.adultswim.com/videos/specials" --query=7:1:8:1
    python widefrog.py "https://www.adultswim.com/videos/the-venture-bros" --query=3:13:4:1
    python widefrog.py "https://www.adultswim.com/videos/hot-streets" --query=3:4:4:2
    - goplay.be
    Belgian IP is needed for most content. Browser cookies are needed as well. The videos from a show are represented by the season index and episode index which are found in their content URL (regardless of their content/grid name). If a video doesn't contain them then they're considered to be bonus videos and are in a separate season (max official season + 1). The order of the bonus videos is entirely random. Credit goes to @karoolus for explaining how to fix the mpd manifest.
    Code:
    #video
    python widefrog.py "https://www.goplay.be/video/gentwest/gent-west-s2/gent-west-s2-aflevering-3"
    python widefrog.py "https://www.goplay.be/video/the-zookeepers-wife"
    python widefrog.py "https://www.goplay.be/video/the-nanny/the-nanny-s2/the-nanny-s2-aflevering-2"
    python widefrog.py "https://www.goplay.be/video/nonkels/donderdagavond-is-nonkels-avond"
    #series
    python widefrog.py "https://www.goplay.be/this-is-us" --query=3:18:4:1
    python widefrog.py "https://www.goplay.be/masters-of-madness" --query=1:16:2:2
    - joyn.de
    You need a good German VPN for most content (except some trailers). You can use an optional account via email/password for any free videos that may require one. Some videos that need an account, need also a PIN if they're age-restricted (the PIN can be given in the config file). To get a PIN go to the site's account settings and add a German ID card (it's up to you how you solve it). For the videos that need a PIN, this restriction is lifted only between 23:00 and 05:30 (more or less, this is just the short version).

    A list in this context, means the list of channels that you have at the URL https://www.joyn.de/play/live-tv . The order for that is up to down and starts from 1. Do not attempt to download livestreams that aren't really LIVE but instead, they are just a collection of vods. A list can also mean the videos from a playlist URL. A series is structured in seasons and episodes. If a show has the tab "Clips", then that one is counted as another season. Its number is the next one after the last official season.

    If a show doesn't give you the choice to select a season, then the season index is obtained from the URLs of the contents. The episode index is obtained in the same way. For the clips from the "Clips" tab, their index is counted from left to right. A series can also be represented by a show from a compilation URL. The "Videos" tab is considered to be season 1 and the videos are counted left to right, up to down. The "Clips" tab is season 2 and the clips are counted from left to right.

    Credit goes to @lostion for explaining how the site works and also to @obo for explaining how the refresh token endpoint works on a public post.

    Code:
    #video
    python widefrog.py "https://www.joyn.de/play/serien/agentin-mit-herz/4-2-amanda-schlaegt-alarm"
    python widefrog.py "https://www.joyn.de/play/highlight/serien/newstime/sugar-glider-als-haustier-besser-nicht"
    python widefrog.py "https://www.joyn.de/play/compilation/rugby-europe-championship-finale-georgien-vs-spanien-im-relive/rugby-wolf-mit-superman-move-deutschland-dennoch-chancenlos"
    python widefrog.py "https://www.joyn.de/play/trailer/compilation/spacetime/spacetime-staffel-4-trailer"
    python widefrog.py "https://www.joyn.de/play/filme/der-verrueckte-professor"
    #livestream
    python widefrog.py "https://www.joyn.de/play/live-tv?channel_id=1272"
    #list
    python widefrog.py "https://www.joyn.de/play/live-tv" --query=:15::16
    python widefrog.py "https://www.joyn.de/play/playlist/350025" --query=:8::9
    #series
    python widefrog.py "https://www.joyn.de/serien/joko-klaas-gegen-prosieben" --query=7:12:8:2
    python widefrog.py "https://www.joyn.de/serien/boruto" --query=6:11:6:12
    python widefrog.py "https://www.joyn.de/compilation/spacetime" --query=1:9:2:1
    - kanopy.com
    Browser cookies are needed. Some videos are country-specific so use a VPN (it's up to you to find out what country works). If your account is associated with multiple libraries, then the one that you set as default is used by the program. Otherwise, the first available library is used.

    A show is structured in seasons and episodes. The seasons' numbers start from 1 and are ordered from up to down, regardless of their original names. The episodes are numbered from 1 and are sorted from left to right, regardless of their original names. If a show doesn't let you choose the season and only has one rail of episodes, then it is considered that those episodes belong to season number 1.
    Code:
    #video
    python widefrog.py "https://www.kanopy.com/en/alplibrary/watch/video/15118833"
    python widefrog.py "https://www.kanopy.com/en/alplibrary/watch/video/14440621/14440627"
    python widefrog.py "https://www.kanopy.com/en/alplibrary/watch/video/14157579/14414563/14414571"
    python widefrog.py "https://www.kanopy.com/en/alplibrary/video/2474289"
    python widefrog.py "https://www.kanopy.com/en/alplibrary/video/12694708/12694352"
    python widefrog.py "https://www.kanopy.com/en/alplibrary/video/15026991/15026993/15026999"
    #series
    python widefrog.py "https://www.kanopy.com/en/alplibrary/video/13615271" --query=1:3:1:5
    python widefrog.py "https://www.kanopy.com/en/alplibrary/video/14837931" --query=2:12:3:1
    - npo.nl
    Only the /start/ and /npo3/ sections from that site are allowed. Regarding /npo3/, a list means a page where multiple npo3 videos are displayed. The order is top to down and only videos are considered to be valid elements. Articles are ignored. Regarding /start/, a show where only the section "Uitzendingen" is displayed is considered a list and the order is top to down. If the show has multiple seasons, those are indexed down-top instead and the same applies to their episodes. The seasons always start from index 1 (had to do this because some shows had seasons numbered as years, and some seasons didn't even have numbers).

    Sadly, some content is geo-restricted to the Netherlands and the content manifest is tied to the user's IP so you need a VPN for downloading as well. But if you just want non-restricted content, everything else is fine. An optional account can be provided through browser cookies.
    Code:
    #video
    python widefrog.py "https://npo.nl/start/video/het-leven-is-vurrukkulluk"
    python widefrog.py "https://npo.nl/start/serie/het-mooiste-meisje-van-de-klas/seizoen-9/joyce_4/afspelen"
    python widefrog.py "https://npo.nl/npo3/mijn-vader-verbrak-contact-wegens-mijn-zwangerschap/16-05-2024/WO_KN_20194462"
    #list
    python widefrog.py "https://npo.nl/start/serie/dit-was-het-nieuws" --query=:5::8
    python widefrog.py "https://npo.nl/npo3/atje-voor-de-sfeer-met-mark-baanders/POMS_S_POWN_20135656" --query=:2::4
    #series
    python widefrog.py "https://npo.nl/start/serie/hunted" --query=10:5:11:7
    - play.tv3.lv
    The service has support for h265 content. The h265 manifest will be merged with the default h264 one and can be downloaded at the same time. Latvian IP is needed if you want to watch some content on the browser, but you don't need a VPN at all when it's about downloading. If you click a random episode, you can access its show by clicking the main show's title. The episodes of a show's season are usually numbered from right to left if proper numbering is missing (like S02E02).

    Some seasons may have an additional grid of videos called "Klipi". Those are short clips related only to that specific season. That grid can be downloaded as a collection as well and is considered to be an additional season. The "Klipi" videos are numbered from left to right instead. If a show has the numbered seasons 1, 10, and 100 then their corresponding "Klipi" seasons are numbered 101, 102, and 103 (in the same order, 1<=>101, 10<=>102, and 100<=>103).

    The script will take a long time if you're trying to download many videos at once for this site due to their security. If it takes too long for a single video then make sure you can watch it in your browser.
    Code:
    #video
    python widefrog.py "https://play.tv3.lv/video/hits-300-minutes-6139414/serija-10-7960418/"
    python widefrog.py "https://play.tv3.lv/video/vinas-melo-labak-1024464/vinas-melo-labak--edijs-uzbruk-2891371/"
    python widefrog.py "https://play.tv3.lv/filmas/zaku-liela-diena-5523875/"
    #series
    python widefrog.py "https://play.tv3.lv/video/enu-speles-1024233/" --query=2:11:3:1
    python widefrog.py "https://play.tv3.lv/video/eiroliga--8253225/" --query=2026:44:2027:1
    - plus.rtl.de
    You need a good German VPN for most content. Didn't test any restricted content but it should in theory work. You can use an optional account via email/password for any free videos that may require one. The highest quality manifest URL is obtained through URL editing. Credit goes to @aqzs and @lostion for explaining the trick in detail. A list in this context means the list of podcasts from a podcast page. The order for that is top-down.

    For series, use the show URL. A series is structured in 2 ways: seasons/episodes and years/months. For the first way, each season that has "Staffel" in its name will keep its corresponding index. The additional seasons (extras) will start their index from the highest "Staffel" and will be sorted alphabetically. For the second way (years/months), the "season" index will be represented by a number with a decimal (year.month). For example, 2024 February is 2024.02 while 2020 December is 2020.12
    Code:
    #video
    python widefrog.py "https://plus.rtl.de/video-tv/shows/hilfe-die-camper-kommen-861468/2023-4-971471/episode-6-die-verbleibenden-paare-erreichen-ihr-ziel-in-spanien-861475"
    python widefrog.py "https://plus.rtl.de/video-tv/filme/soziale-brennpunkte-was-passiert-mit-unseren-staedten-844861"
    python widefrog.py "https://plus.rtl.de/video-tv/serien/disko-76-914295/staffel-1-914296/episode-1-folge-1-914297"
    #audio
    python widefrog.py "https://plus.rtl.de/podcast/die-petze-und-der-besserwisser-mit-julian-classen-und-bianca-schmitt-6ppxy0xjwdkcr/mein-schoenheitseingriff-ueber-6-stunden-2n9tbuw4q0igl"
    #livestream
    python widefrog.py "https://plus.rtl.de/video-tv/live-tv/alarm-fuer-cobra-11-balko-60"
    #list
    python widefrog.py "https://plus.rtl.de/podcast/wie-wir-ticken-euer-psychologie-podcast-t94vff8kaxkzi" --query=:3::6
    #series
    python widefrog.py "https://plus.rtl.de/video-tv/shows/princess-charming-883086" --query=3:5:5:4
    python widefrog.py "https://plus.rtl.de/video-tv/shows/kitchen-impossible-717062" --query=2019.06:2:2020.11:5
    - rtlplay.be
    Browser cookies are needed. Once in a while, you're gonna have to manually refresh them by playing a random video in your browser. Belgian IP is needed or you can configure your rtlplay account to work outside Belgium in settings (it's up to you how you solve it). A list is represented by the livestreams from the URL https://www.rtlplay.be/rtlplay/direct . The order for that is left-right, up-down.
    Code:
    #video
    python widefrog.py "https://www.rtlplay.be/rtlplay/player/9b62f691-3256-4dd8-b402-535efdfd5ebf"
    python widefrog.py "https://www.rtlplay.be/rtlplay/player/899e518b-ca56-4b14-b648-3179d93998cb"
    #livestream
    python widefrog.py "https://www.rtlplay.be/rtlplay/direct/plug"
    #list
    python widefrog.py "https://www.rtlplay.be/rtlplay/direct" --query=:2::3
    #series
    python widefrog.py "https://www.rtlplay.be/rtlplay/h~93dfa518-3b69-415b-aafd-a5f4dc5eb942" --query=2:20:3:1
    - rts.ch
    Only the /play/ section is supported. Swiss IP is needed for most content (not for the downloading stage though). A list for this site means the collection of URLs that are the result of a filtered search. After pressing the search button ("Recherche"), select at least one filter, click apply, and take the updated URL as input.

    A series for this site is represented by the page of a show. Each section of videos represents a season. Some extra videos (like trailers), may appear before the rails and their group is considered a "season" as well. The order is top-down, left-right, regardless of the section's name. A series can also mean the videos from a URL that contains the path /detail/ in it. If you see a group of videos with a little arrow, you can click on it and you'll be redirected to a "/detail/" URL. Credit goes to @aqzs for explaining the forward IP trick.
    Code:
    #video
    python widefrog.py "https://www.rts.ch/play/tv/12h45/video/marseillaise-sifflee-jacques-chirac-a-exige-des-excuses-de-la-fff?urn=urn:rts:video:550530"
    python widefrog.py "https://www.rts.ch/play/tv/doc-portrait/video/les-dents-de-la-mer-un-succes-monstre?urn=urn:rts:video:15483865"
    #list
    python widefrog.py "https://www.rts.ch/play/recherche?query=swiss&shows=urn%3Arts%3Ashow%3Atv%3A1889751&topics=urn%3Arts%3Atopic%3Atv%3A1095&properties=playableAbroad" --query=:3::5
    #series
    python widefrog.py "https://www.rts.ch/play/tv/emission/au-coeur-de-la-suisse?id=13641830" --query=1:5:1:6
    python widefrog.py "https://www.rts.ch/play/tv/emission/les-pique-meurons?id=1799044" --query=3:10:4:1
    python widefrog.py "https://www.rts.ch/play/tv/detail/les-films?id=2be00ed0-f3a4-41e3-97d9-c36e17fade56" --query=1:7:1:9
    ------------------------------------------------------------------------------------------------------------------------------------------------
    New version 1.2.0: +ptvflix.org . Anyone interested in this new service that already has this tool, can download it again using the updated URL at the top.

    Originally Posted by jack_666 View Post
    Great job!. Thanks for sharing.
    Originally Posted by grzech67 View Post
    It works perfectly, thank you for sharing.
    Originally Posted by white_snake View Post
    I said it once and I'll say it again, great job mate! And thanks for the shoutout!
    Originally Posted by LittleSoldier View Post
    Great Job Pepe…
    Originally Posted by aqzs View Post
    As the others said : great job !!
    Originally Posted by PSXman_uk View Post
    Great job
    Thanks for the nice words guys. I appreciate it.

    Originally Posted by PSXman_uk View Post
    for example, I can download individually but doesn't like the query unless it's just me ?
    I explained this scenario in the first post. I wanted to separate the season/episodes section of a show from other bonus sections (extra, trailers, deleted scenes etc.) in case people wanted those downloaded as well in collections. In your case you will have to press on the "Episodes" section and use the updated URL:
    Code:
    python widefrog.py "https://watch.globaltv.com/series/65a52acc-5777-11ec-b478-0242ac110003/collection/ac105e0a-7487-11ec-a150-0242ac110006/" --query=1
    If you want all the seasons, just get rid of the --query parameter.
    Last edited by 2nHxWW6GkN1l916N3ayz8HQoi; 24th Mar 2025 at 06:01. Reason: typos, grammar, spelling, clarifications, new services, version release, etc.
    --[----->+<]>.++++++++++++.---.--------.
    [*drm mass downloader: widefrog*]~~~~~~~~~~~[*how to make your own mass downloader: guide*]
    Quote Quote  
  9. 2nHxWW6GkN1l916N3ayz8HQoi - Thank you very much for this fantastic work
    Quote Quote  
  10. Excellent work, frogman! There's a lot work that goes into something like this, and it's nice to see someone focus on the smaller streaming services for once.

    Keep up the good work!
    Quote Quote  
  11. Thanks for the update I understand where I was going wrong thanks for a great tool
    Quote Quote  
  12. Feels Good Man 2nHxWW6GkN1l916N3ayz8HQoi's Avatar
    Join Date
    Jan 2024
    Location
    Pepe Island
    Search Comp PM
    v1.3.0: added support for npo.nl

    Originally Posted by PepeForEver View Post
    2nHxWW6GkN1l916N3ayz8HQoi - Thank you very much for this fantastic work


    Originally Posted by stabbedbybrick View Post
    Excellent work, frogman! There's a lot work that goes into something like this, and it's nice to see someone focus on the smaller streaming services for once.

    Keep up the good work!
    Thanks a lot, man. Your program helped me sketch the basics of this.

    Originally Posted by PSXman_uk View Post
    Thanks for the update I understand where I was going wrong thanks for a great tool
    No problem.
    --[----->+<]>.++++++++++++.---.--------.
    [*drm mass downloader: widefrog*]~~~~~~~~~~~[*how to make your own mass downloader: guide*]
    Quote Quote  
  13. Member
    Join Date
    Feb 2022
    Location
    Search the forum first!
    Search PM
    Great stuff!! This forum had no-one sharing anything publicly two years ago - now look at us!!
    Noob Starter Pack. Just download every Widevine mpd! Not kidding!.
    https://files.videohelp.com/u/301890/hellyes6.zip
    Quote Quote  
  14. Feels Good Man 2nHxWW6GkN1l916N3ayz8HQoi's Avatar
    Join Date
    Jan 2024
    Location
    Pepe Island
    Search Comp PM
    New version: v1.4.0
    If you're interested in a specific service, Ctrl+F search your site's name and look at the provided use cases. Added support for:
    - cda.pl
    - dazn.com (it has free content): thanks again @snake for testing the service for any possible regional bugs
    - eurovisionsport.com

    The additional tools list and the requirements.txt got updated as well. Might add vrt.be in the next version if it's not too hard to crack.

    Originally Posted by A_n_g_e_l_a View Post
    Great stuff!! This forum had no-one sharing anything publicly two years ago - now look at us!!
    Thanks for the nice words. I don't see any point in hiding these, they're just data scrapers. If any exploits were used, I could understand not wanting to make them public. But in the current state, it's just Python 101.
    Last edited by 2nHxWW6GkN1l916N3ayz8HQoi; 22nd May 2024 at 09:50.
    --[----->+<]>.++++++++++++.---.--------.
    [*drm mass downloader: widefrog*]~~~~~~~~~~~[*how to make your own mass downloader: guide*]
    Quote Quote  
  15. Thank you for making a new tool to get videos.
    Quote Quote  
  16. Feels Good Man 2nHxWW6GkN1l916N3ayz8HQoi's Avatar
    Join Date
    Jan 2024
    Location
    Pepe Island
    Search Comp PM
    v1.5.0: added vrt.be

    Originally Posted by Tom Saurus View Post
    Thank you for making a new tool to get videos.
    You're welcome.
    --[----->+<]>.++++++++++++.---.--------.
    [*drm mass downloader: widefrog*]~~~~~~~~~~~[*how to make your own mass downloader: guide*]
    Quote Quote  
  17. Feels Good Man 2nHxWW6GkN1l916N3ayz8HQoi's Avatar
    Join Date
    Jan 2024
    Location
    Pepe Island
    Search Comp PM
    v1.6.0: + mediasetinfinity.mediaset.it
    --[----->+<]>.++++++++++++.---.--------.
    [*drm mass downloader: widefrog*]~~~~~~~~~~~[*how to make your own mass downloader: guide*]
    Quote Quote  
  18. Member
    Join Date
    Aug 2023
    Location
    Turkey
    Search Comp PM
    super dubi big thanks nice work ..
    Quote Quote  
  19. Great script man!
    I used it to download my favorite series on Belgian public TV.
    (The one with Michel, Guido, Frankie and Alain)
    Quote Quote  
  20. Feels Good Man 2nHxWW6GkN1l916N3ayz8HQoi's Avatar
    Join Date
    Jan 2024
    Location
    Pepe Island
    Search Comp PM
    v1.7.0: +auvio.rtbf.be

    For those of you who already have the tool, there is no need for getting the new version unless you're interested in the added service.

    If someone has available a random 6play.fr video URL where there are no geographic restrictions, feel free to leave a message here (keep in mind that I'm not asking for access to a fancy VPN). I'm interested in adding the site but I can't find accessible content to test stuff. I doubt there's any since I would have found it by now but it's worth a shot asking here.

    Originally Posted by senkron24 View Post
    super dubi big thanks nice work ..
    You're "super dubi big" welcome.

    Originally Posted by Flippi View Post
    Great script man!
    I used it to download my favorite series on Belgian public TV
    Thanks a lot, man. It feels nice knowing that the stuff I developed is put to good use. Happy downloading and enjoy the tool while you can. Sites change all the time.
    Last edited by 2nHxWW6GkN1l916N3ayz8HQoi; 31st May 2024 at 13:03.
    --[----->+<]>.++++++++++++.---.--------.
    [*drm mass downloader: widefrog*]~~~~~~~~~~~[*how to make your own mass downloader: guide*]
    Quote Quote  
  21. Feels Good Man 2nHxWW6GkN1l916N3ayz8HQoi's Avatar
    Join Date
    Jan 2024
    Location
    Pepe Island
    Search Comp PM
    v1.8.0: +rakuten.tv (thanks @brick for testing the prototype on multiple regions).
    --[----->+<]>.++++++++++++.---.--------.
    [*drm mass downloader: widefrog*]~~~~~~~~~~~[*how to make your own mass downloader: guide*]
    Quote Quote  
  22. Im trying to get this series from Rakuten tv as a test
    https://www.rakuten.tv/uk?content_type=tv_shows&tv_show_id=andromeda&content_id=andromeda-1
    tried this from the popup no joy also tried
    https://www.rakuten.tv/uk/player/episodes/stream/andromeda-1/andromeda-1-1
    Also doenst work for me unless im doing it wrong
    Quote Quote  
  23. Feels Good Man 2nHxWW6GkN1l916N3ayz8HQoi's Avatar
    Join Date
    Jan 2024
    Location
    Pepe Island
    Search Comp PM
    Originally Posted by PSXman_uk View Post
    Also doenst work for me unless im doing it wrong
    To avoid spamming this post while blindly guessing the cause of your problem I sent you a PM. Can't really do much without a proper VPN but I can try. I managed to get it right for my country so there is some small chance I may have missed something.
    --[----->+<]>.++++++++++++.---.--------.
    [*drm mass downloader: widefrog*]~~~~~~~~~~~[*how to make your own mass downloader: guide*]
    Quote Quote  
  24. Feels Good Man 2nHxWW6GkN1l916N3ayz8HQoi's Avatar
    Join Date
    Jan 2024
    Location
    Pepe Island
    Search Comp PM
    The rakuten issue was solved. There was a small problem due to some miscommunication on my part. I wasn't aware the show URL can have multiple forms. I edited the first post to detail the problem and solution. In the next tool version, I'll change it so that any type of show URL can be accepted (for now it remains like this since it isn't a major problem). Basically, make sure you select a show after you click the "free" section. The popup URL has to have avod-fast in it.
    --[----->+<]>.++++++++++++.---.--------.
    [*drm mass downloader: widefrog*]~~~~~~~~~~~[*how to make your own mass downloader: guide*]
    Quote Quote  
  25. The exe does not work after unzipping
    Quote Quote  
  26. Feels Good Man 2nHxWW6GkN1l916N3ayz8HQoi's Avatar
    Join Date
    Jan 2024
    Location
    Pepe Island
    Search Comp PM
    Originally Posted by Bruce236 View Post
    The exe does not work after unzipping
    Have you properly installed all the necessary additional tools? How are you running that exe? I hope you aren't double clicking it and expecting a full GUI to magically appear. It's meant to be ran from cmd.
    --[----->+<]>.++++++++++++.---.--------.
    [*drm mass downloader: widefrog*]~~~~~~~~~~~[*how to make your own mass downloader: guide*]
    Quote Quote  
  27. I click on the windows explorer bar and type 'cmd' - that part is fine, and it comes up as the normal screen, but then when entering a link it doesn't work and errors appear.
    Quote Quote  
  28. Feels Good Man 2nHxWW6GkN1l916N3ayz8HQoi's Avatar
    Join Date
    Jan 2024
    Location
    Pepe Island
    Search Comp PM
    Originally Posted by Bruce236 View Post
    I click on the windows explorer bar and type 'cmd' - that part is fine, and it comes up as the normal screen, but then when entering a link it doesn't work and errors appear.
    Show screenshot.
    --[----->+<]>.++++++++++++.---.--------.
    [*drm mass downloader: widefrog*]~~~~~~~~~~~[*how to make your own mass downloader: guide*]
    Quote Quote  



Similar Threads

Visit our sponsor! Try DVDFab and backup Blu-rays!