diff options
Diffstat (limited to 'module/plugins/accounts/FilesonicCom.py')
-rw-r--r-- | module/plugins/accounts/FilesonicCom.py | 32 |
1 files changed, 20 insertions, 12 deletions
diff --git a/module/plugins/accounts/FilesonicCom.py b/module/plugins/accounts/FilesonicCom.py index 1200550ae..7ea7ea7cb 100644 --- a/module/plugins/accounts/FilesonicCom.py +++ b/module/plugins/accounts/FilesonicCom.py @@ -22,29 +22,37 @@ from time import mktime, strptime from module.plugins.Account import Account +try:
+ from json import loads as json_loads
+except ImportError: # pragma: no cover
+ from module.lib.simplejson import loads as json_loads
+ + class FilesonicCom(Account): __name__ = "FilesonicCom" - __version__ = "0.3" + __version__ = "0.31" __type__ = "account" __description__ = """filesonic.com account plugin""" - __author_name__ = ("RaNaN") - __author_mail__ = ("RaNaN@pyload.org") + __author_name__ = ("RaNaN","Paul King") + __author_mail__ = ("RaNaN@pyload.org","") def getDomain(self, req): - xml = req.load("http://api.filesonic.com/utility?method=getFilesonicDomainForCurrentIp&format=xml").decode("utf8") - return re.search(r"response>.*?(filesonic\..*?)</resp", xml).group(1) - + xml = req.load("http://api.filesonic.com/utility?method=getFilesonicDomainForCurrentIp&format=json").decode("utf8") + return json_loads(xml)["FSApi_Utility"]["getFilesonicDomainForCurrentIp"]["response"] + def loadAccountInfo(self, user, req): - xml = req.load("http://api.filesonic.com/user?method=getInfo&format=xml", + xml = req.load("http://api.filesonic.com/user?method=getInfo&format=json", post = {"u": user, "p" : self.accounts[user]["password"]} ).decode("utf8") - if re.search(r'<status>failed', xml): + self.core.log.debug(_("%s: account status retrieved from api %s" % (self.__name__,xml))) + json = json_loads(xml) + if json["FSApi_User"]["getInfo"]["status"] != "success": self.core.log.error(_("%s: Invalid login retrieving user details" % self.__name__)) - self.wrongPassword() - premium = bool(int(re.search(r'<is_premium>(\d+)',xml).group(1))) + return {"validuntil": -1, "trafficleft": -1, "premium" : False} + premium = json["FSApi_User"]["getInfo"]["response"]["users"]["user"]["is_premium"] if premium: - validuntil = re.search(r'<premium_expiration>\d+-\d+-\d+ \d+:\d+:\d+</', xml).group(1) + validuntil = json["FSApi_User"]["getInfo"]["response"]["users"]["user"]["premium_expiration"] validuntil = int(mktime(strptime(validuntil, "%Y-%m-%d %H:%M:%S"))) else: validuntil = -1 @@ -58,7 +66,7 @@ class FilesonicCom(Account): "password": data["password"], "rememberMe" : 1 } - page = req.load("http://www.%s/user/login" % domain, cookies=True, post=post_vars).decode("utf8") + page = req.load("http://www%s/user/login" % domain, cookies=True, post=post_vars).decode("utf8") if "Provided password does not match." in page or "You must be logged in to view this page." in page: self.wrongPassword() |