login works fine with lazy DAL

This commit is contained in:
mdipierro
2012-09-30 00:10:25 -05:00
parent 610cef4bb9
commit d42dfeb268
5 changed files with 79 additions and 37 deletions
+1 -1
View File
@@ -1 +1 @@
Version 2.0.9 (2012-09-29 23:47:22) dev
Version 2.0.9 (2012-09-30 00:10:18) dev
+1 -1
View File
@@ -11,7 +11,7 @@
if not request.env.web2py_runtime_gae:
## if NOT running on Google App Engine use SQLite or other DB
db = DAL('sqlite://storage.sqlite')
db = DAL('sqlite://storage.sqlite')
else:
## connect to Google BigTable (optional 'google:datastore://namespace')
db = DAL('google:datastore')
+75 -33
View File
@@ -519,6 +519,8 @@ class ConnectionPool(object):
sql_locker.release()
if really:
getattr(instance, 'close')()
if instance.db._singleton_code in thread_local.db_instances:
del thread_local.db_instances[instance.db._singleton_code]
if callable(action):
action(None)
@@ -1945,7 +1947,7 @@ class BaseAdapter(ConnectionPool):
db._referee_name % dict(
table=rfield.tablename,field=rfield.name)
if referee_link and not referee_link in colset:
colset[referee_link] = Set(db,rfield == id)
colset[referee_link] = LazySet(rfield,id)
else:
if not '_extra' in new_row:
new_row['_extra'] = Row()
@@ -6443,15 +6445,6 @@ class Row(object):
del d[k]
return d
def Row_unpickler(data):
return Row(cPickle.loads(data))
def Row_pickler(data):
return Row_unpickler, (cPickle.dumps(data.as_dict(datetime_to_str=False)),)
copy_reg.pickle(Row, Row_pickler, Row_unpickler)
################################################################################
# Everything below should be independent of the specifics of the database
# and should work for RDBMs and some NoSQL databases
@@ -6583,15 +6576,23 @@ class DAL(object):
Field('fieldname2'))
"""
#def __new__(cls, uri, *args, **kwargs):
# if not hasattr(thread_local,'db_instances'):
# thread_local.db_instances = {}
# try:
# return thread_local.db_instances[uri]
# except KeyError:
# instance = super(DAL, cls).__new__(cls, uri, *args, **kwargs)
# thread_local.db_instances[uri] = instance
# return instance
def __new__(cls, uri='sqlite://dummy.db', *args, **kwargs):
if not hasattr(thread_local,'db_instances'):
thread_local.db_instances = {}
if 'singleton_code' in kwargs:
singleton_code = kwargs['singleton_code']
del kwargs['singleton_code']
else:
singleton_code = hashlib.md5(uri).hexdigest()
try:
db = thread_local.db_instances[singleton_code]
if args or kwargs:
raise RuntimeError, 'Cannot duplicate a Singleton'
except KeyError:
db = super(DAL, cls).__new__(cls, uri, *args, **kwargs)
db._singleton_code = singleton_code
thread_local.db_instances[singleton_code] = db
return db
@staticmethod
def set_folder(folder):
@@ -6673,6 +6674,8 @@ class DAL(object):
:attempts (defaults to 5). Number of times to attempt connecting
"""
if hasattr(self,'_adapter'): return
if not decode_credentials:
credential_decoder = lambda cred: cred
else:
@@ -7136,6 +7139,8 @@ def index():
adapter = self._adapter
if adapter in thread_local.instances:
thread_local.instances.remove(adapter)
if self._singleton_code in thread_local.db_instances:
del thread_local.db_instances[self._singleton_code]
adapter.close()
def executesql(self, query, placeholders=None, as_dict=False,
@@ -7265,6 +7270,14 @@ def index():
self[tablename].import_from_csv_file(
ifile, id_map, null, unique, id_offset, *args, **kwargs)
def DAL_unpickler(uri):
return DAL(uri)
def DAL_pickler(db):
return DAL_unpickler, (db._uri,)
copy_reg.pickle(DAL, DAL_pickler, DAL_unpickler)
class SQLALL(object):
"""
Helper class providing a comma-separated string having all the field names
@@ -8825,10 +8838,12 @@ class Set(object):
class RecordUpdater(object):
def __init__(self, colset, table, id):
self.colset, self.table, self.id = colset, table, id
self.colset, self.db, self.tablename, self.id = \
colset, table._db, table._tablename, id
def __call__(self, **fields):
colset, table, id = self.colset, self.table, self.id
colset, db, tablename, id = self.colset, self.db, self.tablename, self.id
table = db[tablename]
newfields = fields or dict(colset)
for fieldname in newfields.keys():
if not fieldname in table.fields or table[fieldname].type=='id':
@@ -8839,10 +8854,47 @@ class RecordUpdater(object):
class RecordDeleter(object):
def __init__(self, table, id):
self.table, self.id = table,id
self.db, self.tablename, self.id = table._db, table._tablename, id
def __call__(self):
return self.table._db(self.table._id==self.id).delete()
return self.db(self.db[self.tablename]._id==self.id).delete()
class LazySet(object):
def __init__(self, field, id):
self.db, self.tablename, self.fieldname, self.id = \
field.db, field._tablename, field.name, id
def _getset(self):
query = self.db[self.tablename][self.fieldname]==self.id
return Set(self.db,query)
def __repr__(self):
return repr(self._getset())
def __call__(self, query, ignore_common_filters=False):
return self._getset()(query, ignore_common_filters)
def _count(self,distinct=None):
return self._getset()._count(distinct)
def _select(self, *fields, **attributes):
return self._getset()._select(*field,**attributes)
def _delete(self):
return self._getset()._delete()
def _update(self, **update_fields):
return self._getset()._update(**update_fields)
def isempty(self):
return self._getset().isempty()
def count(self,distinct=None, cache=None):
return self._getset().count(distinct,cache)
def select(self, *fields, **attributes):
return self._getset().select(*fields,**attributes)
def nested_select(self,*fields,**attributes):
return self._getset().nested_select(*fields,**attributes)
def delete(self):
return self._getset().delete()
def update(self, **update_fields):
return self._getset().update(**update_fields)
def update_naive(self, **update_fields):
return self._getset().update_naive(**update_fields)
def validate_and_update(self, **update_fields):
return self._getset().validate_and_update(**update_fields)
def delete_uploaded_files(self, upload_fields=None):
return self._getset().delete_uploaded_files(upload_fields)
class VirtualCommand(object):
def __init__(self,method,row):
@@ -9218,16 +9270,6 @@ class Rows(object):
import gluon.contrib.simplejson as simplejson
return simplejson.dumps(items)
def Rows_unpickler(data):
return cPickle.loads(data)
def Rows_pickler(data):
return Rows_unpickler, \
(cPickle.dumps(data.as_list(storage_to_dict=False,
datetime_to_str=False)),)
copy_reg.pickle(Rows, Rows_pickler, Rows_unpickler)
################################################################################
# dummy function used to define some doctests
+1 -1
View File
@@ -46,7 +46,7 @@ class Storage(dict):
__repr__ = lambda self: '<Storage %s>' % dict.__repr__(self)
# http://stackoverflow.com/questions/5247250/why-does-pickle-getstate-accept-as-a-return-value-the-very-instance-it-requi
__getstate__ = lambda self: None
__reduce_ex__ = None
# __reduce_ex__ = None
def getlist(self,key):
"""
+1 -1
View File
@@ -1709,7 +1709,7 @@ class Auth(object):
"""
login the user = db.auth_user(id)
"""
# user=Storage(self.table_user()._filter_fields(user,id=True))
user = Storage(self.table_user()._filter_fields(user,id=True))
current.session.auth = Storage(
user = user,
last_visit = current.request.now,