[nowness] more api abstraction

pull/6768/head
remitamine 9 years ago
parent f95c5e1218
commit 673bf566fc

@ -30,11 +30,11 @@ class NownessBaseIE(InfoExtractor):
elif source == 'cinematique': elif source == 'cinematique':
return self.url_result('http://cinematique.com/embed/%s' % video_id, 'Cinematique') return self.url_result('http://cinematique.com/embed/%s' % video_id, 'Cinematique')
def api_request(self, url, request_url): def api_request(self, url, request_path):
display_id = self._match_id(url) display_id = self._match_id(url)
lang = 'zh-cn' if 'cn.nowness.com' in url else 'en-us' lang = 'zh-cn' if 'cn.nowness.com' in url else 'en-us'
request = compat_urllib_request.Request(request_url % display_id, headers={ request = compat_urllib_request.Request('http://api.nowness.com/api/' + request_path % display_id, headers={
'X-Nowness-Language': lang, 'X-Nowness-Language': lang,
}) })
json_data = self._download_json(request, display_id) json_data = self._download_json(request, display_id)
@ -72,7 +72,7 @@ class NownessIE(NownessBaseIE):
] ]
def _real_extract(self, url): def _real_extract(self, url):
display_id, post = self.api_request(url, 'http://api.nowness.com/api/post/getBySlug/%s') display_id, post = self.api_request(url, 'post/getBySlug/%s')
return self.extract_url_result(post) return self.extract_url_result(post)
@ -89,7 +89,7 @@ class NownessPlaylistIE(NownessBaseIE):
} }
def _real_extract(self, url): def _real_extract(self, url):
playlist_id, playlist = self.api_request(url, 'http://api.nowness.com/api/post?PlaylistId=%s') playlist_id, playlist = self.api_request(url, 'post?PlaylistId=%s')
entries = [self.extract_url_result(item) for item in playlist['items']] entries = [self.extract_url_result(item) for item in playlist['items']]
return self.playlist_result(entries, playlist_id) return self.playlist_result(entries, playlist_id)
@ -107,7 +107,7 @@ class NownessSerieIE(NownessBaseIE):
} }
def _real_extract(self, url): def _real_extract(self, url):
display_id, serie = self.api_request(url, 'http://api.nowness.com/api/series/getBySlug/%s') display_id, serie = self.api_request(url, 'series/getBySlug/%s')
serie_id = str(serie['id']) serie_id = str(serie['id'])
entries = [self.extract_url_result(post) for post in serie['posts']] entries = [self.extract_url_result(post) for post in serie['posts']]
return self.playlist_result(entries, serie_id) return self.playlist_result(entries, serie_id)

Loading…
Cancel
Save