Fixes #11572 Use cfscrape to avoid Crunchyroll error 503
This commit is contained in:
parent
dcae7b3fdc
commit
72cb991f90
@ -5,6 +5,7 @@ import re
|
|||||||
import json
|
import json
|
||||||
import base64
|
import base64
|
||||||
import zlib
|
import zlib
|
||||||
|
import cfscrape
|
||||||
|
|
||||||
from hashlib import sha1
|
from hashlib import sha1
|
||||||
from math import pow, sqrt, floor
|
from math import pow, sqrt, floor
|
||||||
@ -43,6 +44,12 @@ class CrunchyrollBaseIE(InfoExtractor):
|
|||||||
if username is None:
|
if username is None:
|
||||||
return
|
return
|
||||||
|
|
||||||
|
# Scrape cookie from cloudfront and insert them
|
||||||
|
scraper = cfscrape.create_scraper()
|
||||||
|
tokens = scraper.get_tokens(self._LOGIN_URL, 'Mozilla/5.0 (X11; Linux x86_64; rv:10.0) Gecko/20150101 Firefox/47.0 (Chrome)')
|
||||||
|
self._set_crunchyroll_cookie('cf_clearance', tokens[0]['cf_clearance'])
|
||||||
|
self._set_crunchyroll_cookie('__cfduid', tokens[0]['__cfduid'])
|
||||||
|
|
||||||
login_page = self._download_webpage(
|
login_page = self._download_webpage(
|
||||||
self._LOGIN_URL, None, 'Downloading login page')
|
self._LOGIN_URL, None, 'Downloading login page')
|
||||||
|
|
||||||
@ -103,6 +110,9 @@ class CrunchyrollBaseIE(InfoExtractor):
|
|||||||
request.add_header('Accept-Language', '*')
|
request.add_header('Accept-Language', '*')
|
||||||
return super(CrunchyrollBaseIE, self)._download_webpage(request, *args, **kwargs)
|
return super(CrunchyrollBaseIE, self)._download_webpage(request, *args, **kwargs)
|
||||||
|
|
||||||
|
def _set_crunchyroll_cookie(self, name, value):
|
||||||
|
self._set_cookie('crunchyroll.com', name, value)
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def _add_skip_wall(url):
|
def _add_skip_wall(url):
|
||||||
parsed_url = compat_urlparse.urlparse(url)
|
parsed_url = compat_urlparse.urlparse(url)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user