mirror of
https://github.com/mikf/gallery-dl.git
synced 2024-11-22 02:32:33 +01:00
[instagram] fix and re-enable login with username&password
This reverts commit 3e0848a482
.
(#756, #771, #797, #803)
https://github.com/althonos/InsaLooter/issues/287#issuecomment-630456522
This commit is contained in:
parent
c4d06a8331
commit
0f459f340b
@ -230,6 +230,7 @@ Description The username and password to use when attempting to log in to
|
||||
* ``e621``
|
||||
* ``exhentai``
|
||||
* ``idolcomplex``
|
||||
* ``instagram``
|
||||
* ``luscious``
|
||||
* ``sankaku``
|
||||
* ``tsumino``
|
||||
|
@ -59,7 +59,7 @@ ImgBB https://imgbb.com/ Albums, individual Imag
|
||||
imgbox https://imgbox.com/ Galleries, individual Images
|
||||
imgth https://imgth.com/ Galleries
|
||||
imgur https://imgur.com/ |imgur-C|
|
||||
Instagram https://www.instagram.com/ |instagram-C|
|
||||
Instagram https://www.instagram.com/ |instagram-C| Optional
|
||||
Issuu https://issuu.com/ Publications, User Profiles
|
||||
Jaimini's Box https://jaiminisbox.com/reader/ Chapters, Manga
|
||||
Joyreactor http://joyreactor.com/ Posts, Search Results, Tag Searches, User Profiles
|
||||
|
@ -10,10 +10,11 @@
|
||||
"""Extractors for https://www.instagram.com/"""
|
||||
|
||||
from .common import Extractor, Message
|
||||
from .. import text
|
||||
from .. import text, exception
|
||||
from ..cache import cache
|
||||
import itertools
|
||||
import json
|
||||
import time
|
||||
import re
|
||||
|
||||
|
||||
@ -66,10 +67,36 @@ class InstagramExtractor(Extractor):
|
||||
|
||||
@cache(maxage=360*24*3600, keyarg=1)
|
||||
def _login_impl(self, username, password):
|
||||
self.log.warning(
|
||||
'Logging in with username and password is currently not possible. '
|
||||
'Use cookies from your browser session instead.')
|
||||
return {}
|
||||
self.log.info("Logging in as %s", username)
|
||||
|
||||
page = self.request(self.root + "/accounts/login/").text
|
||||
headers = {
|
||||
"Referer" : self.root + "/accounts/login/",
|
||||
"X-IG-App-ID" : "936619743392459",
|
||||
"X-Requested-With": "XMLHttpRequest",
|
||||
}
|
||||
|
||||
response = self.request(self.root + "/web/__mid/", headers=headers)
|
||||
headers["X-CSRFToken"] = response.cookies["csrftoken"]
|
||||
headers["X-Instagram-AJAX"] = text.extract(
|
||||
page, '"rollout_hash":"', '"')[0]
|
||||
|
||||
url = self.root + "/accounts/login/ajax/"
|
||||
data = {
|
||||
"username" : username,
|
||||
"enc_password" : "#PWD_INSTAGRAM_BROWSER:0:{}:{}".format(
|
||||
int(time.time()), password),
|
||||
"queryParams" : "{}",
|
||||
"optIntoOneTap": "false",
|
||||
}
|
||||
response = self.request(url, method="POST", headers=headers, data=data)
|
||||
|
||||
if not response.json().get("authenticated"):
|
||||
raise exception.AuthenticationError()
|
||||
return {
|
||||
key: self.session.cookies.get(key)
|
||||
for key in ("sessionid", "mid", "csrftoken")
|
||||
}
|
||||
|
||||
def _request_graphql(self, variables, query_hash, csrf=None):
|
||||
headers = {
|
||||
|
@ -151,6 +151,7 @@ AUTH_MAP = {
|
||||
"flickr" : "Optional (OAuth)",
|
||||
"idolcomplex": "Optional",
|
||||
"imgbb" : "Optional",
|
||||
"instagram" : "Optional",
|
||||
"mangoxo" : "Optional",
|
||||
"newgrounds" : "Optional",
|
||||
"nijie" : "Required",
|
||||
|
Loading…
Reference in New Issue
Block a user