moved test data to testing data; work in progress: BSCW interface
git-svn-id: svn://svn.cy55.de/Zope3/src/cybertools/trunk@2591 fd906abe-77d9-0310-91a1-e0d9ade77398
This commit is contained in:
parent
62330d395f
commit
d1f8a17e63
7 changed files with 139 additions and 1 deletions
135
integrator/bscw.py
Normal file
135
integrator/bscw.py
Normal file
|
@ -0,0 +1,135 @@
|
||||||
|
#
|
||||||
|
# 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
|
||||||
|
#
|
||||||
|
|
||||||
|
"""
|
||||||
|
Access to objects in a BSCW repository.
|
||||||
|
|
||||||
|
$Id$
|
||||||
|
"""
|
||||||
|
|
||||||
|
import os
|
||||||
|
from xmlrpclib import ServerProxy
|
||||||
|
from zope import component
|
||||||
|
from zope.app.file.image import getImageInfo
|
||||||
|
from zope.cachedescriptors.property import Lazy
|
||||||
|
from zope.contenttype import guess_content_type
|
||||||
|
from zope.interface import implements, Attribute
|
||||||
|
|
||||||
|
from cybertools.integrator.base import ContainerFactory, FileFactory
|
||||||
|
from cybertools.integrator.base import ReadContainer, File, Image
|
||||||
|
from cybertools.text import mimetypes
|
||||||
|
|
||||||
|
|
||||||
|
# proxy classes
|
||||||
|
|
||||||
|
class ReadContainer(ReadContainer):
|
||||||
|
|
||||||
|
factoryName = 'bscw'
|
||||||
|
data = None
|
||||||
|
|
||||||
|
@Lazy
|
||||||
|
def data(self):
|
||||||
|
data = self.server.get_attributes(self.address,
|
||||||
|
['__class__', 'type', 'id', 'name', 'descr', 'url_link'], 1, True)
|
||||||
|
return dict((item['id'], item) for item in data[1])
|
||||||
|
|
||||||
|
def keys(self):
|
||||||
|
return self.data.keys()
|
||||||
|
|
||||||
|
def __iter__(self):
|
||||||
|
return iter(self.keys())
|
||||||
|
|
||||||
|
def __getitem__(self, key):
|
||||||
|
if key in self:
|
||||||
|
return self.get(key)
|
||||||
|
raise KeyError(key)
|
||||||
|
|
||||||
|
def get(self, key, default=None):
|
||||||
|
if key not in self.data:
|
||||||
|
return default
|
||||||
|
item = self.data[key]
|
||||||
|
if 'Folder' in item['__class__']:
|
||||||
|
return self.containerFactory(item['id'], server=self.server)
|
||||||
|
elif 'Document' in item['__class__']:
|
||||||
|
return self.fileFactory(item['id'], server=self.server,
|
||||||
|
type=item['type'])
|
||||||
|
else:
|
||||||
|
return OtherObject(item['id'], server=self.server)
|
||||||
|
|
||||||
|
def values(self):
|
||||||
|
return [self.get(k) for k in self]
|
||||||
|
|
||||||
|
def __len__(self):
|
||||||
|
return len(self.keys())
|
||||||
|
|
||||||
|
def items(self):
|
||||||
|
return [(k, self.get(k)) for k in self]
|
||||||
|
|
||||||
|
def __contains__(self, key):
|
||||||
|
return key in self.keys()
|
||||||
|
|
||||||
|
|
||||||
|
class File(File):
|
||||||
|
|
||||||
|
contentType = None
|
||||||
|
|
||||||
|
def getData(self):
|
||||||
|
return self.server.get_document()
|
||||||
|
data = property(getData)
|
||||||
|
|
||||||
|
def getSize(self):
|
||||||
|
return os.stat(self.address)[stat.ST_SIZE]
|
||||||
|
|
||||||
|
|
||||||
|
class Image(File):
|
||||||
|
|
||||||
|
width = height = 0
|
||||||
|
|
||||||
|
def getImageSize(self):
|
||||||
|
return self.width, self.height
|
||||||
|
|
||||||
|
|
||||||
|
class OtherObject(File):
|
||||||
|
|
||||||
|
data = u''
|
||||||
|
|
||||||
|
|
||||||
|
# factory classes
|
||||||
|
|
||||||
|
class ContainerFactory(ContainerFactory):
|
||||||
|
|
||||||
|
proxyClass = ReadContainer
|
||||||
|
|
||||||
|
def __call__(self, address, **kw):
|
||||||
|
server = ServerProxy(address)
|
||||||
|
name = kw.pop('name', '')
|
||||||
|
return self.proxyClass(name, server=server, **kw)
|
||||||
|
|
||||||
|
|
||||||
|
class FileFactory(FileFactory):
|
||||||
|
|
||||||
|
def __call__(self, address, **kw):
|
||||||
|
contentType = kw.pop('type', None)
|
||||||
|
width = height = 0
|
||||||
|
obj = File(address, contentType, **kw)
|
||||||
|
if contentType.startswith('image/'):
|
||||||
|
return Image(address, contentType=contentType,
|
||||||
|
width=width, height=height, **kw)
|
||||||
|
else:
|
||||||
|
obj.contentType = contentType
|
||||||
|
return obj
|
3
integrator/testing/__init__.py
Normal file
3
integrator/testing/__init__.py
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
"""
|
||||||
|
$Id$
|
||||||
|
"""
|
Before Width: | Height: | Size: 1.7 KiB After Width: | Height: | Size: 1.7 KiB |
|
@ -7,7 +7,7 @@ from zope.interface.verify import verifyClass
|
||||||
|
|
||||||
|
|
||||||
baseDir = os.path.dirname(__file__)
|
baseDir = os.path.dirname(__file__)
|
||||||
testDir = os.path.join(baseDir, 'testdata')
|
testDir = os.path.join(baseDir, 'testing', 'data')
|
||||||
|
|
||||||
|
|
||||||
class Test(unittest.TestCase):
|
class Test(unittest.TestCase):
|
||||||
|
|
Loading…
Add table
Reference in a new issue