diff options
Diffstat (limited to 'connectivity/source/drivers/mozab/MConnection.hxx')
-rw-r--r-- | connectivity/source/drivers/mozab/MConnection.hxx | 231 |
1 files changed, 231 insertions, 0 deletions
diff --git a/connectivity/source/drivers/mozab/MConnection.hxx b/connectivity/source/drivers/mozab/MConnection.hxx new file mode 100644 index 000000000000..f61aac114bf9 --- /dev/null +++ b/connectivity/source/drivers/mozab/MConnection.hxx @@ -0,0 +1,231 @@ +/************************************************************************* + * + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * Copyright 2000, 2010 Oracle and/or its affiliates. + * + * OpenOffice.org - a multi-platform office productivity suite + * + * This file is part of OpenOffice.org. + * + * OpenOffice.org is free software: you can redistribute it and/or modify + * it under the terms of the GNU Lesser General Public License version 3 + * only, as published by the Free Software Foundation. + * + * OpenOffice.org 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 Lesser General Public License version 3 for more details + * (a copy is included in the LICENSE file that accompanied this code). + * + * You should have received a copy of the GNU Lesser General Public License + * version 3 along with OpenOffice.org. If not, see + * <http://www.openoffice.org/license.html> + * for a copy of the LGPLv3 License. + * + ************************************************************************/ +#ifndef CONNECTIVITY_SCONNECTION_HXX +#define CONNECTIVITY_SCONNECTION_HXX + +#include "connectivity/CommonTools.hxx" + +#include "MCatalog.hxx" +#include "MColumnAlias.hxx" +#include "OSubComponent.hxx" +#include "TConnection.hxx" + +#include <com/sun/star/beans/PropertyValue.hpp> +#include <com/sun/star/mozilla/MozillaProductType.hpp> +#include <com/sun/star/sdbc/SQLWarning.hpp> +#include <com/sun/star/sdbcx/XTablesSupplier.hpp> + +#include <cppuhelper/weakref.hxx> + +#include <memory> + +namespace connectivity +{ + namespace mozab + { + + class MozabDriver; + class ODatabaseMetaData; + class MNameMapper; + class ErrorDescriptor; + + namespace SDBCAddress { + typedef enum { + Unknown = 0, + Mozilla = 1, + ThunderBird = 2, + LDAP = 3, + Outlook = 4, + OutlookExp = 5 + } sdbc_address_type; + } + + // For the moment, we will connect the Mozilla address book to the Mozilla + // top-level address book which will display whatever is in the preferences + // file of Mozilla. + enum MozillaScheme + { + // This one is a base uri which will be completed with the connection data. + SCHEME_MOZILLA, + // This one is for mozilla native address book + SCHEME_MOZILLA_MDB, + // This one is for LDAP address book + SCHEME_LDAP, + // These two uris will be used to obtain directory factories to access all + // address books of the given type. + SCHEME_OUTLOOK_MAPI, + SCHEME_OUTLOOK_EXPRESS + }; + const sal_Char* getSchemeURI( MozillaScheme _eScheme ); + + enum SdbcScheme + { + SDBC_MOZILLA, + SDBC_THUNDERBIRD, + SDBC_LDAP, + SDBC_OUTLOOK_MAPI, + SDBC_OUTLOOK_EXPRESS + }; +#ifdef __MINGW32__ + extern "C" +#endif + const sal_Char* getSdbcScheme( SdbcScheme _eScheme ); + + typedef connectivity::OMetaConnection OConnection_BASE; // implements basics and text encoding + + struct ConnectionImplData; + class OConnection : public OConnection_BASE, + public connectivity::OSubComponent<OConnection, OConnection_BASE> + { + friend class connectivity::OSubComponent<OConnection, OConnection_BASE>; + + protected: + //==================================================================== + // Data attributes + //==================================================================== + ::com::sun::star::sdbc::SQLWarning m_aLastWarning; // Last SQLWarning generated by + // an operation + MozabDriver* m_pDriver; // Pointer to the owning + // driver object + ::std::auto_ptr< ConnectionImplData > m_pImplData; + // This is to be able to hold a boost::shared_ptr. If we would hold it as member, it would + // not compile the mozillasrc directory, since this directory is compiled without RTTI support + // and boost seems to require RTTI on some platforms. + // Store Catalog + ::com::sun::star::uno::Reference< ::com::sun::star::sdbcx::XTablesSupplier> m_xCatalog; + // Start of Additions from the land of mozilla + OColumnAlias m_aColumnAlias; + rtl::OUString m_sMozillaURI; + rtl::OUString m_sMozillaProfile; + sal_Int32 m_nMaxResultRecords; + MNameMapper* m_aNameMapper; + //LDAP only + rtl::OUString m_sHostName; + sal_Bool m_bUseSSL; + rtl::OUString m_sBindDN; + rtl::OUString m_sUser; // the user name + rtl::OUString m_sPassword; + + SDBCAddress::sdbc_address_type m_eSDBCAddressType; + + sal_Bool m_bForceLoadTable; + + public: + virtual void construct( const ::rtl::OUString& url,const ::com::sun::star::uno::Sequence< ::com::sun::star::beans::PropertyValue >& info) throw(::com::sun::star::sdbc::SQLException); + OConnection(MozabDriver* _pDriver); + virtual ~OConnection(); + + void closeAllStatements () throw( ::com::sun::star::sdbc::SQLException); + + // OComponentHelper + virtual void SAL_CALL disposing(void); + // XInterface + virtual void SAL_CALL release() throw(); + + // XServiceInfo + DECLARE_SERVICE_INFO(); + // XConnection + virtual ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XStatement > SAL_CALL createStatement( ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException); + virtual ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XPreparedStatement > SAL_CALL prepareStatement( const ::rtl::OUString& sql ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException); + virtual ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XPreparedStatement > SAL_CALL prepareCall( const ::rtl::OUString& sql ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException); + virtual ::rtl::OUString SAL_CALL nativeSQL( const ::rtl::OUString& sql ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException); + virtual void SAL_CALL setAutoCommit( sal_Bool autoCommit ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException); + virtual sal_Bool SAL_CALL getAutoCommit( ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException); + virtual void SAL_CALL commit( ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException); + virtual void SAL_CALL rollback( ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException); + virtual sal_Bool SAL_CALL isClosed( ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException); + virtual ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XDatabaseMetaData > SAL_CALL getMetaData( ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException); + virtual void SAL_CALL setReadOnly( sal_Bool readOnly ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException); + virtual sal_Bool SAL_CALL isReadOnly( ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException); + virtual void SAL_CALL setCatalog( const ::rtl::OUString& catalog ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException); + virtual ::rtl::OUString SAL_CALL getCatalog( ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException); + virtual void SAL_CALL setTransactionIsolation( sal_Int32 level ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException); + virtual sal_Int32 SAL_CALL getTransactionIsolation( ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException); + virtual ::com::sun::star::uno::Reference< ::com::sun::star::container::XNameAccess > SAL_CALL getTypeMap( ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException); + virtual void SAL_CALL setTypeMap( const ::com::sun::star::uno::Reference< ::com::sun::star::container::XNameAccess >& typeMap ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException); + // XCloseable + virtual void SAL_CALL close( ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException); + // XWarningsSupplier + virtual ::com::sun::star::uno::Any SAL_CALL getWarnings( ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException); + virtual void SAL_CALL clearWarnings( ) throw(::com::sun::star::sdbc::SQLException, ::com::sun::star::uno::RuntimeException); + // + MozabDriver* getDriver() const { return m_pDriver;} + + // Added to enable me to use SQLInterpreter which requires an + // XNameAccess i/f to access tables. + ::com::sun::star::uno::Reference< ::com::sun::star::sdbcx::XTablesSupplier > SAL_CALL createCatalog(); + + + // Additions from the land of mozilla + rtl::OUString getMozURI() const { return m_sMozillaURI; } + rtl::OUString getMozProfile() const { return m_sMozillaProfile; } + void setMozProfile(rtl::OUString &aNewProfile) { m_sMozillaProfile = aNewProfile; } + + ::com::sun::star::mozilla::MozillaProductType getProduct() + { + if (m_eSDBCAddressType == SDBCAddress::ThunderBird) + return ::com::sun::star::mozilla::MozillaProductType_Thunderbird; + return ::com::sun::star::mozilla::MozillaProductType_Mozilla; + } + + // Get Ldap BindDN (user name) + rtl::OUString getBindDN() const { return m_sBindDN; } + // Get Ldap Password + rtl::OUString getPassword() const { return m_sPassword; } + // Get Ldap Host name + rtl::OUString getHost() const { return m_sHostName; } + // Get whether use ssl to connect to ldap + sal_Bool getUseSSL() const {return m_bUseSSL;} + + sal_Bool usesFactory(void) const { return (m_eSDBCAddressType == SDBCAddress::Outlook) || (m_eSDBCAddressType == SDBCAddress::OutlookExp); } + sal_Bool isLDAP(void) const { return m_eSDBCAddressType == SDBCAddress::LDAP; } + sal_Bool isThunderbird(void) const { return m_eSDBCAddressType == SDBCAddress::ThunderBird; } + + sal_Bool isOutlookExpress() const { return m_eSDBCAddressType == SDBCAddress::OutlookExp;} + sal_Int32 getMaxResultRecords() const { return m_nMaxResultRecords; } + + SDBCAddress::sdbc_address_type getSDBCAddressType() const { return m_eSDBCAddressType;} + + const OColumnAlias & getColumnAlias() const { return (m_aColumnAlias); } + + static ::rtl::OUString getDriverImplementationName(); + + MNameMapper* getNameMapper(); + void setForceLoadTables(sal_Bool aForce){ m_bForceLoadTable = aForce;} + sal_Bool getForceLoadTables() { return m_bForceLoadTable;} + + void throwSQLException( const ErrorDescriptor& _rError, const ::com::sun::star::uno::Reference< ::com::sun::star::uno::XInterface >& _rxContext ); + void throwSQLException( const sal_uInt16 _nErrorResourceId, const ::com::sun::star::uno::Reference< ::com::sun::star::uno::XInterface >& _rxContext ); + + private: + // make this private - clients should use throwSQLException instead + using OConnection_BASE::throwGenericSQLException; + }; + } +} +#endif // CONNECTIVITY_SCONNECTION_HXX + |