xref: /trunk/main/dbaccess/source/ui/dlg/dbwiz.cxx (revision cdf0e10c4e3984b49a9502b011690b615761d4a3)
1 /*************************************************************************
2  *
3  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4  *
5  * Copyright 2000, 2010 Oracle and/or its affiliates.
6  *
7  * OpenOffice.org - a multi-platform office productivity suite
8  *
9  * This file is part of OpenOffice.org.
10  *
11  * OpenOffice.org is free software: you can redistribute it and/or modify
12  * it under the terms of the GNU Lesser General Public License version 3
13  * only, as published by the Free Software Foundation.
14  *
15  * OpenOffice.org is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18  * GNU Lesser General Public License version 3 for more details
19  * (a copy is included in the LICENSE file that accompanied this code).
20  *
21  * You should have received a copy of the GNU Lesser General Public License
22  * version 3 along with OpenOffice.org.  If not, see
23  * <http://www.openoffice.org/license.html>
24  * for a copy of the LGPLv3 License.
25  *
26  ************************************************************************/
27 
28 // MARKER(update_precomp.py): autogen include statement, do not remove
29 #include "precompiled_dbaccess.hxx"
30 
31 #ifndef DBAUI_DBWIZ_HXX
32 #include "dbwiz.hxx"
33 #endif
34 #ifndef _DBAUI_DBADMIN_HRC_
35 #include "dbadmin.hrc"
36 #endif
37 #ifndef _DBU_DLG_HRC_
38 #include "dbu_dlg.hrc"
39 #endif
40 #ifndef _DBAUI_DATASOURCEITEMS_HXX_
41 #include "dsitems.hxx"
42 #endif
43 #include "dsnItem.hxx"
44 #ifndef _SFXSTRITEM_HXX
45 #include <svl/stritem.hxx>
46 #endif
47 #ifndef _SFXENUMITEM_HXX
48 #include <svl/eitem.hxx>
49 #endif
50 #ifndef _SFXINTITEM_HXX
51 #include <svl/intitem.hxx>
52 #endif
53 #ifndef _SV_MSGBOX_HXX
54 #include <vcl/msgbox.hxx>
55 #endif
56 #ifndef DBACCESS_SHARED_DBUSTRINGS_HRC
57 #include "dbustrings.hrc"
58 #endif
59 #ifndef _DBAUI_ADMINPAGES_HXX_
60 #include "adminpages.hxx"
61 #endif
62 #ifndef _DBAUI_GENERALPAGE_HXX_
63 #include "generalpage.hxx"
64 #endif
65 #ifndef _DBAUI_LOCALRESACCESS_HXX_
66 #include "localresaccess.hxx"
67 #endif
68 #ifndef _DBAUI_STRINGLISTITEM_HXX_
69 #include "stringlistitem.hxx"
70 #endif
71 #ifndef _DBAUI_PROPERTYSETITEM_HXX_
72 #include "propertysetitem.hxx"
73 #endif
74 #ifndef _UNOTOOLS_CONFIGNODE_HXX_
75 #include <unotools/confignode.hxx>
76 #endif
77 #ifndef DBAUI_CONNECTIONPAGE_HXX
78 #include "ConnectionPage.hxx"
79 #endif
80 #ifndef DBAUI_DRIVERSETTINGS_HXX
81 #include "DriverSettings.hxx"
82 #endif
83 #ifndef _DBAUI_DBADMINIMPL_HXX_
84 #include "DbAdminImpl.hxx"
85 #endif
86 #ifndef _DBA_DBACCESS_HELPID_HRC_
87 #include "dbaccess_helpid.hrc"
88 #endif
89 
90 //.........................................................................
91 namespace dbaui
92 {
93 //.........................................................................
94 using namespace svt;
95 using namespace com::sun::star::uno;
96 using namespace com::sun::star::sdbc;
97 using namespace com::sun::star::lang;
98 using namespace com::sun::star::util;
99 using namespace com::sun::star::beans;
100 using namespace com::sun::star::container;
101 
102 #define START_PAGE                      0
103 #define CONNECTION_PAGE                 1
104 #define ADDITIONAL_PAGE_DBASE           2
105 #define ADDITIONAL_PAGE_FLAT            3
106 #define ADDITIONAL_PAGE_LDAP            4
107 #define ADDITIONAL_PAGE_ADABAS          5
108 #define ADDITIONAL_PAGE_MYSQL_JDBC      6
109 #define ADDITIONAL_PAGE_MYSQL_ODBC      7
110 #define ADDITIONAL_PAGE_ORACLE_JDBC     8
111 #define ADDITIONAL_PAGE_ADO             9
112 #define ADDITIONAL_PAGE_ODBC           10
113 #define ADDITIONAL_USERDEFINED         11
114 #define ADDITIONAL_PAGE_MYSQL_NATIVE   12
115 
116 
117 DBG_NAME(ODbTypeWizDialog)
118 //=========================================================================
119 //= ODbTypeWizDialog
120 //=========================================================================
121 //-------------------------------------------------------------------------
122 ODbTypeWizDialog::ODbTypeWizDialog(Window* _pParent
123                                ,SfxItemSet* _pItems
124                                ,const Reference< XMultiServiceFactory >& _rxORB
125                                ,const ::com::sun::star::uno::Any& _aDataSourceName
126                                )
127     :OWizardMachine(_pParent, ModuleRes(DLG_DATABASE_TYPE_CHANGE), WZB_NEXT | WZB_PREVIOUS | WZB_FINISH | WZB_CANCEL | WZB_HELP )
128     ,m_pOutSet(NULL)
129     ,m_bResetting(sal_False)
130     ,m_bApplied(sal_False)
131     ,m_bUIEnabled( sal_True )
132 {
133     DBG_CTOR(ODbTypeWizDialog,NULL);
134     m_pImpl = ::std::auto_ptr<ODbDataSourceAdministrationHelper>(new ODbDataSourceAdministrationHelper(_rxORB,this,this));
135     m_pImpl->setDataSourceOrName(_aDataSourceName);
136     Reference< XPropertySet > xDatasource = m_pImpl->getCurrentDataSource();
137     m_pOutSet = new SfxItemSet( *_pItems->GetPool(), _pItems->GetRanges() );
138 
139     m_pImpl->translateProperties(xDatasource, *m_pOutSet);
140     m_eType = m_pImpl->getDatasourceType(*m_pOutSet);
141 
142     SetPageSizePixel(LogicToPixel(::Size(PAGE_X, PAGE_Y), MAP_APPFONT));
143     ShowButtonFixedLine(sal_True);
144     defaultButton(WZB_NEXT);
145     enableButtons(WZB_FINISH, sal_False);
146     enableAutomaticNextButtonState( true );
147 
148     m_pPrevPage->SetHelpId(HID_DBWIZ_PREVIOUS);
149     m_pNextPage->SetHelpId(HID_DBWIZ_NEXT);
150     m_pCancel->SetHelpId(HID_DBWIZ_CANCEL);
151     m_pFinish->SetHelpId(HID_DBWIZ_FINISH);
152     m_pHelp->SetUniqueId(UID_DBWIZ_HELP);
153     // no local resources needed anymore
154 
155     DbuTypeCollectionItem* pCollectionItem = PTR_CAST(DbuTypeCollectionItem, _pItems->GetItem(DSID_TYPECOLLECTION));
156     m_pCollection = pCollectionItem->getCollection();
157 
158     FreeResource();
159     ActivatePage();
160 }
161 
162 //-------------------------------------------------------------------------
163 ODbTypeWizDialog::~ODbTypeWizDialog()
164 {
165     DBG_DTOR(ODbTypeWizDialog,NULL);
166     delete m_pOutSet;
167 }
168 //-------------------------------------------------------------------------
169 IMPL_LINK(ODbTypeWizDialog, OnTypeSelected, OGeneralPage*, _pTabPage)
170 {
171     m_eType = _pTabPage->GetSelectedType();
172     const bool bURLRequired = m_pCollection->isConnectionUrlRequired(m_eType);
173     enableButtons(WZB_NEXT,bURLRequired);
174     enableButtons(WZB_FINISH,!bURLRequired);
175     return 1L;
176 }
177 //-------------------------------------------------------------------------
178 WizardTypes::WizardState ODbTypeWizDialog::determineNextState( WizardState _nCurrentState ) const
179 {
180     WizardTypes::WizardState nNextState = WZS_INVALID_STATE;
181     switch(_nCurrentState)
182     {
183         case START_PAGE:
184             switch(m_pCollection->determineType(m_eType))
185             {
186                 case  ::dbaccess::DST_MOZILLA:
187                 case  ::dbaccess::DST_OUTLOOK:
188                 case  ::dbaccess::DST_OUTLOOKEXP:
189                 case  ::dbaccess::DST_EVOLUTION:
190                 case  ::dbaccess::DST_EVOLUTION_GROUPWISE:
191                 case  ::dbaccess::DST_EVOLUTION_LDAP:
192                 case  ::dbaccess::DST_KAB:
193                 case  ::dbaccess::DST_MACAB:
194                     nNextState = WZS_INVALID_STATE;
195                     break;
196                 case  ::dbaccess::DST_MYSQL_NATIVE:
197                     nNextState = ADDITIONAL_PAGE_MYSQL_NATIVE;
198                     break;
199                 default:
200                     nNextState = CONNECTION_PAGE;
201                     break;
202             }
203             break;
204         case CONNECTION_PAGE:
205             switch(m_pCollection->determineType(m_eType))
206             {
207                 case  ::dbaccess::DST_MOZILLA:
208                 case  ::dbaccess::DST_THUNDERBIRD:
209                 case  ::dbaccess::DST_OUTLOOK:
210                 case  ::dbaccess::DST_OUTLOOKEXP:
211                 case  ::dbaccess::DST_EVOLUTION:
212                 case  ::dbaccess::DST_EVOLUTION_GROUPWISE:
213                 case  ::dbaccess::DST_EVOLUTION_LDAP:
214                 case  ::dbaccess::DST_KAB:
215                 case  ::dbaccess::DST_MACAB:
216                 case  ::dbaccess::DST_MSACCESS:
217                 case  ::dbaccess::DST_MSACCESS_2007:
218                 case  ::dbaccess::DST_JDBC:
219                 case  ::dbaccess::DST_CALC:
220                     nNextState = WZS_INVALID_STATE;
221                     break;
222                 case  ::dbaccess::DST_DBASE:
223                     nNextState = ADDITIONAL_PAGE_DBASE;
224                     break;
225                 case  ::dbaccess::DST_FLAT:
226                     nNextState = ADDITIONAL_PAGE_FLAT;
227                     break;
228                 case  ::dbaccess::DST_LDAP:
229                     nNextState = ADDITIONAL_PAGE_LDAP;
230                     break;
231                 case  ::dbaccess::DST_ADABAS:
232                     nNextState = ADDITIONAL_PAGE_ADABAS;
233                     break;
234                 case  ::dbaccess::DST_MYSQL_JDBC:
235                     nNextState = ADDITIONAL_PAGE_MYSQL_JDBC;
236                     break;
237                 case  ::dbaccess::DST_MYSQL_ODBC:
238                     nNextState = ADDITIONAL_PAGE_MYSQL_ODBC;
239                     break;
240                 case  ::dbaccess::DST_ORACLE_JDBC:
241                     nNextState = ADDITIONAL_PAGE_ORACLE_JDBC;
242                     break;
243                 case  ::dbaccess::DST_ADO:
244                     nNextState = ADDITIONAL_PAGE_ADO;
245                     break;
246                 case  ::dbaccess::DST_ODBC:
247                     nNextState = ADDITIONAL_PAGE_ODBC;
248                     break;
249                 default:
250                     nNextState = WZS_INVALID_STATE;
251                     break;
252             }
253             break;
254     }
255 
256     return nNextState;
257 }
258 
259 // -----------------------------------------------------------------------------
260 const SfxItemSet* ODbTypeWizDialog::getOutputSet() const
261 {
262     return m_pOutSet;
263 }
264 // -----------------------------------------------------------------------------
265 SfxItemSet* ODbTypeWizDialog::getWriteOutputSet()
266 {
267     return m_pOutSet;
268 }
269 // -----------------------------------------------------------------------------
270 ::std::pair< Reference<XConnection>,sal_Bool> ODbTypeWizDialog::createConnection()
271 {
272     return m_pImpl->createConnection();
273 }
274 // -----------------------------------------------------------------------------
275 Reference< XMultiServiceFactory > ODbTypeWizDialog::getORB() const
276 {
277     return m_pImpl->getORB();
278 }
279 // -----------------------------------------------------------------------------
280 Reference< XDriver > ODbTypeWizDialog::getDriver()
281 {
282     return m_pImpl->getDriver();
283 }
284 // -----------------------------------------------------------------------------
285 ::rtl::OUString ODbTypeWizDialog::getDatasourceType(const SfxItemSet& _rSet) const
286 {
287     return m_pImpl->getDatasourceType(_rSet);
288 }
289 // -----------------------------------------------------------------------------
290 void ODbTypeWizDialog::clearPassword()
291 {
292     m_pImpl->clearPassword();
293 }
294 
295 // -----------------------------------------------------------------------------
296 TabPage* ODbTypeWizDialog::createPage(WizardState _nState)
297 {
298     sal_uInt16 nStringId = STR_PAGETITLE_ADVANCED;
299     TabPage* pPage = NULL;
300     switch(_nState)
301     {
302         case START_PAGE: // start state
303         {
304             pPage = OGeneralPage::Create(this,*m_pOutSet);
305             OGeneralPage* pGeneralPage = static_cast< OGeneralPage* >( pPage );
306             pGeneralPage->SetTypeSelectHandler( LINK( this, ODbTypeWizDialog, OnTypeSelected));
307 //            pGeneralPage->SetCreationModeHandler( LINK( this, ODbTypeWizDialog, TODO ) );
308             nStringId = STR_PAGETITLE_GENERAL;
309         }
310         break;
311         case CONNECTION_PAGE:
312             pPage = OConnectionTabPage::Create(this,*m_pOutSet);
313             nStringId = STR_PAGETITLE_CONNECTION;
314             break;
315 
316         case ADDITIONAL_PAGE_DBASE:
317             pPage = ODriversSettings::CreateDbase(this,*m_pOutSet);
318             break;
319         case ADDITIONAL_PAGE_FLAT:
320             pPage = ODriversSettings::CreateText(this,*m_pOutSet);
321             break;
322         case ADDITIONAL_PAGE_LDAP:
323             pPage = ODriversSettings::CreateLDAP(this,*m_pOutSet);
324             break;
325         case ADDITIONAL_PAGE_ADABAS:
326             pPage = ODriversSettings::CreateAdabas(this,*m_pOutSet);
327             break;
328         case ADDITIONAL_PAGE_MYSQL_JDBC:
329             pPage = ODriversSettings::CreateMySQLJDBC(this,*m_pOutSet);
330             break;
331         case ADDITIONAL_PAGE_MYSQL_NATIVE:
332             pPage = ODriversSettings::CreateMySQLNATIVE(this,*m_pOutSet);
333             break;
334         case ADDITIONAL_PAGE_MYSQL_ODBC:
335             pPage = ODriversSettings::CreateMySQLODBC(this,*m_pOutSet);
336             break;
337         case ADDITIONAL_PAGE_ORACLE_JDBC:
338             pPage = ODriversSettings::CreateOracleJDBC(this,*m_pOutSet);
339             break;
340         case ADDITIONAL_PAGE_ADO:
341             pPage = ODriversSettings::CreateAdo(this,*m_pOutSet);
342             break;
343         case ADDITIONAL_PAGE_ODBC:
344             pPage = ODriversSettings::CreateODBC(this,*m_pOutSet);
345             break;
346         case ADDITIONAL_USERDEFINED:
347             pPage = ODriversSettings::CreateUser(this,*m_pOutSet);
348             break;
349         default:
350             OSL_ENSURE(0,"Wrong state!");
351             break;
352     }
353 
354     // register ourself as modified listener
355     if ( pPage )
356     {
357         static_cast<OGenericAdministrationPage*>(pPage)->SetServiceFactory(m_pImpl->getORB());
358         static_cast<OGenericAdministrationPage*>(pPage)->SetAdminDialog(this,this);
359         // open our own resource block, as the page titles are strings local to this block
360         LocalResourceAccess aDummy(DLG_DATABASE_ADMINISTRATION, RSC_TABDIALOG);
361 
362         pPage->SetText(String(ModuleRes(nStringId)));
363         defaultButton( _nState == START_PAGE ? WZB_NEXT : WZB_FINISH );
364         enableButtons( WZB_FINISH, _nState == START_PAGE ? sal_False : sal_True);
365         pPage->Show();
366     }
367     return pPage;
368 }
369 // -----------------------------------------------------------------------------
370 sal_Bool ODbTypeWizDialog::leaveState(WizardState _nState)
371 {
372     SfxTabPage* pPage = static_cast<SfxTabPage*>(WizardDialog::GetPage(_nState));
373     if ( pPage )
374         pPage->FillItemSet(*m_pOutSet);
375     return sal_True;
376 }
377 // -----------------------------------------------------------------------------
378 void ODbTypeWizDialog::setTitle(const ::rtl::OUString& _sTitle)
379 {
380     SetText(_sTitle);
381 }
382 //-------------------------------------------------------------------------
383 void ODbTypeWizDialog::enableConfirmSettings( bool _bEnable )
384 {
385     enableButtons( WZB_FINISH, _bEnable );
386     // TODO:
387     // this is hacky. At the moment, this method is used in only one case (#b6532894#).
388     // As soon as it is to be used more wide-spread, we should find a proper concept
389     // for enabling both the Next and Finish buttons, depending on the current page state.
390     // Plus, the concept must also care for the case where those pages are embedded into
391     // anormal tab dialog.
392 }
393 //-------------------------------------------------------------------------
394 sal_Bool ODbTypeWizDialog::saveDatasource()
395 {
396     SfxTabPage* pPage = static_cast<SfxTabPage*>(WizardDialog::GetPage(getCurrentState()));
397     if ( pPage )
398         pPage->FillItemSet(*m_pOutSet);
399 
400     DataSourceInfoConverter aConverter(getORB());
401     ::rtl::OUString sOldURL;
402     if ( m_pImpl->getCurrentDataSource().is() )
403         m_pImpl->getCurrentDataSource()->getPropertyValue(PROPERTY_URL) >>= sOldURL;
404     aConverter.convert(m_pCollection,sOldURL,m_eType,m_pImpl->getCurrentDataSource());
405     return sal_True;
406 }
407 // -----------------------------------------------------------------------------
408 IWizardPageController* ODbTypeWizDialog::getPageController( TabPage* _pCurrentPage ) const
409 {
410     OGenericAdministrationPage* pPage = static_cast<OGenericAdministrationPage*>(_pCurrentPage);
411     return pPage;
412 }
413 // -----------------------------------------------------------------------------
414 sal_Bool ODbTypeWizDialog::onFinish()
415 {
416     saveDatasource();
417     return m_pImpl->saveChanges(*m_pOutSet) ? OWizardMachine::onFinish() : sal_False;
418 }
419 //.........................................................................
420 }   // namespace dbaui
421 //.........................................................................
422