All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
ADOConnectorDialog.cpp
Go to the documentation of this file.
1 /* Copyright (C) 2011-2012 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 <QtGui/QFileDialog>
45 #include <QtGui/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  m_ui->m_providerComboBox->addItem("Microsoft.Jet.OLEDB.4.0");
56 
57 // connect signal and slots
58  connect(m_ui->m_openPushButton, SIGNAL(pressed()), this, SLOT(openPushButtonPressed()));
59  connect(m_ui->m_testPushButton, SIGNAL(pressed()), this, SLOT(testPushButtonPressed()));
60  //connect(m_ui->m_helpPushButton, SIGNAL(pressed()), this, SLOT(helpPushButtonPressed()));
61  connect(m_ui->m_searchDatabaseToolButton, SIGNAL(pressed()), this, SLOT(searchDatabaseToolButtonPressed()));
62 
63  m_ui->m_helpPushButton->setNameSpace("dpi.inpe.br.plugins");
64  m_ui->m_helpPushButton->setPageReference("plugins/ado/ado.html");
65 }
66 
68 {
69 }
70 
72 {
73  return m_datasource;
74 }
75 
77 {
78  return m_driver;
79 }
80 
82 {
83  m_datasource = ds;
84 
85  if(m_datasource.get() != 0)
86  {
87  setConnectionInfo(m_datasource->getConnInfo());
88 
89  m_ui->m_datasourceTitleLineEdit->setText(QString::fromStdString(m_datasource->getTitle()));
90 
91  m_ui->m_datasourceDescriptionTextEdit->setText(QString::fromStdString(m_datasource->getDescription()));
92  }
93 }
94 
96 {
97  try
98  {
99 // check if driver is loaded
100  if(te::da::DataSourceFactory::find("ADO") == 0)
101  throw te::qt::widgets::Exception(TR_QT_WIDGETS("Sorry! No data access driver loaded for ADO data sources!"));
102 
103 // get data source connection info based on form data
104  std::map<std::string, std::string> dsInfo;
105 
106  getConnectionInfo(dsInfo);
107 
108 // perform connection
109  //m_driver.reset(te::da::DataSourceFactory::open("ADO", dsInfo));
110  std::auto_ptr<te::da::DataSource> ds = te::da::DataSourceFactory::make("ADO");
111  ds->setConnectionInfo(dsInfo);
112  ds->open();
113  m_driver.reset(ds.release());
114 
115  if(m_driver.get() == 0)
116  throw te::qt::widgets::Exception(TR_QT_WIDGETS("Could not open ADO data source due to an unknown error!"));
117 
118  QString title = m_ui->m_datasourceTitleLineEdit->text().trimmed();
119 
120  if(title.isEmpty())
121  title = m_ui->m_fileLineEdit->text().trimmed();
122 
123  if(m_datasource.get() == 0)
124  {
125 // create a new data source based on form data
126  m_datasource.reset(new te::da::DataSourceInfo);
127 
128  m_datasource->setConnInfo(dsInfo);
129 
130  boost::uuids::basic_random_generator<boost::mt19937> gen;
131  boost::uuids::uuid u = gen();
132  std::string dsId = boost::uuids::to_string(u);
133 
134  m_datasource->setId(dsId);
135  m_driver->setId(dsId);
136  m_datasource->setTitle(title.toUtf8().data());
137  m_datasource->setDescription(m_ui->m_datasourceDescriptionTextEdit->toPlainText().trimmed().toUtf8().data());
138  m_datasource->setAccessDriver("ADO");
139  m_datasource->setType("ADO");
140  }
141  else
142  {
143  m_driver->setId(m_datasource->getId());
144  m_datasource->setConnInfo(dsInfo);
145  m_datasource->setTitle(title.toUtf8().data());
146  m_datasource->setDescription(m_ui->m_datasourceDescriptionTextEdit->toPlainText().trimmed().toUtf8().data());
147  }
148  }
149  catch(const std::exception& e)
150  {
151  QMessageBox::warning(this,
152  tr("TerraLib Qt Components"),
153  tr(e.what()));
154  return;
155  }
156  catch(...)
157  {
158  QMessageBox::warning(this,
159  tr("TerraLib Qt Components"),
160  tr("Unknown error while opening ADO database!"));
161  return;
162  }
163 
164  accept();
165 }
166 
168 {
169  try
170  {
171 // check if driver is loaded
172  if(te::da::DataSourceFactory::find("ADO") == 0)
173  throw te::qt::widgets::Exception(TR_QT_WIDGETS("Sorry! No data access driver loaded for ADO data sources!"));
174 
175 // get data source connection info based on form data
176  std::map<std::string, std::string> dsInfo;
177 
178  getConnectionInfo(dsInfo);
179 
180 // perform connection
181  //std::auto_ptr<te::da::DataSource> ds(te::da::DataSourceFactory::open("ADO", dsInfo));
182  std::auto_ptr<te::da::DataSource> ds(te::da::DataSourceFactory::make("ADO"));
183  ds->setConnectionInfo(dsInfo);
184  ds->open();
185 
186  if(ds.get() == 0)
187  throw te::qt::widgets::Exception(TR_QT_WIDGETS("Could not open ADO database!"));
188 
189  QMessageBox::warning(this,
190  tr("TerraLib Qt Components"),
191  tr("Data source is ok!"));
192  }
193  catch(const std::exception& e)
194  {
195  QMessageBox::warning(this,
196  tr("TerraLib Qt Components"),
197  tr(e.what()));
198  }
199  catch(...)
200  {
201  QMessageBox::warning(this,
202  tr("TerraLib Qt Components"),
203  tr("Unknown error while testing ADO data source!"));
204  }
205 }
206 
208 {
209  QMessageBox::warning(this,
210  tr("TerraLib Qt Components"),
211  tr("Not implemented yet!\nWe will provide it soon!"));
212 }
213 
215 {
216  QString fileName = QFileDialog::getOpenFileName(this, tr("Open ADO Database"), te::qt::widgets::GetFilePathFromSettings("vector"), tr("Database files (*.accdb *.mdb);; All Files (*.*)"), 0, QFileDialog::ReadOnly);
217 
218  if(fileName.isEmpty())
219  return;
220 
221  m_ui->m_fileLineEdit->setText(fileName);
222 
223  QFileInfo info(fileName);
224 
225  te::qt::widgets::AddFilePathToSettings(info.absolutePath(), "vector");
226 }
227 
228 void te::qt::plugins::ado::ADOConnectorDialog::getConnectionInfo(std::map<std::string, std::string>& connInfo) const
229 {
230 // clear input
231  connInfo.clear();
232 
233  QString qstr = m_ui->m_fileLineEdit->text().trimmed();
234 
235  if(!qstr.isEmpty())
236  connInfo["DB_NAME"] = qstr.toStdString();
237 
238  qstr = m_ui->m_passwordLineEdit->text().trimmed();
239 
240  if(!qstr.isEmpty())
241  connInfo["PASSWORD"] = qstr.toStdString();
242 
243  qstr = m_ui->m_providerComboBox->currentText().trimmed();
244 
245  if(!qstr.isEmpty())
246  connInfo["PROVIDER"] = qstr.toStdString();
247 }
248 
249 void te::qt::plugins::ado::ADOConnectorDialog::setConnectionInfo(const std::map<std::string, std::string>& connInfo)
250 {
251  std::map<std::string, std::string>::const_iterator it = connInfo.find("DB_NAME");
252  std::map<std::string, std::string>::const_iterator itend = connInfo.end();
253 
254  if(it != itend)
255  m_ui->m_fileLineEdit->setText(it->second.c_str());
256 
257  it = connInfo.find("PASSWORD");
258 
259  m_ui->m_passwordLineEdit->setText(it->second.c_str());
260 }
ADOConnectorDialog(QWidget *parent=0, Qt::WindowFlags f=0)
TEQTWIDGETSEXPORT QString GetFilePathFromSettings(const QString &typeFile)
Returns the value of the last saved file path for the typeFile required.
Definition: Utils.cpp:360
A class that represents a data source component.
std::auto_ptr< Ui::ADOConnectorDialogForm > m_ui
TEQTWIDGETSEXPORT void AddFilePathToSettings(const QString &path, const QString &typeFile)
Save last used path in QSettings.
Definition: Utils.cpp:351
static std::auto_ptr< DataSource > make(const std::string &dsType)
void getConnectionInfo(std::map< std::string, std::string > &connInfo) const
static bool find(const std::string &dsType)
const te::da::DataSourceInfoPtr & getDataSource() const
boost::shared_ptr< DataSource > DataSourcePtr
Definition: DataSource.h:1395
#define TR_QT_WIDGETS(message)
It marks a string in order to get translated. This is a special mark used in the TerraLib Qt Widgets ...
Definition: Config.h:60
const te::da::DataSourcePtr & getDriver() const
void setConnectionInfo(const std::map< std::string, std::string > &connInfo)
boost::shared_ptr< DataSourceInfo > DataSourceInfoPtr
void set(const te::da::DataSourceInfoPtr &ds)