[Zope3-Users] Design question (object or interface for category implementation?)

Christophe Combelles ccomb at free.fr
Fri Mar 9 09:55:21 EST 2007


Garanin Michael a écrit :
> Christophe Combelles wrote:
>> Christophe Combelles a écrit :
>>> Hi,
>>>
>>> I'm playing again with the notion of categories of objects.
>>>
>>> I have two main goals:
>>> ---------------------
>>> 1) I must let the user choose the category of an object added to the 
>>> zodb. For this, I must be able to retrieve the list of categories and 
>>> present them in a form field managed by a vocabulary (or in a 
>>> different manner).
>>> 2) I must have different behaviours for categorized objects:
>>> objects of different categories would have different views, different 
>>> addMenuItems (if they are containers), etc.
>>>
>>> the first requirement would tell me to define categories as objects, 
>>> while the second one would tell me to define them as interfaces.
>>>
>>> The possible solutions I see:
>>> ----------------------------
>>>
>>> 1) The simplest solution is to store the categories as text strings 
>>> into the annotations of the object. So categories actually are just 
>>> tags.
>>>
>>> 2) The second solution is to do the same, but replace text strings 
>>> with category objects, that implement ICategory. And categories can 
>>> be stored separately in a category container, or in a registered 
>>> utility that gives the list of available categories. This is a bit 
>>> better, but this way I don't know how to easily let my categorized 
>>> objects behave differently according to their categories.
>>>
>>> 3) The third solution is to define categories as interfaces extending 
>>> ICategory. I can retrieve the list of categories with 
>>> ICategory.dependents
>>> But to present them in a form, I must have a pretty name for each 
>>> interface. Should I store them in a Tagged Value?
>>>
>>> 4) The fourth solution I see, is to define an interface type, 
>>> ICategoryType, extending IInterface just like IContentType. Then my 
>>> categories would be interfaces whose type is ICategoryType. But with 
>>> IContentType, is there a way to retrieve the list of all available 
>>> content types?
>>
>> I've finally mixed 3) and 4) :
>>
>> I have defined ICompany(Interface), IClient(ICompany), 
>> IProvider(ICompany)
>> And I have an ICompanyType(IInterface) interface type
>> I've set the type of IClient and IProvider as ICompanyType in zcml.
>>
>> ICompany has a "types" attribute, for which I've redefined __getattr__ 
>> and __setattr_:
>> __getattr__ retrieve the ICompanyType interfaces from the object
>> __setattr__ calls noLongerProvides then alsoProvides to change the 
>> interfaces.
> I think that it's not work: "alsoProvides" and "directlyProvides" change 
> interfaces only in memory, it's not persistent changes (after restart 
> Zope yours object will be only basic interface) .
> (sorry my honor english).

You've just frightened me, but I've just tried and it just work.
Interfaces are kept between server restart.








More information about the Zope3-users mailing list