[ManyVids] Support new single-page app structure
authordirkf <fieldhouse@gmx.net>
Thu, 13 Oct 2022 01:59:01 +0000 (01:59 +0000)
committerGitHub <noreply@github.com>
Thu, 13 Oct 2022 01:59:01 +0000 (01:59 +0000)
See https://github.com/yt-dlp/yt-dlp/issues/5210#issuecomment-1276919962.

youtube_dl/extractor/manyvids.py

index 6805102ba3b955ea59007cf19e54d0b3ee37a59c..608a02a8d782877f05aa5cf48e2e385748c49b82 100644 (file)
@@ -47,7 +47,12 @@ class ManyVidsIE(InfoExtractor):
     def _real_extract(self, url):
         video_id = self._match_id(url)
 
-        webpage = self._download_webpage(url, video_id)
+        real_url = 'https://www.manyvids.com/video/%s/gtm.js' % (video_id, )
+        try:
+            webpage = self._download_webpage(real_url, video_id)
+        except:
+            # probably useless fallback
+            webpage = self._download_webpage(url, video_id)
 
         info = self._search_regex(
             r'''(<div\b[^>]*\bid\s*=\s*(['"])pageMetaDetails\2[^>]*>)''',
@@ -98,7 +103,8 @@ class ManyVidsIE(InfoExtractor):
             # Sets some cookies
             self._download_webpage(
                 'https://www.manyvids.com/includes/ajax_repository/you_had_me_at_hello.php',
-                video_id, fatal=False, data=urlencode_postdata({
+                video_id, note='Setting format cookies', fatal=False,
+                data=urlencode_postdata({
                     'mvtoken': mv_token,
                     'vid': video_id,
                 }), headers={