Source code for grokcore.site.util
##############################################################################
#
# Copyright (c) 2006-2009 Zope Foundation and Contributors.
# All Rights Reserved.
#
# This software is subject to the provisions of the Zope Public License,
# Version 2.1 (ZPL). A copy of the ZPL should accompany this distribution.
# THIS SOFTWARE IS PROVIDED "AS IS" AND ANY AND ALL EXPRESS OR IMPLIED
# WARRANTIES ARE DISCLAIMED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
# WARRANTIES OF TITLE, MERCHANTABILITY, AGAINST INFRINGEMENT, AND FITNESS
# FOR A PARTICULAR PURPOSE.
#
##############################################################################
from zope.component.hooks import getSite
from zope.component.hooks import setSite
from zope.event import notify
from zope.lifecycleevent import ObjectCreatedEvent
from zope.schema.interfaces import WrongType
from grokcore.site.interfaces import ApplicationAddedEvent
from grokcore.site.interfaces import IApplication
[docs]
def getApplication():
"""Return the nearest enclosing :class:`grokcore.site.Application`.
Raises :exc:`ValueError` if no application can be found.
"""
site = getSite()
if IApplication.providedBy(site):
return site
# Another sub-site is within the application. Walk up the object
# tree until we get to the an application.
obj = site
while obj is not None:
if IApplication.providedBy(obj):
return obj
obj = obj.__parent__
raise ValueError("No application found.")
[docs]
def create_application(factory, container, name):
"""Creates an application and triggers the events from
the application lifecycle.
"""
# Check the factory.
if not IApplication.implementedBy(factory):
raise WrongType(factory)
# Check the availability of the name in the container.
if name in container:
raise KeyError(name)
# Instanciate the application
application = factory()
# Trigger the creation event.
notify(ObjectCreatedEvent(application))
# Persist the application.
# This may raise a KeyError.
container[name] = application
# Trigger the initialization event with the new application as a
# current site.
current = getSite()
setSite(application)
try:
notify(ApplicationAddedEvent(application))
finally:
setSite(current)
return application