2013-06-30 00:22:03 +08:00
# coding: utf-8
2013-06-29 04:01:47 +08:00
import json
import re
from . common import InfoExtractor
from . . utils import (
compat_urllib_parse ,
2013-06-30 00:22:03 +08:00
unified_strdate ,
2013-06-29 04:01:47 +08:00
)
class WatIE ( InfoExtractor ) :
_VALID_URL = r ' http://www.wat.tv/.*-(?P<shortID>.*?)_.*?.html '
IE_NAME = ' wat.tv '
_TEST = {
u ' url ' : u ' http://www.wat.tv/video/world-war-philadelphia-vost-6bv55_2fjr7_.html ' ,
2013-06-30 00:22:03 +08:00
u ' file ' : u ' 10631273.mp4 ' ,
2013-07-30 05:38:02 +08:00
# Sometimes wat serves the whole file with the --test option
u ' md5 ' : u ' d8b2231e1e333acd12aad94b80937e19 ' ,
2013-06-29 04:01:47 +08:00
u ' info_dict ' : {
2013-06-30 00:22:03 +08:00
u ' title ' : u ' World War Z - Philadelphia VOST ' ,
u ' description ' : u ' La menace est partout. Que se passe-t-il à Philadelphia ? \r \n WORLD WAR Z, avec Brad Pitt, au cinéma le 3 juillet. \r \n http://www.worldwarz.fr ' ,
2013-06-29 04:01:47 +08:00
}
}
2013-06-30 00:22:03 +08:00
def download_video_info ( self , real_id ) :
# 'contentv4' is used in the website, but it also returns the related
# videos, we don't need them
info = self . _download_webpage ( ' http://www.wat.tv/interface/contentv3/ ' + real_id , real_id , ' Downloading video info ' )
info = json . loads ( info )
return info [ ' media ' ]
2013-06-29 04:01:47 +08:00
def _real_extract ( self , url ) :
2013-06-30 00:22:03 +08:00
def real_id_for_chapter ( chapter ) :
return chapter [ ' tc_start ' ] . split ( ' - ' ) [ 0 ]
2013-06-29 04:01:47 +08:00
mobj = re . match ( self . _VALID_URL , url )
short_id = mobj . group ( ' shortID ' )
2013-06-30 00:22:03 +08:00
webpage = self . _download_webpage ( url , short_id )
real_id = self . _search_regex ( r ' xtpage = " .*-(.*?) " ; ' , webpage , ' real id ' )
video_info = self . download_video_info ( real_id )
chapters = video_info [ ' chapters ' ]
first_chapter = chapters [ 0 ]
2013-06-29 04:01:47 +08:00
2013-06-30 00:22:03 +08:00
if real_id_for_chapter ( first_chapter ) != real_id :
self . to_screen ( ' Multipart video detected ' )
chapter_urls = [ ]
for chapter in chapters :
chapter_id = real_id_for_chapter ( chapter )
# Yes, when we this chapter is processed by WatIE,
# it will download the info again
chapter_info = self . download_video_info ( chapter_id )
chapter_urls . append ( chapter_info [ ' url ' ] )
entries = [ self . url_result ( chapter_url ) for chapter_url in chapter_urls ]
return self . playlist_result ( entries , real_id , video_info [ ' title ' ] )
# Otherwise we can continue and extract just one part, we have to use
# the short id for getting the video url
info = { ' id ' : real_id ,
2013-07-30 05:38:02 +08:00
' url ' : ' http://wat.tv/get/android5/ %s .mp4 ' % real_id ,
2013-06-29 04:01:47 +08:00
' ext ' : ' mp4 ' ,
2013-06-30 00:22:03 +08:00
' title ' : first_chapter [ ' title ' ] ,
' thumbnail ' : first_chapter [ ' preview ' ] ,
' description ' : first_chapter [ ' description ' ] ,
' view_count ' : video_info [ ' views ' ] ,
2013-06-29 04:01:47 +08:00
}
2013-06-30 00:22:03 +08:00
if ' date_diffusion ' in first_chapter :
info [ ' upload_date ' ] = unified_strdate ( first_chapter [ ' date_diffusion ' ] )
return info