cybertools/agent/transport/remote.py
scrat 5a48213560 intermediate check-in. moved rpcserver.py to testing, but yet only a part of the requested changes have been made there.
rpcclient functionality has been integrated into /transport/remote.py
The transporter class is now using its own config-file (as a first idea).

git-svn-id: svn://svn.cy55.de/Zope3/src/cybertools/trunk@2717 fd906abe-77d9-0310-91a1-e0d9ade77398
2008-06-20 22:18:35 +00:00

98 lines
No EOL
3.2 KiB
Python

#
# Copyright (c) 2008 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
#
"""
Transferring information to or requesting information from a remote
cybertools.agent instance by transferring files to the remote system
and sending requests to a corresponding remote controller.
$Id$
"""
from zope.interface import implements
from twisted.web import xmlrpc
from cybertools.agent.core.agent import QueueableAgent
from cybertools.agent.interfaces import ITransporter
from cybertools.agent.crawl.base import Metadata
from cybertools.agent.crawl.mail import MailResource
from cybertools.agent.crawl.filesystem import FileResource
from cybertools.agent.components import agents
from cybertools.util.config import Configurator
class Transporter(QueueableAgent):
implements(ITransporter)
serverURL = ''
server = ''
method = ''
machineName = ''
userName = ''
password = ''
resource = None
def __init__(self, master, configuration):
super(Transporter, self).__init__(master)
if isinstance(configuration, Configurator):
self.config = configuration
else: # configuration is path to config file
self.config = Configurator()
self.config.load(configuration)
self.serverURL = self.config.xmlrpcClient.serverURL
self.server = xmlrpc.Proxy(self.serverURL)
self.method = self.config.xmlrpcClient.method
self.machineName = self.config.xmlrpcClient.machineName
self.userName = self.config.xmlrpcClient.userName
self.password = self.config.xmlrpcClient.password
def transfer(self, resource):
""" Transfer the resource (an object providing IResource)
to the server and return a Deferred.
"""
deferred = self.server.callRemote('getMetadata', resource.metadata)
deferred.addCallback(self.transferDone)
deferred.addErrback(self.errorHandler)
def errorHandler(self, errorInfo):
"""
Invoked as a callback from self.transfer
Error handler.
"""
print errorInfo
self.server.close()
def transferDone(self, successMessage=''):
"""
Invoked as a callback from self.transfer
This callback method is called when resource and metadata
have been transferred successfully.
"""
pass
# def process(self):
# return self.collect()
# def collect(self, filter=None):
# d = defer.succeed([])
# return d
agents.register(Transporter, Master, name='transport.remote')