[exhentai] update login procedure (#37)
This new version behaves pretty much exactly like a browser would and caches all cookies sent to it and not just "ipb_member_id" and "ipb_pass_hash".
This commit is contained in:
parent
88a386977e
commit
3ee39ffd93
@ -61,12 +61,11 @@ class ExhentaiGalleryExtractor(Extractor):
|
||||
|
||||
url = "{}/g/{}/{}/".format(self.root, self.gid, self.token)
|
||||
response = self.request(url, fatal=False)
|
||||
page, headers = response.text, response.headers
|
||||
page = response.text
|
||||
|
||||
if response.status_code == 404 and "Gallery Not Available" in page:
|
||||
raise exception.AuthorizationError()
|
||||
if (headers.get("Content-Length") == "9615" and
|
||||
"sadpanda.jpg" in headers.get("Content-Disposition", "")):
|
||||
if self._is_sadpanda(response):
|
||||
self.log.info("sadpanda.jpg")
|
||||
raise exception.AuthorizationError()
|
||||
if page.startswith(("Key missing", "Gallery not found")):
|
||||
@ -80,7 +79,7 @@ class ExhentaiGalleryExtractor(Extractor):
|
||||
data.update(image)
|
||||
if "/fullimg.php" in url:
|
||||
data["extension"] = ""
|
||||
self.wait((1, 2))
|
||||
self.wait(1.5)
|
||||
yield Message.Url, url, data
|
||||
|
||||
def get_job_metadata(self, page):
|
||||
@ -175,7 +174,7 @@ class ExhentaiGalleryExtractor(Extractor):
|
||||
if not waittime:
|
||||
waittime = random.uniform(self.wait_min, self.wait_max)
|
||||
else:
|
||||
waittime = random.uniform(*waittime)
|
||||
waittime = random.uniform(waittime * 0.66, waittime * 1.33)
|
||||
time.sleep(waittime)
|
||||
|
||||
def login(self):
|
||||
@ -197,6 +196,11 @@ class ExhentaiGalleryExtractor(Extractor):
|
||||
def _login_impl(self, username, password):
|
||||
"""Actual login implementation"""
|
||||
self.log.info("Logging in as %s", username)
|
||||
|
||||
# visit "home.php" to get "__cfduid" cookie
|
||||
response = self.request("https://e-hentai.org/home.php")
|
||||
|
||||
# send login form
|
||||
url = "https://forums.e-hentai.org/index.php?act=Login&CODE=01"
|
||||
data = {
|
||||
"CookieDate": "1",
|
||||
@ -207,11 +211,30 @@ class ExhentaiGalleryExtractor(Extractor):
|
||||
"ipb_login_submit": "Login!",
|
||||
}
|
||||
headers = {
|
||||
"Referer": "https://e-hentai.org/bounce_login.php?b=d&bt=1-1"
|
||||
"Referer": response.url
|
||||
}
|
||||
response = self.request(url, method="POST", data=data, headers=headers)
|
||||
|
||||
if "You are now logged in as:" not in response.text:
|
||||
self.log.debug(response.text)
|
||||
# visit "exhentai.org" to transfer cookies
|
||||
self.wait(1.5)
|
||||
response = self.request("https://exhentai.org")
|
||||
if self._is_sadpanda(response):
|
||||
raise exception.AuthenticationError()
|
||||
return {c: response.cookies[c] for c in self.cookienames}
|
||||
|
||||
# collect exhentai cookies in dict (this should yield
|
||||
# "ipb_member_id", "ipb_pass_hash", "igneous", and "yay")
|
||||
cookies = {
|
||||
c.name: c.value
|
||||
for c in self.session.cookies
|
||||
if c.domain == self.cookiedomain
|
||||
}
|
||||
|
||||
return cookies
|
||||
|
||||
@staticmethod
|
||||
def _is_sadpanda(response):
|
||||
"""Return True if the response object contains a sad panda"""
|
||||
return (
|
||||
response.headers.get("Content-Length") == "9615" and
|
||||
"sadpanda.jpg" in response.headers.get("Content-Disposition", "")
|
||||
)
|
||||
|
@ -63,6 +63,9 @@ skip = [
|
||||
"exhentai", "kissmanga", "mangafox", "dynastyscans", "nijie",
|
||||
"archivedmoe", "archiveofsins", "thebarchive",
|
||||
# temporary issues
|
||||
"jaiminisbox", # 522
|
||||
"e621",
|
||||
"3dbooru",
|
||||
]
|
||||
# enable selective testing for direct calls
|
||||
if __name__ == '__main__' and len(sys.argv) > 1:
|
||||
|
Loading…
x
Reference in New Issue
Block a user