1
0
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:
Mike Fährmann 2020-05-30 18:07:45 +02:00
parent c4d06a8331
commit 0f459f340b
No known key found for this signature in database
GPG Key ID: 5680CA389D365A88
4 changed files with 35 additions and 6 deletions

View File

@ -230,6 +230,7 @@ Description The username and password to use when attempting to log in to
* ``e621``
* ``exhentai``
* ``idolcomplex``
* ``instagram``
* ``luscious``
* ``sankaku``
* ``tsumino``

View File

@ -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

View File

@ -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 = {

View File

@ -151,6 +151,7 @@ AUTH_MAP = {
"flickr" : "Optional (OAuth)",
"idolcomplex": "Optional",
"imgbb" : "Optional",
"instagram" : "Optional",
"mangoxo" : "Optional",
"newgrounds" : "Optional",
"nijie" : "Required",