1 /**************************************************************
2  *
3  * Licensed to the Apache Software Foundation (ASF) under one
4  * or more contributor license agreements.  See the NOTICE file
5  * distributed with this work for additional information
6  * regarding copyright ownership.  The ASF licenses this file
7  * to you under the Apache License, Version 2.0 (the
8  * "License"); you may not use this file except in compliance
9  * with the License.  You may obtain a copy of the License at
10  *
11  *   http://www.apache.org/licenses/LICENSE-2.0
12  *
13  * Unless required by applicable law or agreed to in writing,
14  * software distributed under the License is distributed on an
15  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16  * KIND, either express or implied.  See the License for the
17  * specific language governing permissions and limitations
18  * under the License.
19  *
20  *************************************************************/
21 
22 
23 
24 // MARKER(update_precomp.py): autogen include statement, do not remove
25 #include "precompiled_dbaccess.hxx"
26 
27 #include "dsntypes.hxx"
28 #include "dbamiscres.hrc"
29 #include <unotools/confignode.hxx>
30 #include <tools/debug.hxx>
31 #include <tools/wldcrd.hxx>
32 #include <osl/file.hxx>
33 #include "dbastrings.hrc"
34 #include "core_resource.hxx"
35 #include "core_resource.hrc"
36 #include <comphelper/documentconstants.hxx>
37 
38 //.........................................................................
39 namespace dbaccess
40 {
41 //.........................................................................
42 
43     using namespace ::com::sun::star;
44 	using namespace ::com::sun::star::uno;
45 	using namespace ::com::sun::star::beans;
46 	using namespace ::com::sun::star::lang;
47     //using namespace ::com::sun::star::sdbc;
48 
49 	namespace
50 	{
lcl_extractHostAndPort(const String & _sUrl,String & _sHostname,sal_Int32 & _nPortNumber)51 		void lcl_extractHostAndPort(const String& _sUrl,String& _sHostname,sal_Int32& _nPortNumber)
52 		{
53 			if ( _sUrl.GetTokenCount(':') >= 2 )
54 			{
55 				_sHostname		= _sUrl.GetToken(0,':');
56 				_nPortNumber	= _sUrl.GetToken(1,':').ToInt32();
57 			}
58 		}
59 	}
60 //=========================================================================
61 //= ODsnTypeCollection
62 //=========================================================================
DBG_NAME(ODsnTypeCollection)63 DBG_NAME(ODsnTypeCollection)
64 //-------------------------------------------------------------------------
65 ODsnTypeCollection::ODsnTypeCollection(const ::com::sun::star::uno::Reference< ::com::sun::star::lang::XMultiServiceFactory >& _xFactory)
66 :m_aDriverConfig(_xFactory)
67 ,m_xFactory(_xFactory)
68 #ifdef DBG_UTIL
69 ,m_nLivingIterators(0)
70 #endif
71 {
72 	DBG_CTOR(ODsnTypeCollection,NULL);
73     const uno::Sequence< ::rtl::OUString > aURLs = m_aDriverConfig.getURLs();
74     const ::rtl::OUString* pIter = aURLs.getConstArray();
75     const ::rtl::OUString* pEnd = pIter + aURLs.getLength();
76     for(;pIter != pEnd;++pIter )
77     {
78         m_aDsnPrefixes.push_back(*pIter);
79         m_aDsnTypesDisplayNames.push_back(m_aDriverConfig.getDriverTypeDisplayName(*pIter));
80     }
81 
82 	DBG_ASSERT(m_aDsnTypesDisplayNames.size() == m_aDsnPrefixes.size(),
83 		"ODsnTypeCollection::ODsnTypeCollection : invalid resources !");
84 }
85 
86 //-------------------------------------------------------------------------
~ODsnTypeCollection()87 ODsnTypeCollection::~ODsnTypeCollection()
88 {
89 	DBG_DTOR(ODsnTypeCollection,NULL);
90 	DBG_ASSERT(0 == m_nLivingIterators, "ODsnTypeCollection::~ODsnTypeCollection : there are still living iterator objects!");
91 }
92 //-------------------------------------------------------------------------
getTypeDisplayName(const::rtl::OUString & _sURL) const93 String ODsnTypeCollection::getTypeDisplayName(const ::rtl::OUString& _sURL) const
94 {
95     return m_aDriverConfig.getDriverTypeDisplayName(_sURL);
96 }
97 //-------------------------------------------------------------------------
cutPrefix(const::rtl::OUString & _sURL) const98 String ODsnTypeCollection::cutPrefix(const ::rtl::OUString& _sURL) const
99 {
100     String sURL( _sURL);
101     String sRet;
102     String sOldPattern;
103     StringVector::const_iterator aIter = m_aDsnPrefixes.begin();
104     StringVector::const_iterator aEnd = m_aDsnPrefixes.end();
105     for(;aIter != aEnd;++aIter)
106     {
107         WildCard aWildCard(*aIter);
108         if ( sOldPattern.Len() < aIter->Len() && aWildCard.Matches(_sURL) )
109         {
110             if ( aIter->Len() < sURL.Len() )
111                 sRet = sURL.Copy(sURL.Match(*aIter));
112             else
113                 sRet = sURL.Copy(aIter->Match(sURL));
114             sOldPattern = *aIter;
115         }
116     }
117 
118     return sRet;
119 }
120 
121 //-------------------------------------------------------------------------
getPrefix(const::rtl::OUString & _sURL) const122 String ODsnTypeCollection::getPrefix(const ::rtl::OUString& _sURL) const
123 {
124     String sURL( _sURL);
125     String sRet;
126     String sOldPattern;
127     StringVector::const_iterator aIter = m_aDsnPrefixes.begin();
128     StringVector::const_iterator aEnd = m_aDsnPrefixes.end();
129     for(;aIter != aEnd;++aIter)
130     {
131         WildCard aWildCard(*aIter);
132         if ( sOldPattern.Len() < aIter->Len() && aWildCard.Matches(sURL) )
133         {
134             if ( aIter->Len() < sURL.Len() )
135                 sRet = aIter->Copy(0,sURL.Match(*aIter));
136             else
137                 sRet = sURL.Copy(0,aIter->Match(sURL));
138             sRet.EraseTrailingChars('*');
139             sOldPattern = *aIter;
140         }
141     }
142 
143     return sRet;
144 }
145 
146 //-------------------------------------------------------------------------
hasDriver(const sal_Char * _pAsciiPattern) const147 bool ODsnTypeCollection::hasDriver( const sal_Char* _pAsciiPattern ) const
148 {
149     String sPrefix( getPrefix( ::rtl::OUString::createFromAscii( _pAsciiPattern ) ) );
150     return ( sPrefix.Len() > 0 );
151 }
152 
153 // -----------------------------------------------------------------------------
isConnectionUrlRequired(const::rtl::OUString & _sURL) const154 bool ODsnTypeCollection::isConnectionUrlRequired(const ::rtl::OUString& _sURL) const
155 {
156     String sURL( _sURL);
157     String sRet;
158     String sOldPattern;
159     StringVector::const_iterator aIter = m_aDsnPrefixes.begin();
160     StringVector::const_iterator aEnd = m_aDsnPrefixes.end();
161     for(;aIter != aEnd;++aIter)
162     {
163         WildCard aWildCard(*aIter);
164         if ( sOldPattern.Len() < aIter->Len() && aWildCard.Matches(sURL) )
165         {
166             sRet = *aIter;
167             sOldPattern = *aIter;
168         }
169     } // for(;aIter != aEnd;++aIter)
170     return sRet.GetChar(sRet.Len()-1) == '*';
171 }
172 // -----------------------------------------------------------------------------
getMediaType(const::rtl::OUString & _sURL) const173 String ODsnTypeCollection::getMediaType(const ::rtl::OUString& _sURL) const
174 {
175     const ::comphelper::NamedValueCollection& aFeatures = m_aDriverConfig.getMetaData(_sURL);
176     return aFeatures.getOrDefault("MediaType",::rtl::OUString());
177 }
178 // -----------------------------------------------------------------------------
getDatasourcePrefixFromMediaType(const::rtl::OUString & _sMediaType,const::rtl::OUString & _sExtension)179 String ODsnTypeCollection::getDatasourcePrefixFromMediaType(const ::rtl::OUString& _sMediaType,const ::rtl::OUString& _sExtension)
180 {
181     String sURL, sFallbackURL;
182     const uno::Sequence< ::rtl::OUString > aURLs = m_aDriverConfig.getURLs();
183     const ::rtl::OUString* pIter = aURLs.getConstArray();
184     const ::rtl::OUString* pEnd = pIter + aURLs.getLength();
185     for(;pIter != pEnd;++pIter )
186     {
187         const ::comphelper::NamedValueCollection& aFeatures = m_aDriverConfig.getMetaData(*pIter);
188         if ( aFeatures.getOrDefault("MediaType",::rtl::OUString()) == _sMediaType )
189         {
190             const ::rtl::OUString sFileExtension = aFeatures.getOrDefault("Extension",::rtl::OUString());
191             if ( _sExtension == sFileExtension )
192             {
193                 sURL = *pIter;
194                 break;
195             }
196             if ( !sFileExtension.getLength() && _sExtension.getLength() )
197                 sFallbackURL = *pIter;
198         }
199     } // for(;pIter != pEnd;++pIter )
200 
201     if ( !sURL.Len() && sFallbackURL.Len() )
202         sURL = sFallbackURL;
203 
204     sURL.EraseTrailingChars('*');
205     return sURL;
206 }
207 // -----------------------------------------------------------------------------
isShowPropertiesEnabled(const::rtl::OUString & _sURL) const208 bool ODsnTypeCollection::isShowPropertiesEnabled( const ::rtl::OUString& _sURL ) const
209 {
210     return !(    _sURL.matchIgnoreAsciiCaseAsciiL("sdbc:embedded:hsqldb",sizeof("sdbc:embedded:hsqldb")-1)
211             ||  _sURL.matchIgnoreAsciiCaseAsciiL("sdbc:address:outlook",sizeof("sdbc:address:outlook")-1)
212             ||  _sURL.matchIgnoreAsciiCaseAsciiL("sdbc:address:outlookexp",sizeof("sdbc:address:outlookexp")-1)
213             ||  _sURL.matchIgnoreAsciiCaseAsciiL("sdbc:address:mozilla:",sizeof("sdbc:address:mozilla:")-1)
214             ||  _sURL.matchIgnoreAsciiCaseAsciiL("sdbc:address:kab",sizeof("sdbc:address:kab")-1)
215             ||  _sURL.matchIgnoreAsciiCaseAsciiL("sdbc:address:evolution:local",sizeof("sdbc:address:evolution:local")-1)
216             ||  _sURL.matchIgnoreAsciiCaseAsciiL("sdbc:address:evolution:groupwise",sizeof("sdbc:address:evolution:groupwise")-1)
217             ||  _sURL.matchIgnoreAsciiCaseAsciiL("sdbc:address:evolution:ldap",sizeof("sdbc:address:evolution:ldap")-1)
218             ||  _sURL.matchIgnoreAsciiCaseAsciiL("sdbc:address:macab",sizeof("sdbc:address:macab")-1)  );
219 }
220 // -----------------------------------------------------------------------------
extractHostNamePort(const::rtl::OUString & _rDsn,String & _sDatabaseName,String & _rsHostname,sal_Int32 & _nPortNumber) const221 void ODsnTypeCollection::extractHostNamePort(const ::rtl::OUString& _rDsn,String& _sDatabaseName,String& _rsHostname,sal_Int32& _nPortNumber) const
222 {
223     String sUrl = cutPrefix(_rDsn);
224     if ( _rDsn.matchIgnoreAsciiCaseAsciiL("jdbc:oracle:thin:",sizeof("jdbc:oracle:thin:")-1) )
225     {
226         lcl_extractHostAndPort(sUrl,_rsHostname,_nPortNumber);
227 		if ( !_rsHostname.Len() && sUrl.GetTokenCount(':') == 2 )
228 		{
229 			_nPortNumber = -1;
230 			_rsHostname = sUrl.GetToken(0,':');
231 		}
232 		if ( _rsHostname.Len() )
233 			_rsHostname = _rsHostname.GetToken(_rsHostname.GetTokenCount('@') - 1,'@');
234 		_sDatabaseName = sUrl.GetToken(sUrl.GetTokenCount(':') - 1,':');
235     } // if ( _rDsn.matchIgnoreAsciiCaseAsciiL("jdbc:oracle:thin:",sizeof("jdbc:oracle:thin:")-1) )
236     else if ( _rDsn.matchIgnoreAsciiCaseAsciiL("sdbc:address:ldap:",sizeof("sdbc:address:ldap:")-1) )
237     {
238         lcl_extractHostAndPort(sUrl,_sDatabaseName,_nPortNumber);
239     }
240     else if ( _rDsn.matchIgnoreAsciiCaseAsciiL("sdbc:adabas:",sizeof("sdbc:adabas:")-1) )
241     {
242         if ( sUrl.GetTokenCount(':') == 2 )
243 			_rsHostname = sUrl.GetToken(0,':');
244 		_sDatabaseName = sUrl.GetToken(sUrl.GetTokenCount(':') - 1,':');
245     }
246     else if ( _rDsn.matchIgnoreAsciiCaseAsciiL("sdbc:mysql:mysqlc:",sizeof("sdbc:mysql:mysqlc:")-1) || _rDsn.matchIgnoreAsciiCaseAsciiL("sdbc:mysql:jdbc:",sizeof("sdbc:mysql:jdbc:")-1) )
247     {
248         lcl_extractHostAndPort(sUrl,_rsHostname,_nPortNumber);
249 
250 		if ( _nPortNumber == -1 && !_rsHostname.Len() && sUrl.GetTokenCount('/') == 2 )
251 			_rsHostname = sUrl.GetToken(0,'/');
252 		_sDatabaseName = sUrl.GetToken(sUrl.GetTokenCount('/') - 1,'/');
253     }
254     else if ( _rDsn.matchIgnoreAsciiCaseAsciiL("sdbc:ado:access:Provider=Microsoft.ACE.OLEDB.12.0;DATA SOURCE=",sizeof("sdbc:ado:access:Provider=Microsoft.ACE.OLEDB.12.0;DATA SOURCE=")-1)
255          || _rDsn.matchIgnoreAsciiCaseAsciiL("sdbc:ado:access:PROVIDER=Microsoft.Jet.OLEDB.4.0;DATA SOURCE=",sizeof("sdbc:ado:access:PROVIDER=Microsoft.Jet.OLEDB.4.0;DATA SOURCE=")-1))
256     {
257         ::rtl::OUString sNewFileName;
258 		if ( ::osl::FileBase::getFileURLFromSystemPath( sUrl, sNewFileName ) == ::osl::FileBase::E_None )
259 		{
260 			_sDatabaseName = sNewFileName;
261 		}
262     }
263 }
264 // -----------------------------------------------------------------------------
getJavaDriverClass(const::rtl::OUString & _sURL) const265 String ODsnTypeCollection::getJavaDriverClass(const ::rtl::OUString& _sURL) const
266 {
267     const ::comphelper::NamedValueCollection& aFeatures = m_aDriverConfig.getProperties(_sURL);
268     return aFeatures.getOrDefault("JavaDriverClass",::rtl::OUString());
269 }
270 //-------------------------------------------------------------------------
isFileSystemBased(const::rtl::OUString & _sURL) const271 sal_Bool ODsnTypeCollection::isFileSystemBased(const ::rtl::OUString& _sURL) const
272 {
273     const ::comphelper::NamedValueCollection& aFeatures = m_aDriverConfig.getMetaData(_sURL);
274     return aFeatures.getOrDefault("FileSystemBased",sal_False);
275 }
276 // -----------------------------------------------------------------------------
supportsTableCreation(const::rtl::OUString & _sURL) const277 sal_Bool ODsnTypeCollection::supportsTableCreation(const ::rtl::OUString& _sURL) const
278 {
279     const ::comphelper::NamedValueCollection& aFeatures = m_aDriverConfig.getMetaData(_sURL);
280     return aFeatures.getOrDefault("SupportsTableCreation",sal_False);
281 }
282 // -----------------------------------------------------------------------------
supportsColumnDescription(const::rtl::OUString & _sURL) const283 sal_Bool ODsnTypeCollection::supportsColumnDescription(const ::rtl::OUString& _sURL) const
284 {
285     const ::comphelper::NamedValueCollection& aFeatures = m_aDriverConfig.getMetaData(_sURL);
286     return aFeatures.getOrDefault("SupportsColumnDescription",sal_False);
287 }
288 // -----------------------------------------------------------------------------
supportsBrowsing(const::rtl::OUString & _sURL) const289 sal_Bool ODsnTypeCollection::supportsBrowsing(const ::rtl::OUString& _sURL) const
290 {
291     const ::comphelper::NamedValueCollection& aFeatures = m_aDriverConfig.getMetaData(_sURL);
292     return aFeatures.getOrDefault("SupportsBrowsing",sal_False);
293 }
294 // -----------------------------------------------------------------------------
needsJVM(const String & _sURL) const295 bool ODsnTypeCollection::needsJVM(const String& _sURL) const
296 {
297     const ::comphelper::NamedValueCollection& aFeatures = m_aDriverConfig.getMetaData(_sURL);
298     return aFeatures.getOrDefault("UseJava",sal_False);
299 }
300 // -----------------------------------------------------------------------------
getDefaultDBSettings(const::rtl::OUString & _sURL) const301 Sequence<PropertyValue> ODsnTypeCollection::getDefaultDBSettings( const ::rtl::OUString& _sURL ) const
302 {
303     const ::comphelper::NamedValueCollection& aProperties = m_aDriverConfig.getProperties(_sURL);
304     return aProperties.getPropertyValues();
305 }
306 
307 //-------------------------------------------------------------------------
isEmbeddedDatabase(const::rtl::OUString & _sURL) const308 bool ODsnTypeCollection::isEmbeddedDatabase( const ::rtl::OUString& _sURL ) const
309 {
310     const ::rtl::OUString sEmbeddedDatabaseURL = getEmbeddedDatabase();
311     WildCard aWildCard(sEmbeddedDatabaseURL);
312     return aWildCard.Matches(_sURL);
313 }
314 // -----------------------------------------------------------------------------
getEmbeddedDatabase() const315 ::rtl::OUString ODsnTypeCollection::getEmbeddedDatabase() const
316 {
317     ::rtl::OUString sEmbeddedDatabaseURL;
318     static const ::rtl::OUString s_sNodeName(RTL_CONSTASCII_USTRINGPARAM("org.openoffice.Office.DataAccess")); ///Installed
319     const ::utl::OConfigurationTreeRoot aInstalled = ::utl::OConfigurationTreeRoot::createWithServiceFactory(m_xFactory, s_sNodeName, -1, ::utl::OConfigurationTreeRoot::CM_READONLY);
320     if ( aInstalled.isValid() )
321     {
322         if ( aInstalled.hasByName("EmbeddedDatabases/DefaultEmbeddedDatabase/Value") )
323         {
324             static const ::rtl::OUString s_sValue(RTL_CONSTASCII_USTRINGPARAM("EmbeddedDatabases/DefaultEmbeddedDatabase/Value"));
325 
326             aInstalled.getNodeValue(s_sValue) >>= sEmbeddedDatabaseURL;
327             if ( sEmbeddedDatabaseURL.getLength() )
328                 aInstalled.getNodeValue(s_sValue + ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("/")) + sEmbeddedDatabaseURL + ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("/URL"))) >>= sEmbeddedDatabaseURL;
329         }
330     } // if ( aInstalled.isValid() )
331     if ( !sEmbeddedDatabaseURL.getLength() )
332         sEmbeddedDatabaseURL = ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("sdbc:embedded:hsqldb"));
333     return sEmbeddedDatabaseURL;
334 }
335 //-------------------------------------------------------------------------
begin() const336 ODsnTypeCollection::TypeIterator ODsnTypeCollection::begin() const
337 {
338 	return TypeIterator(this, 0);
339 }
340 
341 //-------------------------------------------------------------------------
end() const342 ODsnTypeCollection::TypeIterator ODsnTypeCollection::end() const
343 {
344 	return TypeIterator(this, m_aDsnTypesDisplayNames.size());
345 }
346 //-------------------------------------------------------------------------
determineType(const String & _rDsn) const347 DATASOURCE_TYPE ODsnTypeCollection::determineType(const String& _rDsn) const
348 {
349     String sDsn(_rDsn);
350     sDsn.EraseTrailingChars('*');
351 	sal_uInt16 nSeparator = sDsn.Search((sal_Unicode)':');
352 	if (STRING_NOTFOUND == nSeparator)
353 	{
354 		// there should be at least one such separator
355 		DBG_ERROR("ODsnTypeCollection::implDetermineType : missing the colon !");
356 		return DST_UNKNOWN;
357 	}
358 	// find first :
359 	sal_uInt16 nOracleSeparator = sDsn.Search((sal_Unicode)':', nSeparator + 1);
360 	if ( nOracleSeparator != STRING_NOTFOUND )
361 	{
362 		nOracleSeparator = sDsn.Search((sal_Unicode)':', nOracleSeparator + 1);
363 		if (nOracleSeparator != STRING_NOTFOUND && sDsn.EqualsIgnoreCaseAscii("jdbc:oracle:thin", 0, nOracleSeparator))
364 			return DST_ORACLE_JDBC;
365 	}
366 
367 	if (sDsn.EqualsIgnoreCaseAscii("jdbc", 0, nSeparator))
368 		return DST_JDBC;
369 
370 	if (sDsn.EqualsIgnoreCaseAscii("sdbc:embedded:hsqldb", 0, sDsn.Len()))
371 		return DST_EMBEDDED_HSQLDB;
372 
373 	// find second :
374 	nSeparator = sDsn.Search((sal_Unicode)':', nSeparator + 1);
375 	if (STRING_NOTFOUND == nSeparator)
376 	{
377 		// at the moment only jdbc is allowed to have just one separator
378 		DBG_ERROR("ODsnTypeCollection::implDetermineType : missing the second colon !");
379 		return DST_UNKNOWN;
380 	}
381 
382 	if (sDsn.EqualsIgnoreCaseAscii("sdbc:ado:", 0, nSeparator))
383 	{
384 		nSeparator = sDsn.Search((sal_Unicode)':', nSeparator + 1);
385         if (STRING_NOTFOUND != nSeparator && sDsn.EqualsIgnoreCaseAscii("sdbc:ado:access",0, nSeparator) )
386         {
387             nSeparator = sDsn.Search((sal_Unicode)';', nSeparator + 1);
388             if (STRING_NOTFOUND != nSeparator && sDsn.EqualsIgnoreCaseAscii("sdbc:ado:access:Provider=Microsoft.ACE.OLEDB.12.0",0, nSeparator) )
389                 return DST_MSACCESS_2007;
390 
391             return DST_MSACCESS;
392         }
393 		return DST_ADO;
394 	}
395 
396     struct KnownPrefix
397     {
398         const sal_Char*         pAsciiPrefix;
399         const DATASOURCE_TYPE   eType;
400         const bool              bMatchComplete;
401 
402         KnownPrefix()
403             :pAsciiPrefix( NULL )
404             ,eType( DST_UNKNOWN )
405             ,bMatchComplete( false )
406         {
407         }
408         KnownPrefix( const sal_Char* _p, const DATASOURCE_TYPE _t, const bool _m )
409             :pAsciiPrefix( _p )
410             ,eType ( _t )
411             ,bMatchComplete( _m )
412         {
413         }
414     };
415     KnownPrefix aKnowPrefixes[] =
416     {
417         KnownPrefix( "sdbc:calc:",          DST_CALC,               false ),
418         KnownPrefix( "sdbc:flat:",          DST_FLAT,               false ),
419         KnownPrefix( "sdbc:adabas:",        DST_ADABAS,             false ),
420         KnownPrefix( "sdbc:odbc:",          DST_ODBC,               false ),
421         KnownPrefix( "sdbc:dbase:",         DST_DBASE,              false ),
422         KnownPrefix( "sdbc:mysql:odbc:",    DST_MYSQL_ODBC,         false ),
423         KnownPrefix( "sdbc:mysql:jdbc:",    DST_MYSQL_JDBC,         false ),
424         KnownPrefix( "sdbc:mysql:mysqlc:",  DST_MYSQL_NATIVE,       false ),
425         KnownPrefix( "sdbc:mysqlc:",        DST_MYSQL_NATIVE_DIRECT,false ),
426 
427         KnownPrefix( "sdbc:address:mozilla:",           DST_MOZILLA,            true ),
428         KnownPrefix( "sdbc:address:thunderbird:",       DST_THUNDERBIRD,        true ),
429         KnownPrefix( "sdbc:address:ldap:",              DST_LDAP,               true ),
430         KnownPrefix( "sdbc:address:outlook",            DST_OUTLOOK,            true ),
431         KnownPrefix( "sdbc:address:outlookexp",         DST_OUTLOOKEXP,         true ),
432         KnownPrefix( "sdbc:address:evolution:ldap",     DST_EVOLUTION_LDAP,     true ),
433         KnownPrefix( "sdbc:address:evolution:groupwise",DST_EVOLUTION_GROUPWISE,true ),
434         KnownPrefix( "sdbc:address:evolution:local",    DST_EVOLUTION,          true ),
435         KnownPrefix( "sdbc:address:kab",                DST_KAB,                true ),
436         KnownPrefix( "sdbc:address:macab",              DST_MACAB,              true )
437     };
438 
439     for ( size_t i=0; i < sizeof( aKnowPrefixes ) / sizeof( aKnowPrefixes[0] ); ++i )
440     {
441         sal_uInt16 nMatchLen = aKnowPrefixes[i].bMatchComplete ? sDsn.Len() : (sal_uInt16)rtl_str_getLength( aKnowPrefixes[i].pAsciiPrefix );
442         if ( sDsn.EqualsIgnoreCaseAscii( aKnowPrefixes[i].pAsciiPrefix, 0, nMatchLen ) )
443 	        return aKnowPrefixes[i].eType;
444     }
445 
446 	return DST_UNKNOWN;
447 }
448 // -----------------------------------------------------------------------------
fillPageIds(const::rtl::OUString & _sURL,::std::vector<sal_Int16> & _rOutPathIds) const449 void ODsnTypeCollection::fillPageIds(const ::rtl::OUString& _sURL,::std::vector<sal_Int16>& _rOutPathIds) const
450 {
451     DATASOURCE_TYPE eType = determineType(_sURL);
452     switch(eType)
453     {
454         case DST_ADO:
455             _rOutPathIds.push_back(PAGE_DBSETUPWIZARD_ADO);
456             break;
457         case DST_DBASE:
458             _rOutPathIds.push_back(PAGE_DBSETUPWIZARD_DBASE);
459             break;
460         case DST_FLAT:
461             _rOutPathIds.push_back(PAGE_DBSETUPWIZARD_TEXT);
462             break;
463         case DST_CALC:
464             _rOutPathIds.push_back(PAGE_DBSETUPWIZARD_SPREADSHEET);
465             break;
466         case DST_ODBC:
467             _rOutPathIds.push_back(PAGE_DBSETUPWIZARD_ODBC);
468             break;
469         case DST_JDBC:
470             _rOutPathIds.push_back(PAGE_DBSETUPWIZARD_JDBC);
471             break;
472         case DST_MYSQL_ODBC:
473             _rOutPathIds.push_back(PAGE_DBSETUPWIZARD_MYSQL_INTRO);
474             _rOutPathIds.push_back(PAGE_DBSETUPWIZARD_MYSQL_ODBC);
475             break;
476         case DST_MYSQL_JDBC:
477             _rOutPathIds.push_back(PAGE_DBSETUPWIZARD_MYSQL_INTRO);
478             _rOutPathIds.push_back(PAGE_DBSETUPWIZARD_MYSQL_JDBC);
479             break;
480         case DST_MYSQL_NATIVE:
481             _rOutPathIds.push_back(PAGE_DBSETUPWIZARD_MYSQL_INTRO);
482             _rOutPathIds.push_back(PAGE_DBSETUPWIZARD_MYSQL_NATIVE);
483             break;
484         case DST_ORACLE_JDBC:
485             _rOutPathIds.push_back(PAGE_DBSETUPWIZARD_ORACLE);
486             break;
487         case DST_ADABAS:
488             _rOutPathIds.push_back(PAGE_DBSETUPWIZARD_ADABAS);
489             break;
490         case DST_LDAP:
491             _rOutPathIds.push_back(PAGE_DBSETUPWIZARD_LDAP);
492             break;
493         case DST_MSACCESS:
494         case DST_MSACCESS_2007:
495             _rOutPathIds.push_back(PAGE_DBSETUPWIZARD_MSACCESS);
496             break;
497         case DST_OUTLOOKEXP:
498         case DST_OUTLOOK:
499         case DST_MOZILLA:
500         case DST_THUNDERBIRD:
501         case DST_EVOLUTION:
502         case DST_EVOLUTION_GROUPWISE:
503         case DST_EVOLUTION_LDAP:
504         case DST_KAB:
505         case DST_MACAB:
506         case DST_EMBEDDED_HSQLDB:
507             break;
508         default:
509             _rOutPathIds.push_back(PAGE_DBSETUPWIZARD_USERDEFINED);
510             break;
511     }
512 }
513 // -----------------------------------------------------------------------------
getType(const::rtl::OUString & _sURL) const514 ::rtl::OUString ODsnTypeCollection::getType(const ::rtl::OUString& _sURL) const
515 {
516     ::rtl::OUString sOldPattern;
517     StringVector::const_iterator aIter = m_aDsnPrefixes.begin();
518     StringVector::const_iterator aEnd = m_aDsnPrefixes.end();
519     for(;aIter != aEnd;++aIter)
520     {
521         WildCard aWildCard(*aIter);
522         if ( sOldPattern.getLength() < aIter->Len() && aWildCard.Matches(_sURL) )
523         {
524             sOldPattern = *aIter;
525         }
526     } // for(sal_Int32 i = 0;aIter != aEnd;++aIter,++i)
527     return sOldPattern;
528 }
529 // -----------------------------------------------------------------------------
getIndexOf(const::rtl::OUString & _sURL) const530 sal_Int32 ODsnTypeCollection::getIndexOf(const ::rtl::OUString& _sURL) const
531 {
532     sal_Int32 nRet = -1;
533     String sURL( _sURL);
534     String sOldPattern;
535     StringVector::const_iterator aIter = m_aDsnPrefixes.begin();
536     StringVector::const_iterator aEnd = m_aDsnPrefixes.end();
537     for(sal_Int32 i = 0;aIter != aEnd;++aIter,++i)
538     {
539         WildCard aWildCard(*aIter);
540         if ( sOldPattern.Len() < aIter->Len() && aWildCard.Matches(sURL) )
541         {
542             nRet = i;
543             sOldPattern = *aIter;
544         }
545     }
546 
547     return nRet;
548 }
549 // -----------------------------------------------------------------------------
size() const550 sal_Int32 ODsnTypeCollection::size() const
551 {
552     return m_aDsnPrefixes.size();
553 }
554 //=========================================================================
555 //= ODsnTypeCollection::TypeIterator
556 //=========================================================================
557 //-------------------------------------------------------------------------
TypeIterator(const ODsnTypeCollection * _pContainer,sal_Int32 _nInitialPos)558 ODsnTypeCollection::TypeIterator::TypeIterator(const ODsnTypeCollection* _pContainer, sal_Int32 _nInitialPos)
559 	:m_pContainer(_pContainer)
560 	,m_nPosition(_nInitialPos)
561 {
562 	DBG_ASSERT(m_pContainer, "ODsnTypeCollection::TypeIterator::TypeIterator : invalid container!");
563 #ifdef DBG_UTIL
564 	++const_cast<ODsnTypeCollection*>(m_pContainer)->m_nLivingIterators;
565 #endif
566 }
567 
568 //-------------------------------------------------------------------------
TypeIterator(const TypeIterator & _rSource)569 ODsnTypeCollection::TypeIterator::TypeIterator(const TypeIterator& _rSource)
570 	:m_pContainer(_rSource.m_pContainer)
571 	,m_nPosition(_rSource.m_nPosition)
572 {
573 #ifdef DBG_UTIL
574 	++const_cast<ODsnTypeCollection*>(m_pContainer)->m_nLivingIterators;
575 #endif
576 }
577 
578 //-------------------------------------------------------------------------
~TypeIterator()579 ODsnTypeCollection::TypeIterator::~TypeIterator()
580 {
581 #ifdef DBG_UTIL
582 	--const_cast<ODsnTypeCollection*>(m_pContainer)->m_nLivingIterators;
583 #endif
584 }
585 
586 //-------------------------------------------------------------------------
getDisplayName() const587 String ODsnTypeCollection::TypeIterator::getDisplayName() const
588 {
589 	DBG_ASSERT(m_nPosition < (sal_Int32)m_pContainer->m_aDsnTypesDisplayNames.size(), "ODsnTypeCollection::TypeIterator::getDisplayName : invalid position!");
590 	return m_pContainer->m_aDsnTypesDisplayNames[m_nPosition];
591 }
592 // -----------------------------------------------------------------------------
getURLPrefix() const593 ::rtl::OUString ODsnTypeCollection::TypeIterator::getURLPrefix() const
594 {
595     DBG_ASSERT(m_nPosition < (sal_Int32)m_pContainer->m_aDsnPrefixes.size(), "ODsnTypeCollection::TypeIterator::getDisplayName : invalid position!");
596 	return m_pContainer->m_aDsnPrefixes[m_nPosition];
597 }
598 //-------------------------------------------------------------------------
operator ++()599 const ODsnTypeCollection::TypeIterator&	ODsnTypeCollection::TypeIterator::operator++()
600 {
601 	DBG_ASSERT(m_nPosition < (sal_Int32)m_pContainer->m_aDsnTypesDisplayNames.size(), "ODsnTypeCollection::TypeIterator::operator++ : invalid position!");
602 	if (m_nPosition < (sal_Int32)m_pContainer->m_aDsnTypesDisplayNames.size())
603 		++m_nPosition;
604 	return *this;
605 }
606 
607 //-------------------------------------------------------------------------
operator --()608 const ODsnTypeCollection::TypeIterator&	ODsnTypeCollection::TypeIterator::operator--()
609 {
610 	DBG_ASSERT(m_nPosition >= 0, "ODsnTypeCollection::TypeIterator::operator-- : invalid position!");
611 	if (m_nPosition >= 0)
612 		--m_nPosition;
613 	return *this;
614 }
615 
616 //-------------------------------------------------------------------------
operator ==(const ODsnTypeCollection::TypeIterator & lhs,const ODsnTypeCollection::TypeIterator & rhs)617 bool operator==(const ODsnTypeCollection::TypeIterator& lhs, const ODsnTypeCollection::TypeIterator& rhs)
618 {
619 	return (lhs.m_pContainer == rhs.m_pContainer) && (lhs.m_nPosition == rhs.m_nPosition);
620 }
621 
622 //.........................................................................
623 }	// namespace dbaccess
624 //.........................................................................
625 
626