From 9ca8bb2dc011d11cdc16b0b803cbc15560f8ec70 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Mike=20F=C3=A4hrmann?= Date: Sat, 22 Jan 2022 23:09:45 +0100 Subject: [PATCH] [twitter] improve error handling --- gallery_dl/extractor/twitter.py | 38 ++++++++++++++++++++------------- 1 file changed, 23 insertions(+), 15 deletions(-) diff --git a/gallery_dl/extractor/twitter.py b/gallery_dl/extractor/twitter.py index 688be44677..e05f8e300c 100644 --- a/gallery_dl/extractor/twitter.py +++ b/gallery_dl/extractor/twitter.py @@ -987,7 +987,7 @@ def _guest_token(self): endpoint = "/1.1/guest/activate.json" return str(self._call(endpoint, None, root, "POST")["guest_token"]) - def _call(self, endpoint, params, root=None, method="GET"): + def _call(self, endpoint, params, root=None, method="GET", warning=True): if root is None: root = self.root @@ -1012,6 +1012,8 @@ def _call(self, endpoint, params, root=None, method="GET"): if response.status_code < 400: # success + if errors and warning: + self.extractor.log.warning(errors) return data if response.status_code == 429: @@ -1135,13 +1137,16 @@ def _pagination_tweets(self, endpoint, variables, path=None): params = {"variables": json.dumps(variables)} data = self._call(endpoint, params)["data"] - if path is None: - instructions = (data["user"]["result"]["timeline"] - ["timeline"]["instructions"]) - else: - for key in path: - data = data[key] - instructions = data["instructions"] + try: + if path is None: + instructions = (data["user"]["result"]["timeline"] + ["timeline"]["instructions"]) + else: + for key in path: + data = data[key] + instructions = data["instructions"] + except KeyError: + return if pinned_tweet: pinned_tweet = False @@ -1214,13 +1219,16 @@ def _pagination_users(self, endpoint, variables, path=None): params = {"variables": json.dumps(variables)} data = self._call(endpoint, params)["data"] - if path is None: - instructions = (data["user"]["result"]["timeline"] - ["timeline"]["instructions"]) - else: - for key in path: - data = data[key] - instructions = data["instructions"] + try: + if path is None: + instructions = (data["user"]["result"]["timeline"] + ["timeline"]["instructions"]) + else: + for key in path: + data = data[key] + instructions = data["instructions"] + except KeyError: + return for instr in instructions: if instr["type"] == "TimelineAddEntries":