]>
Raphaƫl G. Git Repositories - youtubedl/blob - youtube_dl/extractor/veoh.py 
   1  from  __future__ 
import  unicode_literals
   6  from  . common 
import  InfoExtractor
  14  class  VeohIE ( InfoExtractor
):   15      _VALID_URL 
=  r
'http://(?:www\.)?veoh\.com/(?:watch|iphone/#_Watch)/(?P<id>(?:v|yapi-)[\da-zA-Z]+)'   19              'url' :  'http://www.veoh.com/watch/v56314296nk7Zdmz3' ,   20              'md5' :  '620e68e6a3cff80086df3348426c9ca3' ,   24                  'title' :  'Straight Backs Are Stronger' ,   25                  'uploader' :  'LUMOback' ,   26                  'description' :  'At LUMOback, we believe straight backs are stronger.  The LUMOback Posture & Movement Sensor:  It gently vibrates when you slouch, inspiring improved posture and mobility.  Use the app to track your data and improve your posture over time. ' ,   30              'url' :  'http://www.veoh.com/watch/v27701988pbTc4wzN?h1=Chile+workers+cover+up+to+avoid+skin+damage' ,   31              'md5' :  '4a6ff84b87d536a6a71e6aa6c0ad07fa' ,   35                  'title' :  'Chile workers cover up to avoid skin damage' ,   36                  'description' :  'md5:2bd151625a60a32822873efc246ba20d' ,   37                  'uploader' :  'afp-news' ,   42              'url' :  'http://www.veoh.com/watch/v69525809F6Nc4frX' ,   43              'md5' :  '4fde7b9e33577bab2f2f8f260e30e979' ,   44              'note' :  'Embedded ooyala video' ,   48                  'title' :  'Doctors Alter Plan For Preteen \' s Weight Loss Surgery' ,   49                  'description' :  'md5:f5a11c51f8fb51d2315bca0937526891' ,   50                  'uploader' :  'newsy-videos' ,   52              'skip' :  'This video has been deleted.' ,   56      def  _extract_formats ( self
,  source
):   58          link 
=  source
. get ( 'aowPermalink' )   65          link 
=  source
. get ( 'fullPreviewHashLowPath' )   71          link 
=  source
. get ( 'fullPreviewHashHighPath' )   79      def  _extract_video ( self
,  source
):   81              'id' :  source
. get ( 'videoId' ),   82              'title' :  source
. get ( 'title' ),   83              'description' :  source
. get ( 'description' ),   84              'thumbnail' :  source
. get ( 'highResImage' )  or  source
. get ( 'medResImage' ),   85              'uploader' :  source
. get ( 'username' ),   86              'duration' :  int_or_none ( source
. get ( 'length' )),   87              'view_count' :  int_or_none ( source
. get ( 'views' )),   88              'age_limit' :  18  if  source
. get ( 'isMature' ) ==  'true'  or  source
. get ( 'isSexy' ) ==  'true'  else  0 ,   89              'formats' :  self
._ extract
_ formats
( source
),   92      def  _real_extract ( self
,  url
):   93          mobj 
=  re
. match ( self
._ VALID
_U RL
,  url
)   94          video_id 
=  mobj
. group ( 'id' )   96          if  video_id
. startswith ( 'v' ):   97              rsp 
=  self
._ download
_ xml
(   98                  r
'http://www.veoh.com/api/findByPermalink?permalink= %s '  %  video_id
,  video_id
,  'Downloading video XML' )   99              stat 
=  rsp
. get ( 'stat' )  101                  return  self
._ extract
_ video
( rsp
. find ( './videoList/video' ))  103                  raise  ExtractorError (  104                      ' %s  said:  %s '  % ( self
. IE_NAME
,  rsp
. find ( './errorList/error' ). get ( 'errorMessage' )),  expected
= True )  106          webpage 
=  self
._ download
_ webpage
( url
,  video_id
)  108          if  'class="adultwarning-container"'  in  webpage
:  109              self
. report_age_confirmation ()  111              request 
=  sanitized_Request ( url
)  112              request
. add_header ( 'Cookie' ,  'confirmedAdult=true' )  113              webpage 
=  self
._ download
_ webpage
( request
,  video_id
)  115          m_youtube 
=  re
. search ( r
'http://www\.youtube\.com/v/(.*?)(\&|"|\?)' ,  webpage
)  116          if  m_youtube 
is not None :  117              youtube_id 
=  m_youtube
. group ( 1 )  118              self
. to_screen ( ' %s : detected Youtube video.'  %  video_id
)  119              return  self
. url_result ( youtube_id
,  'Youtube' )  122              self
._ search
_ regex
( r
'videoDetailsJSON = \' ({.* ?
}) \' ; ', webpage, ' info
').replace(' \\\' ', ' \' '))  124          video = self._extract_video(info)  125          video[' age_limit
'] = age_limit