-def setupVarious(context):
+from Products.CMFCore.utils import getToolByName
+from Acquisition import aq_base
+from zope import event
+from Products.Archetypes.event import ObjectInitializedEvent
+from plone.app.controlpanel.security import SecurityControlPanelAdapter
- # Ordinarily, GenericSetup handlers check for the existence of XML files.
- # Here, we are not parsing an XML file, but we use this text file as a
- # flag to check that we actually meant for this import step to be run.
- # The file is found in profiles/default.
+INSTALL_PRODUCTS = [
+ 'easyshop.core',
+ 'koehsel.theme',
+]
- if context.readDataFile('koehsel.theme_various.txt') is None:
+SITE_OWNER = 'admin'
+
+def makeObject(container, type_name, id, **kw):
+ """Create an object in CONTAINER with type TYPE_NAME and id ID. Additional keyword args
+specify additional factory arguments. After creation, the object is published if needed."""
+ id = container.invokeFactory(id=id, type_name=type_name, **kw)
+ ob = getattr(container,id)
+ event.notify(ObjectInitializedEvent(ob))
+ if hasattr(aq_base(ob), 'at_post_create_script'):
+ ob.at_post_create_script()
+ if hasattr(aq_base(ob), 'manage_afterPortalFactoryCreate'):
+ ob.manage_afterPortalFactoryCreate()
+ return ob
+
+
+def siteSetup(context):
+
+ if context.readDataFile('koehsel.policy_setup.txt') is None:
return
- # Add additional setup code here
+ site = context.getSite()
+ qi = getToolByName(site, 'portal_quickinstaller')
+
+ # Install EasyShop product
+
+ for p in INSTALL_PRODUCTS:
+ if not qi.isProductInstalled(p):
+ qi.installProduct(p)
+
+ # Enable Self-Registration
+
+ scpa = SecurityControlPanelAdapter(site)
+ scpa.set_enable_self_reg(True)
+
+ # If not already installed, initialize development content
+
+ try: site.shop
+ except AttributeError:
+ siteSetupContent(site)
+
+
+def siteSetupContent(site):
+
+ wf = getToolByName(site, 'portal_workflow')
+
+ # Change front-page stuff
+
+ fp = getattr(site,'front-page')
+ fp.setTitle("Startsteite")
+ fp.setDescription("")
+ fp.setText("")
+ fp.setPresentation(False)
+ fp.reindexObject()
+
+ # Create easy-shop instance
+
+ shop = makeObject(container=site, type_name='EasyShop', id='shop',
+ title='Shop', shopOwner='admin')
+
+ if wf.getInfoFor(shop,'review_state','') != 'published':
+ wf.doActionFor(shop,'publish',comment='site setup')
+
+ # Hide Users, News and Events
+
+ for id in ('Members', 'news', 'events'):
+ ob = getattr(site,id)
+ if wf.getInfoFor(ob,'review_state','') != 'private':
+ wf.doActionFor(ob,'retract',comment='site setup')
+
+ # Add sample user
+
+ mt = getToolByName(site,'portal_membership')
+ mt.addMember('shop','shop',[],[])
+ member = mt.getMemberById('shop')
+ member.setMemberProperties({'fullname': 'Shop Testuser'})
+
+
+def contentSetup(app):
+ app.manage_addProduct['CMFPlone'].addPloneSite(id='site',
+ extension_ids=['koehsel.policy:default'])
+
+
+# Called via hackery in __init__.py on every site start
+def appInit(app):
+ try: app.site
+ except AttributeError:
+
+ from Testing.makerequest import makerequest
+ from AccessControl.SecurityManagement import newSecurityManager
+ import transaction, AccessControl
+
+ # Call 'contentSetup' as SITE_OWNER user with a valid REQUEST
+ req = makerequest(app)
+ newSecurityManager(req.REQUEST, app.acl_users.getUserById(SITE_OWNER).__of__(app.acl_users))
+ contentSetup(req)
+ transaction.commit()
+ newSecurityManager(None, AccessControl.User.system)