summaryrefslogtreecommitdiffstats
path: root/pyload/network/CookieJar.py
diff options
context:
space:
mode:
authorGravatar Walter Purcaro <vuolter@gmail.com> 2014-12-11 17:03:31 +0100
committerGravatar Walter Purcaro <vuolter@gmail.com> 2014-12-11 17:03:31 +0100
commit5ae784da28024596e5f2621179625728cdc1e8f6 (patch)
tree273ae5dd85c8633d55491e438d893ee3434a8024 /pyload/network/CookieJar.py
parentClean up some import header (diff)
downloadpyload-5ae784da28024596e5f2621179625728cdc1e8f6.tar.xz
Bucket and CookieJar from 0.5.0
Diffstat (limited to 'pyload/network/CookieJar.py')
-rw-r--r--pyload/network/CookieJar.py54
1 files changed, 31 insertions, 23 deletions
diff --git a/pyload/network/CookieJar.py b/pyload/network/CookieJar.py
index 4e877b605..a2b302776 100644
--- a/pyload/network/CookieJar.py
+++ b/pyload/network/CookieJar.py
@@ -1,34 +1,42 @@
# -*- coding: utf-8 -*-
-# @author: RaNaN, mkaay
+# @author: RaNaN
+import Cookie
+
+from datetime import datetime, timedelta
from time import time
-class CookieJar(object):
- def __init__(self, pluginname, account=None):
- self.cookies = {}
- self.plugin = pluginname
- self.account = account
- def addCookies(self, clist):
- for c in clist:
- name = c.split("\t")[5]
- self.cookies[name] = c
+# monkey patch for 32 bit systems
+def _getdate(future=0, weekdayname=Cookie._weekdayname, monthname=Cookie._monthname):
+ dt = datetime.now() + timedelta(seconds=int(future))
+ return "%s, %02d %3s %4d %02d:%02d:%02d GMT" % \
+ (weekdayname[dt.weekday()], dt.day, monthname[dt.month], dt.year, dt.hour, dt.minute, dt.second)
- def getCookies(self):
- return self.cookies.values()
+Cookie._getdate = _getdate
- def parseCookie(self, name):
- if name in self.cookies:
- return self.cookies[name].split("\t")[6]
- else:
- return None
+
+class CookieJar(Cookie.SimpleCookie):
def getCookie(self, name):
- return self.parseCookie(name)
+ return self[name].value
+
+ def setCookie(self, domain, name, value, path="/", exp=None, secure="FALSE"):
+ self[name] = value
+ self[name]["domain"] = domain
+ self[name]["path"] = path
+
+ # Value of expires should be integer if possible
+ # otherwise the cookie won't be used
+ if not exp:
+ expires = time() + 3600 * 24 * 180
+ else:
+ try:
+ expires = int(exp)
+ except ValueError:
+ expires = exp
- def setCookie(self, domain, name, value, path="/", exp=time()+3600*24*180):
- s = ".%s TRUE %s FALSE %s %s %s" % (domain, path, exp, name, value)
- self.cookies[name] = s
+ self[name]["expires"] = expires
- def clear(self):
- self.cookies = {}
+ if secure == "TRUE":
+ self[name]["secure"] = secure