Commit f4ebb503 authored by Ayush Tiwari's avatar Ayush Tiwari

sql_catalog: Drop usage of getattr from SQLCatalog

This would increase compatibility between accessors in erp5_catalog and
remove the need of copy and patch. At the same time, it also helps in
increasing performance as using _getOb is always less costly than
getattr, as it reduces the need to look in acquisition.
parent b7d700ce
...@@ -962,13 +962,16 @@ class Catalog(Folder, ...@@ -962,13 +962,16 @@ class Catalog(Folder,
self.subject_set_uid_dict[subject_list] = subject_set_uid self.subject_set_uid_dict[subject_list] = subject_set_uid
return (subject_set_uid, subject_list) return (subject_set_uid, subject_list)
def getSqlClearCatalogList(self):
return self.sql_clear_catalog
def _clear(self): def _clear(self):
""" """
Clears the catalog by calling a list of methods Clears the catalog by calling a list of methods
""" """
methods = self.sql_clear_catalog method_id_list = self.getSqlClearCatalogList()
for method_name in methods: for method_name in method_id_list:
method = getattr(self, method_name) method = self._getOb(method_name)
try: try:
method() method()
except ConflictError: except ConflictError:
...@@ -990,23 +993,29 @@ class Catalog(Folder, ...@@ -990,23 +993,29 @@ class Catalog(Folder,
self._clearSubjectCache() self._clearSubjectCache()
self._clearCaches() self._clearCaches()
def getSqlCatalogReservedUid(self):
return self.sql_catalog_reserve_uid
security.declarePrivate('insertMaxUid') security.declarePrivate('insertMaxUid')
def insertMaxUid(self): def insertMaxUid(self):
""" """
Add a dummy item so that SQLCatalog will not use existing uids again. Add a dummy item so that SQLCatalog will not use existing uids again.
""" """
if self._max_uid is not None and self._max_uid() != 0: if self._max_uid is not None and self._max_uid() != 0:
method_id = self.sql_catalog_reserve_uid method_id = self.getSqlCatalogReservedUid()
method = getattr(self, method_id) method = self._getOb(method_id)
self._max_uid.change(1) self._max_uid.change(1)
method(uid = [self._max_uid()]) method(uid = [self._max_uid()])
def getSqlCatalogClearReserved(self):
return self.sql_catalog_clear_reserved
def _clearReserved(self): def _clearReserved(self):
""" """
Clears reserved uids Clears reserved uids
""" """
method_id = self.sql_catalog_clear_reserved method_id = self.getSqlCatalogClearReserved()
method = getattr(self, method_id) method = self._getOb(method_id)
try: try:
method() method()
except ConflictError: except ConflictError:
...@@ -1018,6 +1027,9 @@ class Catalog(Folder, ...@@ -1018,6 +1027,9 @@ class Catalog(Folder,
raise raise
self._last_clear_reserved_time += 1 self._last_clear_reserved_time += 1
def getSqlGetitemByUid(self):
return self.sql_getitem_by_uid
security.declarePrivate('getRecordForUid') security.declarePrivate('getRecordForUid')
def getRecordForUid(self, uid): def getRecordForUid(self, uid):
""" """
...@@ -1032,7 +1044,7 @@ class Catalog(Folder, ...@@ -1032,7 +1044,7 @@ class Catalog(Folder,
# It could also have a performance impact for traversals to objects in # It could also have a performance impact for traversals to objects in
# the acquisition context on Zope 2.12 even when it didn't raise a weird # the acquisition context on Zope 2.12 even when it didn't raise a weird
# error. # error.
method = getattr(self, self.sql_getitem_by_uid) method = self._getOb(self.getSqlGetitemByUid())
search_result = method(uid = uid) search_result = method(uid = uid)
if len(search_result) > 0: if len(search_result) > 0:
return search_result[0] return search_result[0]
...@@ -1058,23 +1070,35 @@ class Catalog(Folder, ...@@ -1058,23 +1070,35 @@ class Catalog(Folder,
self.schema = schema self.schema = schema
self.names = names self.names = names
def getSqlSearchTablesList(self):
return list(self.sql_search_tables)
security.declarePrivate('getCatalogSearchTableIds') security.declarePrivate('getCatalogSearchTableIds')
def getCatalogSearchTableIds(self): def getCatalogSearchTableIds(self):
"""Return selected tables of catalog which are used in JOIN. """Return selected tables of catalog which are used in JOIN.
catalaog is always first catalaog is always first
""" """
search_tables = list(self.sql_search_tables) or ['catalog'] search_tables = self.getSqlSearchTablesList() or ['catalog']
if search_tables[0] != 'catalog': if search_tables[0] != 'catalog':
search_tables = ['catalog'] + [x for x in search_tables if x != 'catalog'] search_tables = ['catalog'] + [x for x in search_tables if x != 'catalog']
# XXX: cast to tuple to avoid a mutable persistent property ? # XXX: cast to tuple to avoid a mutable persistent property ?
self.sql_search_tables = search_tables self.sql_search_tables = search_tables
return search_tables return search_tables
def getSqlSearchResultKeysList(self):
return self.sql_search_result_keys
security.declarePublic('getCatalogSearchResultKeys') security.declarePublic('getCatalogSearchResultKeys')
def getCatalogSearchResultKeys(self): def getCatalogSearchResultKeys(self):
"""Return search result keys. """Return search result keys.
""" """
return self.sql_search_result_keys return self.getSqlSearchResultKeysList()
def getSqlCatalogMultiSchema(self):
return self.sql_catalog_multi_schema
def getSqlCatalogSchema(self):
return self.sql_catalog_schema
@transactional_cache_decorator('SQLCatalog._getCatalogSchema') @transactional_cache_decorator('SQLCatalog._getCatalogSchema')
def _getCatalogSchema(self): def _getCatalogSchema(self):
...@@ -1086,7 +1110,7 @@ class Catalog(Folder, ...@@ -1086,7 +1110,7 @@ class Catalog(Folder,
"than sql_catalog_multi_schema. It makes many SQL queries " "than sql_catalog_multi_schema. It makes many SQL queries "
"instead of one", "instead of one",
DeprecationWarning) DeprecationWarning)
method_name = self.sql_catalog_schema method_name = self.getSqlCatalogSchema()
try: try:
method = getattr(self, method_name) method = getattr(self, method_name)
except AttributeError: except AttributeError:
...@@ -1204,6 +1228,9 @@ class Catalog(Folder, ...@@ -1204,6 +1228,9 @@ class Catalog(Folder,
uid_buffer_dict[thread_key] = UidBuffer() uid_buffer_dict[thread_key] = UidBuffer()
return uid_buffer_dict[thread_key] return uid_buffer_dict[thread_key]
def getSqlCatalogProduceReserved(self):
return self.sql_catalog_produce_reserved
# the cataloging API # the cataloging API
security.declarePrivate('produceUid') security.declarePrivate('produceUid')
def produceUid(self): def produceUid(self):
...@@ -1233,8 +1260,8 @@ class Catalog(Folder, ...@@ -1233,8 +1260,8 @@ class Catalog(Folder,
# already keeps track of the highest allocated number for all id # already keeps track of the highest allocated number for all id
# generator groups. # generator groups.
else: else:
method_id = self.sql_catalog_produce_reserved method_id = self.getSqlCatalogProduceReserved()
method = getattr(self, method_id) method = self._getOb(method_id)
# Generate an instance id randomly. Note that there is a small possibility that this # Generate an instance id randomly. Note that there is a small possibility that this
# would conflict with others. # would conflict with others.
random_factor_list = [time.time(), os.getpid(), os.times()] random_factor_list = [time.time(), os.getpid(), os.times()]
...@@ -1467,6 +1494,9 @@ class Catalog(Folder, ...@@ -1467,6 +1494,9 @@ class Catalog(Folder,
check_uid=check_uid, check_uid=check_uid,
idxs=idxs) idxs=idxs)
def getSqlCatalogObjectListList(self):
return self.sql_catalog_object_list
def _catalogObjectList(self, object_list, method_id_list=None, def _catalogObjectList(self, object_list, method_id_list=None,
disable_cache=0, check_uid=1, idxs=None): disable_cache=0, check_uid=1, idxs=None):
"""This is the real method to catalog objects. """This is the real method to catalog objects.
...@@ -1509,7 +1539,10 @@ class Catalog(Folder, ...@@ -1509,7 +1539,10 @@ class Catalog(Folder,
assigned_uid_dict = {} assigned_uid_dict = {}
for object in object_list: for object in object_list:
uid = getattr(aq_base(object), 'uid', None) try:
uid = aq_base(object).uid
except AttributeError:
uid = None
# Generate unique uid for object having 0 or None as uid # Generate unique uid for object having 0 or None as uid
if uid is None or uid == 0: if uid is None or uid == 0:
try: try:
...@@ -1611,7 +1644,7 @@ class Catalog(Folder, ...@@ -1611,7 +1644,7 @@ class Catalog(Folder,
assigned_uid_dict[uid] = object assigned_uid_dict[uid] = object
if method_id_list is None: if method_id_list is None:
method_id_list = self.sql_catalog_object_list method_id_list = self.getSqlCatalogObjectListList()
econtext = getEngine().getContext() econtext = getEngine().getContext()
if disable_cache: if disable_cache:
argument_cache = DummyDict() argument_cache = DummyDict()
...@@ -1730,6 +1763,9 @@ class Catalog(Folder, ...@@ -1730,6 +1763,9 @@ class Catalog(Folder,
def _getCatalogMethod(self, method_name): def _getCatalogMethod(self, method_name):
return getattr(self, method_name) return getattr(self, method_name)
def getSqlCatalogDeleteUid(self):
return self.sql_catalog_delete_uid
security.declarePrivate('beforeUncatalogObject') security.declarePrivate('beforeUncatalogObject')
def beforeUncatalogObject(self, path=None,uid=None): def beforeUncatalogObject(self, path=None,uid=None):
""" """
...@@ -1740,7 +1776,7 @@ class Catalog(Folder, ...@@ -1740,7 +1776,7 @@ class Catalog(Folder,
if uid is None and path is not None: if uid is None and path is not None:
uid = self.getUidForPath(path) uid = self.getUidForPath(path)
method_name = self.sql_catalog_delete_uid method_name = self.getSqlCatalogDeleteUid()
if uid is None: if uid is None:
return None return None
if method_name in (None,''): if method_name in (None,''):
...@@ -1748,9 +1784,12 @@ class Catalog(Folder, ...@@ -1748,9 +1784,12 @@ class Catalog(Folder,
LOG('ZSQLCatalog.beforeUncatalogObject',0,'The sql_catalog_delete_uid'\ LOG('ZSQLCatalog.beforeUncatalogObject',0,'The sql_catalog_delete_uid'\
+ ' method is not defined') + ' method is not defined')
return self.uncatalogObject(path=path,uid=uid) return self.uncatalogObject(path=path,uid=uid)
method = getattr(self, method_name) method = self._getOb(method_name)
method(uid = uid) method(uid = uid)
def getSqlUncatalogObjectList(self):
return self.sql_uncatalog_object
security.declarePrivate('uncatalogObject') security.declarePrivate('uncatalogObject')
def uncatalogObject(self, path=None, uid=None): def uncatalogObject(self, path=None, uid=None):
""" """
...@@ -1770,29 +1809,35 @@ class Catalog(Folder, ...@@ -1770,29 +1809,35 @@ class Catalog(Folder,
if uid is None and path is not None: if uid is None and path is not None:
uid = self.getUidForPath(path) uid = self.getUidForPath(path)
methods = self.sql_uncatalog_object method_id_list = self.getSqlUncatalogObjectList()
if uid is None: if uid is None:
return None return None
for method_name in methods: for method_name in method_id_list:
# Do not put try/except here, it is required to raise error # Do not put try/except here, it is required to raise error
# if uncatalog does not work. # if uncatalog does not work.
method = getattr(self, method_name) method = self._getOb(method_name)
method(uid = uid) method(uid = uid)
def getSqlCatalogTranslationList(self):
return self.sql_catalog_translation_list
security.declarePrivate('catalogTranslationList') security.declarePrivate('catalogTranslationList')
def catalogTranslationList(self, object_list): def catalogTranslationList(self, object_list):
"""Catalog translations. """Catalog translations.
""" """
method_name = self.sql_catalog_translation_list method_name = self.getSqlCatalogTranslationList()
return self.catalogObjectList(object_list, method_id_list = (method_name,), return self.catalogObjectList(object_list, method_id_list = (method_name,),
check_uid=0) check_uid=0)
def getSqlDeleteTranslationList(self):
return self.sql_delete_translation_list
security.declarePrivate('deleteTranslationList') security.declarePrivate('deleteTranslationList')
def deleteTranslationList(self): def deleteTranslationList(self):
"""Delete translations. """Delete translations.
""" """
method_name = self.sql_delete_translation_list method_name = self.getSqlDeleteTranslationList()
method = getattr(self, method_name) method = self._getOb(method_name)
try: try:
method() method()
except ConflictError: except ConflictError:
...@@ -1800,18 +1845,27 @@ class Catalog(Folder, ...@@ -1800,18 +1845,27 @@ class Catalog(Folder,
except: except:
LOG('SQLCatalog', WARNING, 'could not delete translations', error=sys.exc_info()) LOG('SQLCatalog', WARNING, 'could not delete translations', error=sys.exc_info())
def getSqlUniqueValues(self):
return self.sql_unique_values
security.declarePrivate('uniqueValuesFor') security.declarePrivate('uniqueValuesFor')
def uniqueValuesFor(self, name): def uniqueValuesFor(self, name):
""" return unique values for FieldIndex name """ """ return unique values for FieldIndex name """
method = getattr(self, self.sql_unique_values) method = self._getOb(self.getSqlUniqueValues())
return method(column=name) return method(column=name)
def getSqlCatalogPaths(self):
return self.sql_catalog_paths
security.declarePrivate('getPaths') security.declarePrivate('getPaths')
def getPaths(self): def getPaths(self):
""" Returns all object paths stored inside catalog """ """ Returns all object paths stored inside catalog """
method = getattr(self, self.sql_catalog_paths) method = self._getOb(self.getSqlCatalogPaths())
return method() return method()
def getSqlGetitemByPath(self):
return self.sql_getitem_by_path
security.declarePrivate('getUidForPath') security.declarePrivate('getUidForPath')
def getUidForPath(self, path): def getUidForPath(self, path):
""" Looks up into catalog table to convert path into uid """ """ Looks up into catalog table to convert path into uid """
...@@ -1822,9 +1876,8 @@ class Catalog(Folder, ...@@ -1822,9 +1876,8 @@ class Catalog(Folder,
""" Looks up into catalog table to convert path into uid """ """ Looks up into catalog table to convert path into uid """
return { return {
x.path: x.uid x.path: x.uid
for x in getattr( for x in self._getOb(
self, self.getSqlGetitemByPath()
self.sql_getitem_by_path,
)( )(
path=None, path=None,
path_list=path_list, path_list=path_list,
...@@ -1837,9 +1890,8 @@ class Catalog(Folder, ...@@ -1837,9 +1890,8 @@ class Catalog(Folder,
""" Looks up into catalog table to convert uid into path """ """ Looks up into catalog table to convert uid into path """
return { return {
x.uid: x.path x.uid: x.path
for x in getattr( for x in self._getOb(
self, self.getSqlGetitemByUid()
self.sql_getitem_by_uid,
)( )(
uid=None, uid=None,
uid_list=uid_list, uid_list=uid_list,
...@@ -2028,10 +2080,22 @@ class Catalog(Folder, ...@@ -2028,10 +2080,22 @@ class Catalog(Folder,
related_key_definition_cache[key] = result related_key_definition_cache[key] = result
return result return result
def getSqlCatalogKeywordSearchKeysList(self):
return self.sql_catalog_keyword_search_keys
def getSqlCatalogFullTextSearchKeysList(self):
return self.sql_catalog_full_text_search_keys
def getSqlCatalogDatetimeSearchKeysList(self):
return self.sql_catalog_datetime_search_keys
def getSqlCatalogScriptableKeysList(self):
return self.sql_catalog_scriptable_keys
@transactional_cache_decorator('SQLCatalog._getgetScriptableKeyDict') @transactional_cache_decorator('SQLCatalog._getgetScriptableKeyDict')
def _getgetScriptableKeyDict(self): def _getgetScriptableKeyDict(self):
result = {} result = {}
for scriptable_key_definition in self.sql_catalog_scriptable_keys: for scriptable_key_definition in self.getSqlCatalogScriptableKeysList():
split_scriptable_key_definition = scriptable_key_definition.split('|') split_scriptable_key_definition = scriptable_key_definition.split('|')
if len(split_scriptable_key_definition) != 2: if len(split_scriptable_key_definition) != 2:
LOG('SQLCatalog', WARNING, 'Malformed scriptable key definition: %r. Ignored.' % (scriptable_key_definition, )) LOG('SQLCatalog', WARNING, 'Malformed scriptable key definition: %r. Ignored.' % (scriptable_key_definition, ))
...@@ -2501,13 +2565,16 @@ class Catalog(Folder, ...@@ -2501,13 +2565,16 @@ class Catalog(Folder,
kw['order_by_list'] = order_by_list or [] kw['order_by_list'] = order_by_list or []
return kw return kw
def getSqlCatalogSearchKeysList(self):
return self.sql_catalog_search_keys
@transactional_cache_decorator('SQLCatalog._getSearchKeyDict') @transactional_cache_decorator('SQLCatalog._getSearchKeyDict')
def _getSearchKeyDict(self): def _getSearchKeyDict(self):
result = {} result = {}
search_key_column_dict = { search_key_column_dict = {
'KeywordKey': self.sql_catalog_keyword_search_keys, 'KeywordKey': self.getSqlCatalogKeywordSearchKeysList(),
'FullTextKey': self.sql_catalog_full_text_search_keys, 'FullTextKey': self.getSqlCatalogFullTextSearchKeysList(),
'DateTimeKey': self.sql_catalog_datetime_search_keys, 'DateTimeKey': self.getSqlCatalogDatetimeSearchKeysList(),
} }
for key, column_list in search_key_column_dict.iteritems(): for key, column_list in search_key_column_dict.iteritems():
for column in column_list: for column in column_list:
...@@ -2515,7 +2582,7 @@ class Catalog(Folder, ...@@ -2515,7 +2582,7 @@ class Catalog(Folder,
LOG('SQLCatalog', WARNING, 'Ambiguous configuration: column %r is set to use %r key, but also to use %r key. Former takes precedence.' % (column, result[column], key)) LOG('SQLCatalog', WARNING, 'Ambiguous configuration: column %r is set to use %r key, but also to use %r key. Former takes precedence.' % (column, result[column], key))
else: else:
result[column] = key result[column] = key
for line in self.sql_catalog_search_keys: for line in self.getSqlCatalogSearchKeysList():
try: try:
column, key = [x.strip() for x in line.split('|', 2)] column, key = [x.strip() for x in line.split('|', 2)]
result[column] = key result[column] = key
...@@ -2586,9 +2653,12 @@ class Catalog(Folder, ...@@ -2586,9 +2653,12 @@ class Catalog(Folder,
limit_expression=query['limit_expression'], limit_expression=query['limit_expression'],
) )
def getSqlSearchResults(self):
return self.sql_search_results
security.declarePrivate('getSearchResultsMethod') security.declarePrivate('getSearchResultsMethod')
def getSearchResultsMethod(self): def getSearchResultsMethod(self):
return getattr(self, self.sql_search_results) return self._getOb(self.getSqlSearchResults())
security.declarePrivate('searchResults') security.declarePrivate('searchResults')
def searchResults(self, REQUEST=None, **kw): def searchResults(self, REQUEST=None, **kw):
...@@ -2606,9 +2676,12 @@ class Catalog(Folder, ...@@ -2606,9 +2676,12 @@ class Catalog(Folder,
__call__ = searchResults __call__ = searchResults
def getSqlCountResults(self):
return self.sql_count_results
security.declarePrivate('getCountResultsMethod') security.declarePrivate('getCountResultsMethod')
def getCountResultsMethod(self): def getCountResultsMethod(self):
return getattr(self, self.sql_count_results) return self._getOb(self.getSqlCountResults())
security.declarePrivate('countResults') security.declarePrivate('countResults')
def countResults(self, REQUEST=None, **kw): def countResults(self, REQUEST=None, **kw):
...@@ -2625,28 +2698,37 @@ class Catalog(Folder, ...@@ -2625,28 +2698,37 @@ class Catalog(Folder,
def isAdvancedSearchText(self, search_text): def isAdvancedSearchText(self, search_text):
return isAdvancedSearchText(search_text, self.isValidColumn) return isAdvancedSearchText(search_text, self.isValidColumn)
def getSqlRecordObjectList(self):
return self.sql_record_object_list
security.declarePrivate('recordObjectList') security.declarePrivate('recordObjectList')
def recordObjectList(self, path_list, catalog=1): def recordObjectList(self, path_list, catalog=1):
""" """
Record the path of an object being catalogged or uncatalogged. Record the path of an object being catalogged or uncatalogged.
""" """
method = getattr(self, self.sql_record_object_list) method = self._getOb(self.getSqlRecordObjectList())
method(path_list=path_list, catalog=catalog) method(path_list=path_list, catalog=catalog)
def getSqlDeleteRecordedObjectList(self):
return self.sql_delete_recorded_object_list
security.declarePrivate('deleteRecordedObjectList') security.declarePrivate('deleteRecordedObjectList')
def deleteRecordedObjectList(self, uid_list=()): def deleteRecordedObjectList(self, uid_list=()):
""" """
Delete all objects which contain any path. Delete all objects which contain any path.
""" """
method = getattr(self, self.sql_delete_recorded_object_list) method = self._getOb(self.getSqlDeleteRecordedObjectList())
method(uid_list=uid_list) method(uid_list=uid_list)
def getSqlReadRecordedObjectList(self):
return self.sql_read_recorded_object_list
security.declarePrivate('readRecordedObjectList') security.declarePrivate('readRecordedObjectList')
def readRecordedObjectList(self, catalog=1): def readRecordedObjectList(self, catalog=1):
""" """
Read objects. Note that this might not return all objects since ZMySQLDA limits the max rows. Read objects. Note that this might not return all objects since ZMySQLDA limits the max rows.
""" """
method = getattr(self, self.sql_read_recorded_object_list) method = self._getOb(self.getSqlReadRecordedObjectList())
return method(catalog=catalog) return method(catalog=catalog)
# Filtering # Filtering
...@@ -2822,6 +2904,34 @@ class Catalog(Folder, ...@@ -2822,6 +2904,34 @@ class Catalog(Folder,
return filter_dict return filter_dict
return None return None
def getSqlCatalogObjectList(self):
try:
method_id_list = self.sql_catalog_object
except AttributeError:
method_id_list = ()
return method_id_list
def getSqlUncatalogObjectList(self):
try:
method_id_list = self.sql_uncatalog_object
except AttributeError:
method_id_list = ()
return method_id_list
def getSqlUpdateObjectList(self):
try:
method_id_list = self.sql_update_object
except AttributeError:
method_id_list = ()
return method_id_list
def getSqlCatalogObjectListList(self):
try:
method_id_list = self.sql_catalog_object_list
except AttributeError:
method_id_list = ()
return method_id_list
security.declarePrivate('getFilterableMethodList') security.declarePrivate('getFilterableMethodList')
def getFilterableMethodList(self): def getFilterableMethodList(self):
""" """
...@@ -2829,11 +2939,11 @@ class Catalog(Folder, ...@@ -2829,11 +2939,11 @@ class Catalog(Folder,
""" """
method_dict = {} method_dict = {}
if withCMF: if withCMF:
methods = getattr(self,'sql_catalog_object',()) + \ method_id_list = self.getSqlCatalogObjectList() +\
getattr(self,'sql_uncatalog_object',()) + \ self.getSqlUncatalogObjectList() +\
getattr(self,'sql_update_object',()) + \ self.getSqlUpdateObjectList() +\
getattr(self,'sql_catalog_object_list',()) self.getSqlCatalogObjectListList()
for method_id in methods: for method_id in method_id_list:
method_dict[method_id] = 1 method_dict[method_id] = 1
method_list = map(lambda method_id: getattr(self, method_id, None), method_dict.keys()) method_list = map(lambda method_id: getattr(self, method_id, None), method_dict.keys())
return filter(lambda method: method is not None, method_list) return filter(lambda method: method is not None, method_list)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment