cybertools/organize/interfaces.py
helmutm 821b922f6a provide basic information for RegistrationTemplate
git-svn-id: svn://svn.cy55.de/Zope3/src/cybertools/trunk@1856 fd906abe-77d9-0310-91a1-e0d9ade77398
2007-08-01 08:33:17 +00:00

223 lines
7.2 KiB
Python

#
# Copyright (c) 2007 Helmut Merz helmutm@cy55.de
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
#
"""
Interfaces for organizational stuff like persons, addresses, tasks, services...
$Id$
"""
from zope.interface import Interface, Attribute
from zope import schema
from zope.i18nmessageid import MessageFactory
_ = MessageFactory('zope')
# schema fields
class SimpleList(schema.List): pass
class LinesList(schema.List): pass
# persons, addresses, ...
class IPerson(Interface):
""" Resembles a human being with a name (first and last name),
a birth date, and a set of addresses.
"""
firstName = schema.TextLine(
title=_(u'First name'),
description=_(u'The first name'),
required=False,)
lastName = schema.TextLine(
title=_(u'Last name'),
description=_(u'The last name or surname'),)
email = schema.TextLine(
title=_(u'E-Mail address'),
description=_(u'The standard email address of the person'),)
phoneNumbers = SimpleList(
value_type=schema.TextLine(),
default=[],
title=_(u'Phone numbers'),
description=_(u'Note one or more phone numbers here'),
required=False,)
birthDate = schema.Date(
title=_(u'Date of birth'),
description=_(u'The date of birth - should be a '
'datetime.date object'),
required=False,)
age = schema.Int(
title=_(u'Age'),
description=_(u'The current age in full years'),
readonly=True)
addresses = Attribute('A mapping whose values provide the IAddress '
'interface')
class IAddress(Interface):
""" A postal address of a person or institution.
"""
street = schema.TextLine(
title=_(u'Street, number'),
description=_(u'Street and number'),
required=False,)
zipcode = schema.TextLine(
title=_(u'ZIP code'),
description=_(u'ZIP code, postal code'),
required=False,)
city = schema.TextLine(
title=_(u'City'),
description=_(u'Name of the city'),
required=True,)
country = schema.TextLine(
title=_(u'Country code'),
description=_(u'International two-letter country code'),
required=False,)
lines = LinesList(
value_type=schema.TextLine(),
default=[],
title=_(u'Additional lines'),
description=_(u'Additional address lines'),
required=False,)
# tasks
class ITask(Interface):
""" A task has a start date, an optional end date, and is usually
assigned to one or more persons.
"""
start = schema.Date(
title=_(u'Start date'),
description=_(u'The date when the task should start'),
required=False,)
end = schema.Date(
title=_(u'End date'),
description=_(u'The date until that the task should be '
'finished'),
required=False,)
# services
class IServiceManager(Interface):
""" A manager or container for a set of services.
"""
services = Attribute('A collection of services managed by this object.')
class IServiceGroup(Interface):
""" A group of related services or a general service definition,
e.g. a regular bus service or a series of trainings.
"""
services = Attribute('A collection of services belonging to this object.')
class IService(Interface):
""" A service that clients may register with.
"""
serviceGroup = Attribute('The service group this object is an instance of.')
capacity = schema.Int(
title=_(u'Capacity'),
description=_(u'The capacity (maximum number of clients) '
'of this service; a negative number means: '
'no restriction, i.e. unlimited capacity.'),
required=False,)
availableCapacity = Attribute('Available capacity, i.e. number of seats '
'still available; a negative number means: '
'no restriction, i.e. unlimited capacity; '
'read-only')
serviceProviders = Attribute('A collection of one or more service providers.')
resources = Attribute('A collection of one or more resources.')
registrations = Attribute('A collection of client registrations.')
def register(client):
""" Register a client with this service. Return an IRegistration
object if the registration is successful, otherwise
(e.g. if the service's capacity is exhausted) return None.
"""
class IScheduledService(IService):
""" A service that starts at a certain date/time and
usually ends a certain time later.
"""
start = schema.Date(
title=_(u'Start date/time'),
description=_(u'The date/time when the service starts'),
required=False,)
end = schema.Date(
title=_(u'End date/time'),
description=_(u'The date/time when the service ends'),
required=False,)
duration = Attribute('Time delta between start and end date/time.')
class IClient(Interface):
""" An fairly abstract interface for objects to be used as clients
for services.
"""
manager = Attribute('The object that cares for this client.')
class IClientFactory(Interface):
""" Creates client objects.
"""
def __call__(data):
""" Creates and returns a client object built from the
data set provided.
"""
class IRegistration(Interface):
""" Information about the registration of a client with a service.
"""
client = Attribute('The client registered')
class IRegistrationTemplate(Interface):
""" Provides and processes data for a service registration form.
"""
class IResource(Interface):
""" A resource is needed by a service to be able to work, e.g. a
room or a bus. A resource may have a limited capacity so that
at a certain time it may only be used by services to a certain
extent.
"""
class IServiceProvider(Interface):
""" A party, that is responsible for providing a service.
"""