X-Git-Url: http://dolda2000.com/gitweb/?p=wrw.git;a=blobdiff_plain;f=wrw%2Fsession.py;fp=wrw%2Fsession.py;h=3185b0bbf1b12bc22ae895255f85599afbc72bdf;hp=0c585a37bdd97d00551614a7c7590b58d7d76f59;hb=425ebacf6c53fa475ad0e8c7aea62d19617d4aea;hpb=691f278cd4876685033cf7377ee77a3220e3d216 diff --git a/wrw/session.py b/wrw/session.py index 0c585a3..3185b0b 100644 --- a/wrw/session.py +++ b/wrw/session.py @@ -1,5 +1,5 @@ -import threading, time, pickle, random, os -import cookie, env +import threading, time, pickle, random, os, binascii +from . import cookie, env __all__ = ["db", "get"] @@ -8,7 +8,7 @@ def gennonce(length): class session(object): def __init__(self, lock, expire=86400 * 7): - self.id = gennonce(16).encode("hex") + self.id = binascii.b2a_hex(gennonce(16)) self.dict = {} self.lock = lock self.ctime = self.atime = self.mtime = int(time.time()) @@ -77,7 +77,7 @@ class db(object): def clean(self): now = int(time.time()) with self.lock: - clist = self.live.keys() + clist = list(self.live.keys()) for sessid in clist: with self.lock: try: @@ -195,7 +195,7 @@ class db(object): data = self.backdb[sessid] try: return pickle.loads(data) - except Exception, e: + except: raise KeyError() def freeze(self, sess):