############################################################################## # # Copyright (c) 2002 Zope Corporation and Contributors. All Rights Reserved. # # This software is subject to the provisions of the Zope Public License, # Version 2.1 (ZPL). A copy of the ZPL should accompany this distribution. # THIS SOFTWARE IS PROVIDED "AS IS" AND ANY AND ALL EXPRESS OR IMPLIED # WARRANTIES ARE DISCLAIMED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED # WARRANTIES OF TITLE, MERCHANTABILITY, AGAINST INFRINGEMENT, AND FITNESS # FOR A PARTICULAR PURPOSE # ############################################################################## database_type='Gadfly' __doc__='''%s Database Connection $Id: DA.py 40218 2005-11-18 14:39:19Z andreasjung $''' % database_type __version__='$Revision: 1.16 $'[11:-2] from db import DB, manage_DataSources import sys, DABase, Globals import Shared.DC.ZRDB.Connection, ThreadLock from zExceptions import BadRequest _Connection=Shared.DC.ZRDB.Connection.Connection _connections={} _connections_lock=ThreadLock.allocate_lock() data_sources=manage_DataSources addConnectionForm=Globals.HTMLFile('dtml/connectionAdd',globals()) def manage_addZGadflyConnection( self, id, title, connection, check=None, REQUEST=None): """Add a DB connection to a folder""" # Note - type checking is taken care of by _setObject # and the Connection object constructor. self._setObject(id, Connection( id, title, connection, check)) if REQUEST is not None: return self.manage_main(self,REQUEST) class Connection(DABase.Connection): " " database_type=database_type id='%s_database_connection' % database_type meta_type=title='Z %s Database Connection' % database_type icon='misc_/Z%sDA/conn' % database_type manage_properties=Globals.HTMLFile('dtml/connectionEdit', globals(), data_sources=data_sources) def connected(self): if hasattr(self, '_v_database_connection'): return self._v_database_connection.opened return '' def title_and_id(self): s=_Connection.inheritedAttribute('title_and_id')(self) if (hasattr(self, '_v_database_connection') and self._v_database_connection.opened): s="%s, which is connected" % s else: s="%s, which is not connected" % s return s def title_or_id(self): s=_Connection.inheritedAttribute('title_and_id')(self) if (hasattr(self, '_v_database_connection') and self._v_database_connection.opened): s="%s (connected)" % s else: s="%s ( not connected)" % s return s def connect(self,s): _connections_lock.acquire() try: c=_connections if c.has_key(s): c=self._v_database_connection=c[s] if not c.opened: c.open() return self try: try: self._v_database_connection=c[s]=DB(s) except: t, v, tb = sys.exc_info() raise BadRequest, ( 'Invalid connection string: ' '%s
\n' '\n' % (s,t,v)), tb finally: tb=None return self finally: _connections_lock.release()