2009-11-26 13:54:00 +00:00
|
|
|
# -*- encoding: utf-8 -*-
|
|
|
|
|
|
|
|
#
|
|
|
|
# Copyright P. Christeas <p_christ@hol.gr> 2008,2009
|
|
|
|
#
|
|
|
|
#
|
|
|
|
# WARNING: This program as such is intended to be used by professional
|
|
|
|
# programmers who take the whole responsability of assessing all potential
|
|
|
|
# consequences resulting from its eventual inadequacies and bugs
|
|
|
|
# End users who are looking for a ready-to-use solution with commercial
|
|
|
|
# garantees and support are strongly adviced to contract a Free Software
|
|
|
|
# Service Company
|
|
|
|
#
|
|
|
|
# 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.
|
|
|
|
###############################################################################
|
|
|
|
|
|
|
|
|
|
|
|
import netsvc
|
2010-04-06 11:11:32 +00:00
|
|
|
import tools
|
2010-04-12 10:52:00 +00:00
|
|
|
from dav_fs import openerp_dav_handler
|
2009-11-26 13:54:00 +00:00
|
|
|
from tools.config import config
|
|
|
|
from DAV.WebDAVServer import DAVRequestHandler
|
|
|
|
from service.websrv_lib import HTTPDir,FixSendError
|
2010-04-06 11:11:32 +00:00
|
|
|
|
|
|
|
|
|
|
|
def OpenDAVConfig(**kw):
|
|
|
|
class OpenDAV:
|
|
|
|
def __init__(self, **kw):
|
|
|
|
self.__dict__.update(**kw)
|
|
|
|
|
|
|
|
class Config:
|
|
|
|
DAV = OpenDAV(**kw)
|
|
|
|
|
|
|
|
return Config()
|
2009-11-26 13:54:00 +00:00
|
|
|
|
2010-04-12 10:52:00 +00:00
|
|
|
|
2009-11-26 13:54:00 +00:00
|
|
|
class DAVHandler(FixSendError,DAVRequestHandler):
|
|
|
|
verbose = False
|
2009-12-15 14:31:05 +00:00
|
|
|
|
2009-11-26 13:54:00 +00:00
|
|
|
def get_userinfo(self,user,pw):
|
2009-12-15 14:31:05 +00:00
|
|
|
print "get_userinfo"
|
|
|
|
return False
|
2009-11-26 13:54:00 +00:00
|
|
|
def _log(self, message):
|
2009-12-15 14:31:05 +00:00
|
|
|
netsvc.Logger().notifyChannel("webdav",netsvc.LOG_DEBUG,message)
|
|
|
|
|
2009-11-26 13:54:00 +00:00
|
|
|
def handle(self):
|
2010-04-06 11:11:32 +00:00
|
|
|
self._init_buffer()
|
2009-11-26 13:54:00 +00:00
|
|
|
|
|
|
|
def finish(self):
|
|
|
|
pass
|
|
|
|
|
2010-04-06 11:11:32 +00:00
|
|
|
def get_db_from_path(self, uri):
|
|
|
|
if uri or uri == '/':
|
|
|
|
dbs = self.IFACE_CLASS.db_list()
|
|
|
|
res = len(dbs) and dbs[0] or False
|
|
|
|
else:
|
|
|
|
res = self.IFACE_CLASS.get_db(uri)
|
|
|
|
return res
|
|
|
|
|
2009-11-26 13:54:00 +00:00
|
|
|
def setup(self):
|
2010-04-06 11:11:32 +00:00
|
|
|
davpath = '/'+config.get_misc('webdav','vdir','webdav')
|
|
|
|
self.baseuri = "http://%s:%d/"% (self.server.server_name,self.server.server_port)
|
2010-04-12 10:52:00 +00:00
|
|
|
self.IFACE_CLASS = openerp_dav_handler(self, self.verbose)
|
2010-04-06 11:11:32 +00:00
|
|
|
|
2009-12-15 14:31:05 +00:00
|
|
|
|
2009-11-26 13:54:00 +00:00
|
|
|
def log_message(self, format, *args):
|
2009-12-15 14:31:05 +00:00
|
|
|
netsvc.Logger().notifyChannel('webdav',netsvc.LOG_DEBUG_RPC,format % args)
|
2009-11-26 13:54:00 +00:00
|
|
|
|
|
|
|
def log_error(self, format, *args):
|
2009-12-15 14:31:05 +00:00
|
|
|
netsvc.Logger().notifyChannel('xmlrpc',netsvc.LOG_WARNING,format % args)
|
2009-11-26 13:54:00 +00:00
|
|
|
|
|
|
|
|
|
|
|
try:
|
2010-04-06 11:11:32 +00:00
|
|
|
from service.http_server import reg_http_service,OpenERPAuthProvider
|
|
|
|
|
2009-12-29 09:36:55 +00:00
|
|
|
if (config.get_misc('webdav','enable',True)):
|
2010-04-06 11:11:32 +00:00
|
|
|
directory = '/'+config.get_misc('webdav','vdir','webdav')
|
2009-12-15 14:31:05 +00:00
|
|
|
handler = DAVHandler
|
2010-04-06 11:11:32 +00:00
|
|
|
verbose = config.get_misc('webdav','verbose',True)
|
2009-12-15 14:31:05 +00:00
|
|
|
handler.debug = config.get_misc('webdav','debug',True)
|
2010-04-06 11:11:32 +00:00
|
|
|
_dc = { 'verbose' : verbose,
|
|
|
|
'directory' : directory,
|
|
|
|
'lockemulation' : False,
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
conf = OpenDAVConfig(**_dc)
|
|
|
|
handler._config = conf
|
|
|
|
reg_http_service(HTTPDir(directory,DAVHandler,OpenERPAuthProvider()))
|
|
|
|
netsvc.Logger().notifyChannel('webdav',netsvc.LOG_INFO,"WebDAV service registered at path: %s/ "% directory)
|
2009-11-26 13:54:00 +00:00
|
|
|
except Exception, e:
|
2009-12-15 14:31:05 +00:00
|
|
|
logger = netsvc.Logger()
|
|
|
|
logger.notifyChannel('webdav', netsvc.LOG_ERROR, 'Cannot launch webdav: %s' % e)
|
2009-11-26 13:54:00 +00:00
|
|
|
|
|
|
|
#eof
|
|
|
|
|
|
|
|
|
|
|
|
|