##############################################################################
#
# 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()