]>
jfr.im git - yt-dlp.git/blob - yt_dlp/extractor/gofile.py
3 from .common
import InfoExtractor
10 class GofileIE(InfoExtractor
):
11 _VALID_URL
= r
'https?://(?:www\.)?gofile\.io/d/(?P<id>[^/]+)'
13 'url': 'https://gofile.io/d/AMZyDw',
17 'playlist_mincount': 2,
20 'id': 'de571ac1-5edc-42e2-8ec2-bdac83ad4a31',
24 'release_timestamp': 1638338704,
25 'release_date': '20211201',
29 'url': 'https://gofile.io/d/is8lKr',
35 'skip': 'No video/audio found at provided URL.',
37 'url': 'https://gofile.io/d/TMjXd9',
43 'url': 'https://gofile.io/d/gqOtRf',
47 'playlist_mincount': 1,
49 'videopassword': 'password',
54 def _real_initialize(self
):
55 token
= self
._get
_cookies
('https://gofile.io/').get('accountToken')
57 self
._TOKEN
= token
.value
60 account_data
= self
._download
_json
(
61 'https://api.gofile.io/createAccount', None, note
='Getting a new guest account')
62 self
._TOKEN
= account_data
['data']['token']
63 self
._set
_cookie
('gofile.io', 'accountToken', self
._TOKEN
)
65 def _entries(self
, file_id
):
69 'websiteToken': 12345,
71 password
= self
.get_param('videopassword')
73 query_params
['password'] = hashlib
.sha256(password
.encode('utf-8')).hexdigest()
74 files
= self
._download
_json
(
75 'https://api.gofile.io/getContent', file_id
, note
='Getting filelist', query
=query_params
)
77 status
= files
['status']
78 if status
== 'error-passwordRequired':
80 'This video is protected by a password, use the --video-password option', expected
=True)
82 raise ExtractorError(f
'{self.IE_NAME} said: status {status}', expected
=True)
85 for file in (try_get(files
, lambda x
: x
['data']['contents'], dict) or {}).values():
86 file_type
, file_format
= file.get('mimetype').split('/', 1)
87 if file_type
not in ('video', 'audio') and file_format
!= 'vnd.mts':
91 file_url
= file.get('link')
95 'title': file['name'].rsplit('.', 1)[0],
97 'filesize': file.get('size'),
98 'release_timestamp': file.get('createTime')
102 raise ExtractorError('No video/audio found at provided URL.', expected
=True)
104 def _real_extract(self
, url
):
105 file_id
= self
._match
_id
(url
)
106 return self
.playlist_result(self
._entries
(file_id
), playlist_id
=file_id
)