]>
Commit | Line | Data |
---|---|---|
5fb9077e NJ |
1 | # coding: utf-8 |
2 | from __future__ import unicode_literals | |
3 | ||
4 | import json | |
5 | import re | |
6 | ||
7 | from .common import InfoExtractor | |
8 | from ..utils import ( | |
9 | ExtractorError, | |
10 | compat_urllib_parse, | |
11 | compat_urllib_request, | |
12 | int_or_none, | |
13 | ) | |
14 | ||
15 | ||
16 | class MoeVideoIE(InfoExtractor): | |
ff0ba8ce | 17 | IE_DESC = 'LetitBit video services: moevideo.net, playreplay.net and videochart.net' |
5fb9077e NJ |
18 | _VALID_URL = r'''(?x) |
19 | https?://(?P<host>(?:www\.)? | |
ff0ba8ce | 20 | (?:(?:moevideo|playreplay|videochart)\.net))/ |
5fb9077e NJ |
21 | (?:video|framevideo)/(?P<id>[0-9]+\.[0-9A-Za-z]+)''' |
22 | _API_URL = 'http://api.letitbit.net/' | |
23 | _API_KEY = 'tVL0gjqo5' | |
24 | _TESTS = [ | |
25 | { | |
26 | 'url': 'http://moevideo.net/video/00297.0036103fe3d513ef27915216fd29', | |
27 | 'md5': '129f5ae1f6585d0e9bb4f38e774ffb3a', | |
28 | 'info_dict': { | |
29 | 'id': '00297.0036103fe3d513ef27915216fd29', | |
30 | 'ext': 'flv', | |
31 | 'title': 'Sink cut out machine', | |
32 | 'description': 'md5:f29ff97b663aefa760bf7ca63c8ca8a8', | |
33 | 'thumbnail': 're:^https?://.*\.jpg$', | |
34 | 'width': 540, | |
35 | 'height': 360, | |
36 | 'duration': 179, | |
0dc53655 | 37 | 'filesize': 17822500, |
5fb9077e NJ |
38 | } |
39 | }, | |
40 | { | |
41 | 'url': 'http://playreplay.net/video/77107.7f325710a627383d40540d8e991a', | |
42 | 'md5': '74f0a014d5b661f0f0e2361300d1620e', | |
43 | 'info_dict': { | |
44 | 'id': '77107.7f325710a627383d40540d8e991a', | |
45 | 'ext': 'flv', | |
46 | 'title': 'Operacion Condor.', | |
47 | 'description': 'md5:7e68cb2fcda66833d5081c542491a9a3', | |
48 | 'thumbnail': 're:^https?://.*\.jpg$', | |
49 | 'width': 480, | |
50 | 'height': 296, | |
51 | 'duration': 6027, | |
0dc53655 | 52 | 'filesize': 588257923, |
5fb9077e NJ |
53 | } |
54 | }, | |
55 | ] | |
56 | ||
57 | def _real_extract(self, url): | |
58 | mobj = re.match(self._VALID_URL, url) | |
59 | video_id = mobj.group('id') | |
60 | ||
61 | webpage = self._download_webpage( | |
62 | 'http://%s/video/%s' % (mobj.group('host'), video_id), | |
63 | video_id, 'Downloading webpage') | |
64 | ||
65 | title = self._og_search_title(webpage) | |
66 | thumbnail = self._og_search_thumbnail(webpage) | |
67 | description = self._og_search_description(webpage) | |
68 | ||
69 | r = [ | |
70 | self._API_KEY, | |
71 | [ | |
72 | 'preview/flv_link', | |
73 | { | |
74 | 'uid': video_id, | |
75 | }, | |
76 | ], | |
77 | ] | |
78 | r_json = json.dumps(r) | |
79 | post = compat_urllib_parse.urlencode({'r': r_json}) | |
80 | req = compat_urllib_request.Request(self._API_URL, post) | |
81 | req.add_header('Content-type', 'application/x-www-form-urlencoded') | |
82 | ||
83 | response = self._download_json(req, video_id) | |
84 | if response['status'] != 'OK': | |
85 | raise ExtractorError( | |
86 | '%s returned error: %s' % (self.IE_NAME, response['data']), | |
87 | expected=True | |
88 | ) | |
89 | item = response['data'][0] | |
90 | video_url = item['link'] | |
91 | duration = int_or_none(item['length']) | |
92 | width = int_or_none(item['width']) | |
93 | height = int_or_none(item['height']) | |
94 | filesize = int_or_none(item['convert_size']) | |
95 | ||
96 | formats = [{ | |
97 | 'format_id': 'sd', | |
98 | 'http_headers': {'Range': 'bytes=0-'}, # Required to download | |
99 | 'url': video_url, | |
100 | 'width': width, | |
101 | 'height': height, | |
0dc53655 | 102 | 'filesize': filesize, |
5fb9077e NJ |
103 | }] |
104 | ||
105 | return { | |
106 | 'id': video_id, | |
107 | 'title': title, | |
108 | 'thumbnail': thumbnail, | |
109 | 'description': description, | |
110 | 'duration': duration, | |
111 | 'formats': formats, | |
112 | } |