[Zope-Checkins] SVN: Zope/trunk/ - extended warning time for
removal of old-style product metadata support
Yvo Schubbe
y.2005- at wcm-solutions.de
Fri Nov 4 04:33:23 EST 2005
Log message for revision 39883:
- extended warning time for removal of old-style product metadata support
Changed:
U Zope/trunk/doc/CHANGES.txt
U Zope/trunk/lib/python/OFS/Application.py
-=-
Modified: Zope/trunk/doc/CHANGES.txt
===================================================================
--- Zope/trunk/doc/CHANGES.txt 2005-11-04 09:33:10 UTC (rev 39882)
+++ Zope/trunk/doc/CHANGES.txt 2005-11-04 09:33:23 UTC (rev 39883)
@@ -75,9 +75,6 @@
Other
- - OFS Application: Removed support for long deprecated old-style product
- metadata in the __init__.py of products.
-
- ZSQLMethod.manage_main: Moved the error message that warns of a
non-existing or closed database connection next to the Connection ID
dropdown and present it using red to increase its visibility.
Modified: Zope/trunk/lib/python/OFS/Application.py
===================================================================
--- Zope/trunk/lib/python/OFS/Application.py 2005-11-04 09:33:10 UTC (rev 39882)
+++ Zope/trunk/lib/python/OFS/Application.py 2005-11-04 09:33:23 UTC (rev 39883)
@@ -18,6 +18,7 @@
import os, sys, traceback
from cgi import escape
from StringIO import StringIO
+from warnings import warn
import Globals, Products, App.Product, App.ProductRegistry
import transaction
@@ -781,11 +782,80 @@
product, product_name, package_dir, app)
context=ProductContext(productObject, app, product)
- # Look for an 'initialize' method in the product.
+ # Look for an 'initialize' method in the product. If it does
+ # not exist, then this is an old product that has never been
+ # updated. In that case, we will analyze the product and
+ # build up enough information to do initialization manually.
initmethod=pgetattr(product, 'initialize', None)
if initmethod is not None:
initmethod(context)
+ # Support old-style product metadata. Older products may
+ # define attributes to name their permissions, meta_types,
+ # constructors, etc.
+ permissions={}
+ new_permissions={}
+ if pgetattr(product, '__ac_permissions__', None) is not None:
+ warn('__init__.py of %s has a long deprecated '
+ '\'__ac_permissions__\' attribute. '
+ '\'__ac_permissions__\' will be ignored by '
+ 'install_product in Zope 2.10. Please use registerClass '
+ 'instead.' % product.__name__,
+ DeprecationWarning)
+ for p in pgetattr(product, '__ac_permissions__', ()):
+ permission, names, default = (
+ tuple(p)+('Manager',))[:3]
+ if names:
+ for name in names:
+ permissions[name]=permission
+ elif not folder_permissions.has_key(permission):
+ new_permissions[permission]=()
+
+ if pgetattr(product, 'meta_types', None) is not None:
+ warn('__init__.py of %s has a long deprecated \'meta_types\' '
+ 'attribute. \'meta_types\' will be ignored by '
+ 'install_product in Zope 2.10. Please use registerClass '
+ 'instead.' % product.__name__,
+ DeprecationWarning)
+ for meta_type in pgetattr(product, 'meta_types', ()):
+ # Modern product initialization via a ProductContext
+ # adds 'product' and 'permission' keys to the meta_type
+ # mapping. We have to add these here for old products.
+ pname=permissions.get(meta_type['action'], None)
+ if pname is not None:
+ meta_type['permission']=pname
+ meta_type['product']=productObject.id
+ meta_type['visibility'] = 'Global'
+ meta_types.append(meta_type)
+
+ if pgetattr(product, 'methods', None) is not None:
+ warn('__init__.py of %s has a long deprecated \'methods\' '
+ 'attribute. \'methods\' will be ignored by '
+ 'install_product in Zope 2.10. Please use registerClass '
+ 'instead.' % product.__name__,
+ DeprecationWarning)
+ for name,method in pgetattr(
+ product, 'methods', {}).items():
+ if not hasattr(Folder.Folder, name):
+ setattr(Folder.Folder, name, method)
+ if name[-9:]!='__roles__': # not Just setting roles
+ if (permissions.has_key(name) and
+ not folder_permissions.has_key(
+ permissions[name])):
+ permission=permissions[name]
+ if new_permissions.has_key(permission):
+ new_permissions[permission].append(name)
+ else:
+ new_permissions[permission]=[name]
+
+ if new_permissions:
+ new_permissions=new_permissions.items()
+ for permission, names in new_permissions:
+ folder_permissions[permission]=names
+ new_permissions.sort()
+ Folder.Folder.__ac_permissions__=tuple(
+ list(Folder.Folder.__ac_permissions__)+new_permissions)
+
if not doInstall():
transaction().abort()
else:
More information about the Zope-Checkins
mailing list