summaryrefslogtreecommitdiffstats
path: root/gallery_dl/extractor/gofile.py
diff options
context:
space:
mode:
authorLibravatarUnit 193 <unit193@unit193.net>2024-03-25 02:57:44 -0400
committerLibravatarUnit 193 <unit193@unit193.net>2024-03-25 02:57:44 -0400
commit6e662211019a89caec44de8a57c675872b0b5498 (patch)
tree5d9d5a2b7efc3a24dd6074e99b253b639fe5af1d /gallery_dl/extractor/gofile.py
parent01166fa52707cc282467427cf0e65c1b8983c4be (diff)
New upstream version 1.26.9.upstream/1.26.9
Diffstat (limited to 'gallery_dl/extractor/gofile.py')
-rw-r--r--gallery_dl/extractor/gofile.py33
1 files changed, 19 insertions, 14 deletions
diff --git a/gallery_dl/extractor/gofile.py b/gallery_dl/extractor/gofile.py
index 289f91c..f0eb4e9 100644
--- a/gallery_dl/extractor/gofile.py
+++ b/gallery_dl/extractor/gofile.py
@@ -41,9 +41,13 @@ class GofileFolderExtractor(Extractor):
folder = self._get_content(self.content_id, password)
yield Message.Directory, folder
+ try:
+ contents = folder.pop("children")
+ except KeyError:
+ raise exception.AuthorizationError("Password required")
+
num = 0
- contents = folder.pop("contents")
- for content_id in folder["childs"]:
+ for content_id in folder["childrenIds"]:
content = contents[content_id]
content["folder"] = folder
@@ -67,31 +71,32 @@ class GofileFolderExtractor(Extractor):
@memcache()
def _create_account(self):
self.log.debug("Creating temporary account")
- return self._api_request("createAccount")["token"]
+ return self._api_request("accounts", method="POST")["token"]
@cache(maxage=86400)
def _get_website_token(self):
self.log.debug("Fetching website token")
page = self.request(self.root + "/dist/js/alljs.js").text
- return text.extr(page, 'fetchData.wt = "', '"')
+ return text.extr(page, 'wt: "', '"')
def _get_content(self, content_id, password=None):
+ headers = {"Authorization": "Bearer " + self.api_token}
+ params = {"wt": self.website_token}
if password is not None:
- password = hashlib.sha256(password.encode()).hexdigest()
- return self._api_request("getContent", {
- "contentId" : content_id,
- "token" : self.api_token,
- "wt" : self.website_token,
- "password" : password,
- })
-
- def _api_request(self, endpoint, params=None):
+ params["password"] = hashlib.sha256(password.encode()).hexdigest()
+ return self._api_request("contents/" + content_id, params, headers)
+
+ def _api_request(self, endpoint, params=None, headers=None, method="GET"):
response = self.request(
- "https://api.gofile.io/" + endpoint, params=params).json()
+ "https://api.gofile.io/" + endpoint,
+ method=method, params=params, headers=headers,
+ ).json()
if response["status"] != "ok":
if response["status"] == "error-notFound":
raise exception.NotFoundError("content")
+ if response["status"] == "error-passwordRequired":
+ raise exception.AuthorizationError("Password required")
raise exception.StopExtraction(
"%s failed (Status: %s)", endpoint, response["status"])