loops/agent/interfaces.py
helmutm d564ff0de1 provide first simple logging implementation
git-svn-id: svn://svn.cy55.de/Zope3/src/loops/trunk@1935 fd906abe-77d9-0310-91a1-e0d9ade77398
2007-08-19 14:44:05 +00:00

264 lines
8.6 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
#
"""
loops client agent interfaces.
$Id$
"""
from zope.interface import Interface, Attribute
class IAgent(Interface):
""" An agent watches its client, looks for resources to process,
and transfers these to its server.
"""
scheduler = Attribute('IScheduler instance.')
transporter = Attribute('The transporter to be used for transferring '
'objects.')
class IScheduler(Interface):
""" Manages jobs and cares that they are started at the appropriate
time.
"""
logger = Attribute('Logger instance to be used for recording '
'job execution and execution results.')
def schedule(job, startTime=None):
""" Register the job given for execution at the intended start
date/time (an integer timestamp) and return the job.
If the start time is not given schedulethe job for immediate
start. Return the start time with which the job has been
scheduled - this may be different from the start time
supplied.
"""
def getJobsToExecute(startTime=None):
""" Return a collection of jobs that are scheduled for execution at
or before the date/time given.
If startTime is None the current date/time is used.
"""
class IScheduledJob(Interface):
""" A job that will be executed on some external triggering at
a predefined date and time.
"""
startTime = Attribute('Date/time at which the job should be executed.')
params = Attribute('Mapping with key/value pairs to be used by '
'the ``execute()`` method.')
repeat = Attribute('Number of seconds after which the job should be '
'rescheduled. Do not repeat if 0.')
successors = Attribute('Jobs to execute immediately after this '
'one has been finished.')
whenStarted = Attribute('A callable with one argument (the job) that will '
'be called when the job has started.')
whenfinished = Attribute('A callable with two arguments, the job and the '
'result of running the job, that will be called when '
'the job has finished.')
def execute():
""" Execute the job.
Store log information about job execution in a log record.
"""
def reschedule(startTime):
""" Re-schedule the job, setting the date/time the job should be
executed again.
"""
class ILogger(Interface):
""" Ordered collection (list) of log records.
"""
externalLoggers = Attribute('A collection of logger objects '
'to which the logging records should be written.')
def setup():
""" Initialize the logger with the current configuration settings.
"""
def log(data):
""" Record the information given by the ``data`` argument
(a mapping).
"""
class ILogRecord(Interface):
"""
"""
def __str__():
""" Return a string representation suitable for writing on a
log file.
"""
class ICrawlingJob(IScheduledJob):
""" Collects resources.
"""
predefinedMetadata = Attribute('A mapping with metadata to be used '
'for all resources found.')
def collect():
""" Return a deferred that upon callback will provide a
collection of resource objects that should be transferred
to the server.
Use the selection criteria given to filter the resources that
should be collected.
"""
class IResource(Interface):
""" Represents a data object that is collected by a crawler and
will be transferred to the server.
"""
data = Attribute("A string, file, or similar representation of the "
"resource's content")
path = Attribute('A filesystem path or some other information '
'uniquely identifying the resource on the client '
'machine for the current user.')
application = Attribute('The name of the application that provided '
'the resource, e.g. "filesystem" or "mail".')
metadata = Attribute('Information describing this resource; '
'should be an IMetadataSet object.')
class IMetadataSet(Interface):
""" Metadata associated with a resource; a mapping.
"""
def asXML():
""" Return an XML string representing the metadata set.
If this metadata set contains other metadata sets
(nested metadata) this will be converted to XML as well.
"""
def set(key, value):
""" Set a metadata element.
The value may be a string or another metadata set
(nested metadata).
"""
class ITransporter(Interface):
""" Transfers collected resources to the server.
"""
serverURL = Attribute('URL of the server the resources will be '
'transferred to. The URL also determines the '
'transfer protocol, e.g. HTTP or FTP.')
method = Attribute('Transport method, e.g. PUT.')
machineName = Attribute('Name under which the local machine is '
'known to the server.')
userName = Attribute('User name for logging in to the server.')
password = Attribute('Password for logging in to the server.')
def createJob():
""" Return a transport job for this transporter.
"""
def transfer(resource):
""" Transfer the resource (an object providing IResource)
to the server and return a Deferred.
"""
class ITransportJob(IScheduledJob):
""" A job managing the the transfer of a resource to the server.
"""
transporter = Attribute('The transporter object to use for transer.')
class IConfigurator(Interface):
""" Manages (stores and receives) configuration information.
"""
filename = Attribute('The path to a file with configuration parameters.')
def load(p=None, filename=None):
""" Load configuration directly from a string or an open file
(if ``p`` is set) or using the ``filename`` parameter (a path).
If no string and no filename is given the configuration
file is searched in the user's home folder.
If the configuration is loaded from a file using the
``filename`` parameter or from the default location the
path is stored in the ``filename`` attribute.
"""
def save(filename=None):
""" Save configuration settings to the file given, or to the
file from which it was loaded, or to the default location.
"""
# future extensions
class IPackageManager(Interface):
""" Allows to install, update, or remove software packages (plugins,
typically as Python eggs) from a server.
"""
sources = Attribute('A list of URLs that provide software packages. ')
def getInstalledPackages():
""" Return a list of dictionaries, format:
[{'name': name, 'version': version,
'date': date_time_of_installation,}, ...]
"""
def getUpdateCandidates():
""" Return a list of dictionaries with information about updateable
packages.
"""
def installPackage(name, version=None, source=None):
""" Install a package.
If version is not given try to get the most recent one.
If source is not given search the sources attribute for the
first fit.
"""
def updatePackage(name, version=None, source=None):
""" Update a package.
If version is not given try to get the most recent one.
If source is not given search the sources attribute for the
first fit.
"""
def removePackage(name):
""" Remove a package from this agent.
"""