All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
ADOConnectorDialog.cpp
Go to the documentation of this file.
1 /* Copyright (C) 2008 National Institute For Space Research (INPE) - Brazil.
2 
3  This file is part of the TerraLib - a Framework for building GIS enabled applications.
4 
5  TerraLib is free software: you can redistribute it and/or modify
6  it under the terms of the GNU Lesser General Public License as published by
7  the Free Software Foundation, either version 3 of the License,
8  or (at your option) any later version.
9 
10  TerraLib is distributed in the hope that it will be useful,
11  but WITHOUT ANY WARRANTY; without even the implied warranty of
12  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13  GNU Lesser General Public License for more details.
14 
15  You should have received a copy of the GNU Lesser General Public License
16  along with TerraLib. See COPYING. If not, write to
17  TerraLib Team at <terralib-team@terralib.org>.
18  */
19 
20 /*!
21  \file terralib/qt/widgets/connector/ado/ADOConnectorDialog.cpp
22 
23  \brief ....
24 */
25 
26 // TerraLib
27 #include "../../../../common/Translator.h"
28 #include "../../../../dataaccess/datasource/DataSource.h"
29 #include "../../../../dataaccess/datasource/DataSourceFactory.h"
30 #include "../../../../dataaccess/datasource/DataSourceInfo.h"
31 #include "../../../../dataaccess/datasource/DataSourceManager.h"
32 #include "../../../widgets/Exception.h"
33 #include "../../../widgets/Utils.h"
34 #include "ui_ADOConnectorDialogForm.h"
35 #include "ADOConnectorDialog.h"
36 
37 // Boost
38 #include <boost/algorithm/string/case_conv.hpp>
39 #include <boost/lexical_cast.hpp>
40 #include <boost/uuid/random_generator.hpp>
41 #include <boost/uuid/uuid_io.hpp>
42 
43 // Qt
44 #include <QFileDialog>
45 #include <QMessageBox>
46 
48  : QDialog(parent, f),
49  m_ui(new Ui::ADOConnectorDialogForm)
50 {
51 // add controls
52  m_ui->setupUi(this);
53 
54 // popule providers
55 #ifdef _M_IX86
56  m_ui->m_providerComboBox->addItem("Microsoft.Jet.OLEDB.4.0");
57 #else
58  m_ui->m_providerComboBox->addItem("Microsoft.ACE.OLEDB.12.0");
59 #endif
60 
61 // connect signal and slots
62  connect(m_ui->m_openPushButton, SIGNAL(pressed()), this, SLOT(openPushButtonPressed()));
63  connect(m_ui->m_testPushButton, SIGNAL(pressed()), this, SLOT(testPushButtonPressed()));
64  //connect(m_ui->m_helpPushButton, SIGNAL(pressed()), this, SLOT(helpPushButtonPressed()));
65  connect(m_ui->m_searchDatabaseToolButton, SIGNAL(pressed()), this, SLOT(searchDatabaseToolButtonPressed()));
66 
67  m_ui->m_helpPushButton->setNameSpace("dpi.inpe.br.plugins");
68  m_ui->m_helpPushButton->setPageReference("plugins/ado/ado.html");
69 
70  if(op == UPDATE)
71  m_ui->m_openPushButton->setText(TE_TR("Update"));
72 }
73 
75 {
76 }
77 
79 {
80  return m_datasource;
81 }
82 
84 {
85  return m_driver;
86 }
87 
89 {
90  m_datasource = ds;
91 
92  if(m_datasource.get() != 0)
93  {
94  setConnectionInfo(m_datasource->getConnInfo());
95 
96  m_ui->m_datasourceTitleLineEdit->setText(QString::fromStdString(m_datasource->getTitle()));
97 
98  m_ui->m_datasourceDescriptionTextEdit->setText(QString::fromStdString(m_datasource->getDescription()));
99  }
100 }
101 
103 {
104  try
105  {
106 // check if driver is loaded
107  if(te::da::DataSourceFactory::find("ADO") == 0)
108  throw te::qt::widgets::Exception(TE_TR("Sorry! No data access driver loaded for ADO data sources!"));
109 
110 // perform connection
111  //m_driver.reset(te::da::DataSourceFactory::open("ADO", dsInfo));
112  std::auto_ptr<te::da::DataSource> ds = te::da::DataSourceFactory::make("ADO");
113  ds->setConnectionInfo(getConnectionInfo(true));
114  ds->open();
115  m_driver.reset(ds.release());
116 
117  if(m_driver.get() == 0)
118  throw te::qt::widgets::Exception(TE_TR("Could not open ADO data source due to an unknown error!"));
119 
120  QString title = m_ui->m_datasourceTitleLineEdit->text().trimmed();
121 
122  if(title.isEmpty())
123  title = m_ui->m_fileLineEdit->text().trimmed();
124 
125  if(m_datasource.get() == 0)
126  {
127 // create a new data source based on form data
128  m_datasource.reset(new te::da::DataSourceInfo);
129 
130  m_datasource->setConnInfo(getConnectionInfo(m_ui->m_savePasswordCheckBox->isChecked()));
131 
132  boost::uuids::basic_random_generator<boost::mt19937> gen;
133  boost::uuids::uuid u = gen();
134  std::string dsId = boost::uuids::to_string(u);
135 
136  m_datasource->setId(dsId);
137  m_driver->setId(dsId);
138  m_datasource->setTitle(title.toUtf8().data());
139  m_datasource->setDescription(m_ui->m_datasourceDescriptionTextEdit->toPlainText().trimmed().toUtf8().data());
140  m_datasource->setAccessDriver("ADO");
141  m_datasource->setType("ADO");
142  }
143  else
144  {
145  m_driver->setId(m_datasource->getId());
146  m_datasource->setConnInfo(getConnectionInfo(m_ui->m_savePasswordCheckBox->isChecked()));
147  m_datasource->setTitle(title.toUtf8().data());
148  m_datasource->setDescription(m_ui->m_datasourceDescriptionTextEdit->toPlainText().trimmed().toUtf8().data());
149  }
150  }
151  catch(const std::exception& e)
152  {
153  QMessageBox::warning(this,
154  tr("TerraLib Qt Components"),
155  tr(e.what()));
156  return;
157  }
158  catch(...)
159  {
160  QMessageBox::warning(this,
161  tr("TerraLib Qt Components"),
162  tr("Unknown error while opening ADO database!"));
163  return;
164  }
165 
166  accept();
167 }
168 
170 {
171  try
172  {
173 // check if driver is loaded
174  if(te::da::DataSourceFactory::find("ADO") == 0)
175  throw te::qt::widgets::Exception(TE_TR("Sorry! No data access driver loaded for ADO data sources!"));
176 
177 // perform connection
178  //std::auto_ptr<te::da::DataSource> ds(te::da::DataSourceFactory::open("ADO", dsInfo));
179  std::auto_ptr<te::da::DataSource> ds(te::da::DataSourceFactory::make("ADO"));
180  ds->setConnectionInfo(getConnectionInfo(true));
181  ds->open();
182 
183  if(ds.get() == 0)
184  throw te::qt::widgets::Exception(TE_TR("Could not open ADO database!"));
185 
186  QMessageBox::warning(this,
187  tr("TerraLib Qt Components"),
188  tr("Data source is ok!"));
189  }
190  catch(const std::exception& e)
191  {
192  QMessageBox::warning(this,
193  tr("TerraLib Qt Components"),
194  tr(e.what()));
195  }
196  catch(...)
197  {
198  QMessageBox::warning(this,
199  tr("TerraLib Qt Components"),
200  tr("Unknown error while testing ADO data source!"));
201  }
202 }
203 
205 {
206  QMessageBox::warning(this,
207  tr("TerraLib Qt Components"),
208  tr("Not implemented yet!\nWe will provide it soon!"));
209 }
210 
212 {
213  QString fileName = QFileDialog::getOpenFileName(this, tr("Open ADO Database"), te::qt::widgets::GetFilePathFromSettings("vector"), tr("Database files (*.accdb *.mdb);; All Files (*.*)"), 0, QFileDialog::ReadOnly);
214 
215  if(fileName.isEmpty())
216  return;
217 
218  m_ui->m_fileLineEdit->setText(fileName);
219 
220  QFileInfo info(fileName);
221 
222  te::qt::widgets::AddFilePathToSettings(info.absolutePath(), "vector");
223 }
224 
225 std::map<std::string, std::string> te::qt::plugins::ado::ADOConnectorDialog::getConnectionInfo(bool getPrivateKeys) const
226 {
227  std::map<std::string, std::string> connInfo;
228 
229  QString qstr = m_ui->m_fileLineEdit->text().trimmed();
230 
231  if(!qstr.isEmpty())
232  connInfo["DB_NAME"] = qstr.toStdString();
233 
234  if(getPrivateKeys)
235  {
236  qstr = m_ui->m_passwordLineEdit->text().trimmed();
237 
238  if(!qstr.isEmpty())
239  connInfo["PASSWORD"] = qstr.toStdString();
240  }
241 
242  qstr = m_ui->m_providerComboBox->currentText().trimmed();
243 
244  if(!qstr.isEmpty())
245  connInfo["PROVIDER"] = qstr.toStdString();
246 
247  return connInfo;
248 }
249 
250 void te::qt::plugins::ado::ADOConnectorDialog::setConnectionInfo(const std::map<std::string, std::string>& connInfo)
251 {
252  std::map<std::string, std::string>::const_iterator it = connInfo.find("DB_NAME");
253  std::map<std::string, std::string>::const_iterator itend = connInfo.end();
254 
255  if(it != itend)
256  m_ui->m_fileLineEdit->setText(it->second.c_str());
257 
258  it = connInfo.find("PASSWORD");
259 
260  if(it != itend)
261  m_ui->m_passwordLineEdit->setText(it->second.c_str());
262 }
static bool find(const std::string &dsType)
boost::shared_ptr< DataSource > DataSourcePtr
Definition: DataSource.h:1435
TEQTWIDGETSEXPORT void AddFilePathToSettings(const QString &path, const QString &typeFile)
Save last used path in QSettings.
Definition: Utils.cpp:367
const te::da::DataSourcePtr & getDriver() const
#define TE_TR(message)
It marks a string in order to get translated.
Definition: Translator.h:347
ADOConnectorDialog(QWidget *parent=0, Qt::WindowFlags f=0, Operation op=CONNECTION)
std::auto_ptr< Ui::ADOConnectorDialogForm > m_ui
static std::auto_ptr< DataSource > make(const std::string &dsType)
void set(const te::da::DataSourceInfoPtr &ds)
A class that represents a data source component.
TEQTWIDGETSEXPORT QString GetFilePathFromSettings(const QString &typeFile)
Returns the value of the last saved file path for the typeFile required.
Definition: Utils.cpp:376
void setConnectionInfo(const std::map< std::string, std::string > &connInfo)
std::map< std::string, std::string > getConnectionInfo(bool getPrivateKeys) const
const te::da::DataSourceInfoPtr & getDataSource() const
boost::shared_ptr< DataSourceInfo > DataSourceInfoPtr