Central Components¶
Creating University instances¶
As University
instances make use of the Zope Component
Architecture (ZCA), we have to setup the basic component registries,
before we can create instances. We do this by simply grokking the
whole waeup
package. This way all interfaces, utilities and adapters
defined in the package are looked up and registered with the global
registries (this is done by the testlayer automatically).
Now we can import the University
class and create an
instance:
>>> from waeup.kofa.app import University
>>> myuniversity = University()
>>> myuniversity
<waeup.kofa.app.University object at 0x...>
Instances of University comply with the interface waeup.kofa.interfaces.IUniversity:
>>> from zope.interface.verify import verifyClass
>>> from waeup.kofa.interfaces import IUniversity
>>> verifyClass(IUniversity, University)
True
A freshly created instance provides the attributes promised by the interface:
>>> from waeup.kofa.app import University
>>> myuniversity = University()
>>> myuniversity['configuration'].name
u'Sample University'
>>> myuniversity['faculties']
<waeup.kofa.university.facultiescontainer.FacultiesContainer object at 0x...>
>>> myuniversity['students']
<waeup.kofa.students.container.StudentsContainer object at 0x...>
>>> myuniversity['users']
<waeup.kofa.userscontainer.UsersContainer object at 0x...>
>>> myuniversity['datacenter']
<waeup.kofa.datacenter.DataCenter object at 0x...>
>>> myuniversity['configuration']
<waeup.kofa.configuration.ConfigurationContainer object at 0x...>
Kofa plugins¶
waeup.kofa provides an API to ‘plugin’ components. Things that should be setup at creation time of a Kofa application can indicate that by providing a utility providing IKofaPlugin.
The plugins are looked up by an created app, which then will call the
setup()
method of each plugin.
>>> from waeup.kofa.interfaces import IKofaPluggable
>>> from zope.component import getAdapters, getUtilitiesFor
>>> sorted(list(getUtilitiesFor(IKofaPluggable)))
[(u'academics', <waeup.kofa.university.facultiescontainer.AcademicsPlugin ...)]
We can provide a new plugin like this:
>>> import grok
>>> from waeup.kofa.interfaces import IKofaPluggable
>>> class MyPlugin(grok.GlobalUtility):
... grok.implements(IKofaPluggable)
... def setup(self, site, name, logger):
... print "Setup was called for"
... print site
... def update(self, site, name, logger):
... pass
When we register the plugin
>>> grok.testing.grok_component('MyPlugin', MyPlugin)
True
and setup a new Kofa instance, we will get a message:
>>> from waeup.kofa.app import University
>>> site = University()
Setup was called for
<waeup.kofa.app.University object at 0x...>
Apparently the plugin can do with the University object whatever it likes. That’s what plugins are for.