2018-03-25 09:50:17 +08:00
from __future__ import unicode_literals
import re
from . common import InfoExtractor
from . . compat import (
compat_kwargs ,
)
from . . utils import (
ExtractorError ,
urlencode_postdata ,
)
class TorrinsIE ( InfoExtractor ) :
IE_NAME = ' torrins '
_VALID_URL = r ''' (?x)
https ? : / /
2018-03-27 00:05:23 +08:00
www \. torrins \. com / ( ? : guitar | piano | bass ) - lessons / ( ? : song - lessons | style - genre ) / [ ^ / ] + / ( ? P < id > [ ^ / ] + ) / [ ^ \. ] + \. html
2018-03-25 09:50:17 +08:00
'''
_LOGIN_URL = ' https://www.torrins.com/services/user/sign-in '
_ORIGIN_URL = ' https://www.torrins.com '
_NETRC_MACHINE = ' torrins '
2018-03-25 11:11:44 +08:00
_TEST = {
2018-03-25 09:50:17 +08:00
' url ' : ' https://www.torrins.com/guitar-lessons/song-lessons/english-songs/another-brick-in-the-wall/song-demo.html ' ,
' info_dict ' : {
' id ' : ' another-brick-in-the-wall ' ,
' ext ' : ' mp4 ' ,
' title ' : ' Another Brick in the Wall Guitar - Song Demo ' ,
' description ' : ' md5:c0d51f6f21ef4ec65f091055a5eef876 ' ,
' duration ' : 579.29 ,
} ,
' skip ' : ' Requires torrins premium account credentials ' ,
2018-03-25 11:11:44 +08:00
}
2018-03-25 09:50:17 +08:00
def _handle_error ( self , response ) :
if not isinstance ( response , dict ) :
return
2018-03-27 00:05:23 +08:00
error = response [ ' error ' ]
2018-03-25 09:50:17 +08:00
if error :
2018-03-27 00:05:23 +08:00
error_str = ' Torrins returned error # %s : %s ' % ( error [ ' code ' ] , error . get [ ' message ' ] )
error_data = error [ ' data ' ]
2018-03-25 09:50:17 +08:00
if error_data :
2018-03-27 00:05:23 +08:00
error_str + = ' - %s ' % error_data [ ' formErrors ' ]
2018-03-25 09:50:17 +08:00
raise ExtractorError ( error_str , expected = True )
def _download_webpage ( self , * args , * * kwargs ) :
kwargs . setdefault ( ' headers ' , { } ) [ ' User-Agent ' ] = ' Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_5) AppleWebKit/603.2.4 (KHTML, like Gecko) Version/10.1.1 Safari/603.2.4 '
return super ( TorrinsIE , self ) . _download_webpage (
* args , * * compat_kwargs ( kwargs ) )
def _real_initialize ( self ) :
self . _login ( )
def _login ( self ) :
( username , password ) = self . _get_login_info ( )
if username is None :
return
def is_logged ( reason ) :
webpage = self . _download_webpage ( self . _ORIGIN_URL , None , reason )
return any ( re . search ( p , webpage ) for p in (
r ' id=[ " \' ](?:bt-logout) ' ,
r ' >Logout< ' ) )
# already logged in
if is_logged ( ' Checking if already logged in ' ) :
return
login_form = {
' email ' : username ,
' password ' : password ,
}
response = self . _download_webpage (
self . _LOGIN_URL , None , ' Logging in ' ,
data = urlencode_postdata ( login_form ) ,
headers = {
' Referer ' : self . _ORIGIN_URL ,
' Origin ' : self . _ORIGIN_URL ,
} )
if not is_logged ( ' Post login check ' ) :
error = self . _html_search_regex (
r ' (?s)<div[^>]+class= " form-errors[^ " ]* " >(.+?)</div> ' ,
response , ' error message ' , default = None )
if error :
raise ExtractorError ( ' Unable to login: %s ' % error , expected = True )
raise ExtractorError ( ' Unable to log in ' )
def _real_extract ( self , url ) :
course_id = self . _match_id ( url )
webpage = self . _download_webpage ( url , course_id )
2018-03-25 10:47:54 +08:00
video_json = self . _html_search_regex ( r " <div id= \" video \" idata= ' (.+?) ' " , webpage , ' video formats ' )
2018-03-25 09:50:17 +08:00
video_json = self . _parse_json ( video_json , course_id )
2018-03-27 00:05:23 +08:00
title = video_json . get ( ' title ' ) or self . _og_search_title ( webpage )
2018-03-25 12:16:38 +08:00
video_id = video_json [ ' id ' ]
2018-03-25 09:50:17 +08:00
2018-03-27 00:58:05 +08:00
formats = [ ]
if ' low ' in video_json :
formats . append ( {
2018-03-25 12:16:38 +08:00
' url ' : video_json [ ' low ' ] ,
2018-03-25 09:50:17 +08:00
' format_id ' : ' low ' ,
' height ' : 240 ,
' ext ' : ' mp4 '
2018-03-27 00:58:05 +08:00
} )
if ' medium ' in video_json :
formats . append ( {
2018-03-25 12:16:38 +08:00
' url ' : video_json [ ' medium ' ] ,
2018-03-25 09:50:17 +08:00
' format_id ' : ' medium ' ,
' height ' : 360 ,
' ext ' : ' mp4 '
2018-03-27 00:58:05 +08:00
} )
if ' high ' in video_json :
formats . append ( {
2018-03-25 12:16:38 +08:00
' url ' : video_json [ ' high ' ] ,
2018-03-25 09:50:17 +08:00
' format_id ' : ' high ' ,
' height ' : 480 ,
' ext ' : ' mp4 '
2018-03-27 00:58:05 +08:00
} )
2018-03-25 09:50:17 +08:00
return {
' id ' : video_id ,
' title ' : title ,
' formats ' : formats
2018-03-25 10:47:54 +08:00
}