added view and template for BSCW integration
git-svn-id: svn://svn.cy55.de/Zope3/src/cybertools/trunk@2642 fd906abe-77d9-0310-91a1-e0d9ade77398
This commit is contained in:
		
							parent
							
								
									228b7e9077
								
							
						
					
					
						commit
						e2de9b742d
					
				
					 4 changed files with 117 additions and 0 deletions
				
			
		
							
								
								
									
										3
									
								
								integrator/browser/__init__.py
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								integrator/browser/__init__.py
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,3 @@
 | 
				
			||||||
 | 
					"""
 | 
				
			||||||
 | 
					$Id$
 | 
				
			||||||
 | 
					"""
 | 
				
			||||||
							
								
								
									
										67
									
								
								integrator/browser/bscw.py
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										67
									
								
								integrator/browser/bscw.py
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,67 @@
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					#  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
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					"""
 | 
				
			||||||
 | 
					BSCW repository view.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					$Id$
 | 
				
			||||||
 | 
					"""
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					from zope.app.pagetemplate import ViewPageTemplateFile
 | 
				
			||||||
 | 
					from zope import component
 | 
				
			||||||
 | 
					from zope.cachedescriptors.property import Lazy
 | 
				
			||||||
 | 
					from zope.traversing.browser import absoluteURL
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					from cybertools.integrator.bscw import ContainerFactory
 | 
				
			||||||
 | 
					from cybertools.integrator.interfaces import IContainerFactory
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					listing_macros = ViewPageTemplateFile('listing.pt')
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					class BSCWView(object):
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    template = listing_macros
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    baseUrl = ''
 | 
				
			||||||
 | 
					    baseId = ''
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    def __init__(self, context, request):
 | 
				
			||||||
 | 
					        self.context = context
 | 
				
			||||||
 | 
					        self.request = request
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Lazy
 | 
				
			||||||
 | 
					    def listing(self):
 | 
				
			||||||
 | 
					        return self.template.macros['listing']
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    def content(self):
 | 
				
			||||||
 | 
					        url = self.context.getRepositoryURL()
 | 
				
			||||||
 | 
					        if isinstance(url, basestring):
 | 
				
			||||||
 | 
					            server, id = url.rsplit('/', 1)
 | 
				
			||||||
 | 
					            self.baseUrl = server
 | 
				
			||||||
 | 
					        else:   # already a real server object
 | 
				
			||||||
 | 
					            server = url
 | 
				
			||||||
 | 
					            id = self.baseId
 | 
				
			||||||
 | 
					        id = self.request.form.get('id', id)
 | 
				
			||||||
 | 
					        factory = component.getUtility(IContainerFactory, name='bscw')
 | 
				
			||||||
 | 
					        root = factory(id, server=server, baseUrl=self.baseUrl)
 | 
				
			||||||
 | 
					        return root.values()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    def getUrlForObject(self, obj):
 | 
				
			||||||
 | 
					        url = absoluteURL(self.context, self.request)
 | 
				
			||||||
 | 
					        return '%s?id=%s' % (url, obj.internalPath)
 | 
				
			||||||
							
								
								
									
										14
									
								
								integrator/browser/listing.pt
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								integrator/browser/listing.pt
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
					@ -0,0 +1,14 @@
 | 
				
			||||||
 | 
					<!-- $Id$ -->
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					<metal:listing define-macro="listing">
 | 
				
			||||||
 | 
					    <dl>
 | 
				
			||||||
 | 
					      <tal:item repeat="item view/content">
 | 
				
			||||||
 | 
					        <dt>
 | 
				
			||||||
 | 
					          <a tal:attributes="href python: view.getUrlForObject(item)"
 | 
				
			||||||
 | 
					             tal:content="item/title" />
 | 
				
			||||||
 | 
					        </dt>
 | 
				
			||||||
 | 
					        <dd tal:content="item/description">
 | 
				
			||||||
 | 
					        </dd>
 | 
				
			||||||
 | 
					      </tal:item>
 | 
				
			||||||
 | 
					    </dl>
 | 
				
			||||||
 | 
					</metal:listing>
 | 
				
			||||||
| 
						 | 
					@ -6,6 +6,8 @@ Integration of external sources.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  ($Id$)
 | 
					  ($Id$)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  >>> from zope.app.testing.setup import placefulSetUp, placefulTearDown
 | 
				
			||||||
 | 
					  >>> site = placefulSetUp(True)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
Accessing Objects on a Remote BSCW Repository
 | 
					Accessing Objects on a Remote BSCW Repository
 | 
				
			||||||
=============================================
 | 
					=============================================
 | 
				
			||||||
| 
						 | 
					@ -76,3 +78,34 @@ Let's also have a look at the item contained in the root object.
 | 
				
			||||||
  >>> str(bs_5.externalUrlInfo)
 | 
					  >>> str(bs_5.externalUrlInfo)
 | 
				
			||||||
  'http://localhost/bscw.cgi/5'
 | 
					  'http://localhost/bscw.cgi/5'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					The BSCW Repository View
 | 
				
			||||||
 | 
					========================
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  >>> class BSCWAccess(object):
 | 
				
			||||||
 | 
					  ...     def __init__(self, server):
 | 
				
			||||||
 | 
					  ...         self.server = server
 | 
				
			||||||
 | 
					  ...     def getRepositoryURL(self):
 | 
				
			||||||
 | 
					  ...         return self.server
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  >>> site['bscw'] = BSCWAccess(server)
 | 
				
			||||||
 | 
					  >>> bscwAccess = site['bscw']
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  >>> from cybertools.integrator.browser.bscw import BSCWView
 | 
				
			||||||
 | 
					  >>> from zope.publisher.browser import TestRequest
 | 
				
			||||||
 | 
					  >>> view = BSCWView(bscwAccess, TestRequest())
 | 
				
			||||||
 | 
					  >>> view.baseUrl = 'http://localhost/bscw.cgi/'
 | 
				
			||||||
 | 
					  >>> view.baseId = '4'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  >>> view.content()
 | 
				
			||||||
 | 
					  [<...ReadContainer...>]
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  >>> view.getUrlForObject(view.content()[0])
 | 
				
			||||||
 | 
					  'http://127.0.0.1/bscw?id=bs_5'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					Fin de partie
 | 
				
			||||||
 | 
					=============
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  >>> placefulTearDown()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		
		Reference in a new issue