diff options
| -rw-r--r-- | youtube_dl/extractor/__init__.py | 3 | ||||
| -rw-r--r-- | youtube_dl/extractor/ro220.py | 42 | 
2 files changed, 45 insertions, 0 deletions
| diff --git a/youtube_dl/extractor/__init__.py b/youtube_dl/extractor/__init__.py index b4db8f0bf..39c530ba3 100644 --- a/youtube_dl/extractor/__init__.py +++ b/youtube_dl/extractor/__init__.py @@ -57,6 +57,7 @@ from .pornotube import PornotubeIE  from .rbmaradio import RBMARadioIE  from .redtube import RedTubeIE  from .ringtv import RingTVIE +from .ro220 import Ro220IE  from .roxwel import RoxwelIE  from .rtlnow import RTLnowIE  from .sina import SinaIE @@ -116,12 +117,14 @@ _ALL_CLASSES = [  ]  _ALL_CLASSES.append(GenericIE) +  def gen_extractors():      """ Return a list of an instance of every supported extractor.      The order does matter; the first extractor matched is the one handling the URL.      """      return [klass() for klass in _ALL_CLASSES] +  def get_info_extractor(ie_name):      """Returns the info extractor class with the given ie_name"""      return globals()[ie_name+'IE'] diff --git a/youtube_dl/extractor/ro220.py b/youtube_dl/extractor/ro220.py new file mode 100644 index 000000000..c32f64d99 --- /dev/null +++ b/youtube_dl/extractor/ro220.py @@ -0,0 +1,42 @@ +import re + +from .common import InfoExtractor +from ..utils import ( +    clean_html, +    compat_parse_qs, +) + + +class Ro220IE(InfoExtractor): +    IE_NAME = '220.ro' +    _VALID_URL = r'(?x)(?:https?://)?(?:www\.)?220\.ro/(?P<category>[^/]+)/(?P<shorttitle>[^/]+)/(?P<video_id>[^/]+)' +    _TEST = { +        u"url": u"http://www.220.ro/sport/Luati-Le-Banii-Sez-4-Ep-1/LYV6doKo7f/", +        u'file': u'LYV6doKo7f.mp4', +        u'md5': u'03af18b73a07b4088753930db7a34add', +        u'info_dict': { +            u"title": u"Luati-le Banii sez 4 ep 1", +            u"description": u"Iata-ne reveniti dupa o binemeritata vacanta. Va astept si pe Facebook cu pareri si comentarii.", +        } +    } + +    def _real_extract(self, url): +        mobj = re.match(self._VALID_URL, url) +        video_id = mobj.group('video_id') + +        webpage = self._download_webpage(url, video_id) +        flashVars_str = self._search_regex( +            r'<param name="flashVars" value="([^"]+)"', +            webpage, u'flashVars') +        flashVars = compat_parse_qs(flashVars_str) + +        info = { +            '_type': 'video', +            'id': video_id, +            'ext': 'mp4', +            'url': flashVars['videoURL'][0], +            'title': flashVars['title'][0], +            'description': clean_html(flashVars['desc'][0]), +            'thumbnail': flashVars['preview'][0], +        } +        return info | 
