Compare commits

...

2 Commits

Author SHA1 Message Date
wranai
405fd65708
Merge b94f293553 into e1b3fa242c 2024-07-28 01:30:44 +09:00
wranai
b94f293553
fix tiktok when logged in
tiktok now shows metadata in a diff format when logged in
2021-11-10 23:43:55 +01:00

View File

@ -107,10 +107,18 @@ class TikTokIE(TikTokBaseIE):
def _real_extract(self, url): def _real_extract(self, url):
video_id = self._match_id(url) video_id = self._match_id(url)
webpage = self._download_webpage(url, video_id) webpage = self._download_webpage(url, video_id)
try:
page_props = self._parse_json(self._search_regex( page_props = self._parse_json(self._search_regex(
r'<script[^>]+\bid=["\']__NEXT_DATA__[^>]+>\s*({.+?})\s*</script', r'<script[^>]+\bid=["\']__NEXT_DATA__[^>]+>\s*({.+?})\s*</script',
webpage, 'data'), video_id)['props']['pageProps'] webpage, 'data'), video_id)['props']['pageProps']
data = try_get(page_props, lambda x: x['itemInfo']['itemStruct'], dict) data = try_get(page_props, lambda x: x['itemInfo']['itemStruct'], dict)
except:
page_props = self._parse_json(self._search_regex(
r'<script[^>]+\bid=["\']sigi-persisted-data[^>]+>window\[\'SIGI_STATE\']=({.+?});window\[',
webpage, 'data'), video_id)
data = try_get(page_props, lambda x: x['ItemModule'][video_id], dict)
author = try_get(page_props, lambda x: x['UserModule']['users'][data['author']], dict)
data['author'] = author
if not data and page_props.get('statusCode') == 10216: if not data and page_props.get('statusCode') == 10216:
raise ExtractorError('This video is private', expected=True) raise ExtractorError('This video is private', expected=True)
return self._extract_video(data, video_id) return self._extract_video(data, video_id)