mirror of
https://github.com/fralx/LimeReport.git
synced 2024-12-24 08:34:38 +03:00
Added ability to use variables in the connection settings
This commit is contained in:
parent
f774ab5a49
commit
011b17b537
@ -69,7 +69,7 @@ void ConnectionDialog::slotAccept()
|
|||||||
if (!m_connection){
|
if (!m_connection){
|
||||||
m_controller->addConnectionDesc(uiToConnection());
|
m_controller->addConnectionDesc(uiToConnection());
|
||||||
} else {
|
} else {
|
||||||
m_controller->changeConnectionDesc(uiToConnection());
|
m_controller->changeConnectionDesc(uiToConnection(m_connection));
|
||||||
}
|
}
|
||||||
close();
|
close();
|
||||||
}
|
}
|
||||||
@ -98,35 +98,35 @@ void ConnectionDialog::checkFieldsFill()
|
|||||||
|
|
||||||
bool ConnectionDialog::checkConnection()
|
bool ConnectionDialog::checkConnection()
|
||||||
{
|
{
|
||||||
bool connectionEstablished = false;
|
QScopedPointer<LimeReport::ConnectionDesc> con(uiToConnection());
|
||||||
QString lastError;
|
// LimeReport::ConnectionDesc con;
|
||||||
{
|
// con.setName(ui->leConnectionName->text()+"_check");
|
||||||
QSqlDatabase db = QSqlDatabase::addDatabase(ui->cbbDrivers->currentText(),ui->leConnectionName->text()+"_check");
|
// con.setHost(ui->leServerName->text());
|
||||||
db.setHostName(ui->leServerName->text());
|
// con.setUserName(ui->leUserName->text());
|
||||||
db.setUserName(ui->leUserName->text());
|
// con.setPassword(ui->lePassword->text());
|
||||||
db.setDatabaseName(ui->leDataBase->text());
|
// con.setDatabaseName(ui->leDataBase->text());
|
||||||
db.setPassword(ui->lePassword->text());
|
// con.setDriver(ui->cbbDrivers->currentText());
|
||||||
connectionEstablished = db.open();
|
if (!m_controller->checkConnectionDesc(con.data())){
|
||||||
if (!db.open()) {
|
throw LimeReport::ReportError(m_controller->lastError());
|
||||||
lastError=db.lastError().text();
|
|
||||||
}
|
}
|
||||||
}
|
|
||||||
QSqlDatabase::removeDatabase(ui->leConnectionName->text()+"_check");
|
|
||||||
if (!connectionEstablished) throw LimeReport::ReportError(lastError);
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
LimeReport::ConnectionDesc *ConnectionDialog::uiToConnection()
|
LimeReport::ConnectionDesc *ConnectionDialog::uiToConnection(LimeReport::ConnectionDesc* conDesc)
|
||||||
{
|
{
|
||||||
if (!m_connection) m_connection = new LimeReport::ConnectionDesc();
|
LimeReport::ConnectionDesc* result;
|
||||||
m_connection->setName(ui->leConnectionName->text());
|
if (conDesc)
|
||||||
m_connection->setHost(ui->leServerName->text());
|
result = conDesc;
|
||||||
m_connection->setDriver(ui->cbbDrivers->currentText());
|
else
|
||||||
m_connection->setUserName(ui->leUserName->text());
|
result = new LimeReport::ConnectionDesc();
|
||||||
m_connection->setPassword(ui->lePassword->text());
|
result ->setName(ui->leConnectionName->text());
|
||||||
m_connection->setDatabaseName(ui->leDataBase->text());
|
result ->setHost(ui->leServerName->text());
|
||||||
m_connection->setAutoconnect(ui->cbAutoConnect->isChecked());
|
result ->setDriver(ui->cbbDrivers->currentText());
|
||||||
return m_connection;
|
result ->setUserName(ui->leUserName->text());
|
||||||
|
result ->setPassword(ui->lePassword->text());
|
||||||
|
result ->setDatabaseName(ui->leDataBase->text());
|
||||||
|
result ->setAutoconnect(ui->cbAutoConnect->isChecked());
|
||||||
|
return result ;
|
||||||
}
|
}
|
||||||
|
|
||||||
void ConnectionDialog::connectionToUI()
|
void ConnectionDialog::connectionToUI()
|
||||||
|
@ -48,7 +48,7 @@ protected:
|
|||||||
void init();
|
void init();
|
||||||
void checkFieldsFill();
|
void checkFieldsFill();
|
||||||
bool checkConnection();
|
bool checkConnection();
|
||||||
LimeReport::ConnectionDesc* uiToConnection();
|
LimeReport::ConnectionDesc* uiToConnection(LimeReport::ConnectionDesc *conDesc = 0);
|
||||||
void connectionToUI();
|
void connectionToUI();
|
||||||
signals:
|
signals:
|
||||||
void conectionRegistred(LimeReport::ConnectionDesc* connectionDesc);
|
void conectionRegistred(LimeReport::ConnectionDesc* connectionDesc);
|
||||||
@ -56,7 +56,6 @@ private slots:
|
|||||||
void slotAccept();
|
void slotAccept();
|
||||||
void slotCheckConnection();
|
void slotCheckConnection();
|
||||||
void on_toolButton_clicked();
|
void on_toolButton_clicked();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Ui::ConnectionDialog *ui;
|
Ui::ConnectionDialog *ui;
|
||||||
LimeReport::ConnectionDesc* m_connection;
|
LimeReport::ConnectionDesc* m_connection;
|
||||||
|
@ -595,11 +595,27 @@ void DataBrowser::addConnectionDesc(ConnectionDesc *connection)
|
|||||||
|
|
||||||
void DataBrowser::changeConnectionDesc(ConnectionDesc *connection)
|
void DataBrowser::changeConnectionDesc(ConnectionDesc *connection)
|
||||||
{
|
{
|
||||||
Q_UNUSED(connection)
|
|
||||||
if (connection->autoconnect()) m_report->dataManager()->connectConnection(connection->name());
|
if (connection->autoconnect()) m_report->dataManager()->connectConnection(connection->name());
|
||||||
updateDataTree();
|
updateDataTree();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool DataBrowser::checkConnectionDesc(ConnectionDesc *connection)
|
||||||
|
{
|
||||||
|
bool result = m_report->dataManager()->checkConnectionDesc(connection);
|
||||||
|
if (!result) setLastError(m_report->dataManager()->lastError());
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
QString DataBrowser::lastError() const
|
||||||
|
{
|
||||||
|
return m_lastError;
|
||||||
|
}
|
||||||
|
|
||||||
|
void DataBrowser::setLastError(const QString &lastError)
|
||||||
|
{
|
||||||
|
m_lastError = lastError;
|
||||||
|
}
|
||||||
|
|
||||||
void DataBrowser::on_dataTree_currentItemChanged(QTreeWidgetItem *current, QTreeWidgetItem *previous)
|
void DataBrowser::on_dataTree_currentItemChanged(QTreeWidgetItem *current, QTreeWidgetItem *previous)
|
||||||
{
|
{
|
||||||
Q_UNUSED(previous)
|
Q_UNUSED(previous)
|
||||||
|
@ -59,6 +59,9 @@ public:
|
|||||||
void closeAllDataWindows();
|
void closeAllDataWindows();
|
||||||
void setSettings(QSettings* value, bool owned = false);
|
void setSettings(QSettings* value, bool owned = false);
|
||||||
QSettings* settings();
|
QSettings* settings();
|
||||||
|
QString lastError() const;
|
||||||
|
void setLastError(const QString &lastError);
|
||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
void slotDatasourcesChanged();
|
void slotDatasourcesChanged();
|
||||||
void slotAddConnection();
|
void slotAddConnection();
|
||||||
@ -100,6 +103,7 @@ private:
|
|||||||
|
|
||||||
void addConnectionDesc(ConnectionDesc *connection);
|
void addConnectionDesc(ConnectionDesc *connection);
|
||||||
void changeConnectionDesc(ConnectionDesc *connection);
|
void changeConnectionDesc(ConnectionDesc *connection);
|
||||||
|
bool checkConnectionDesc(ConnectionDesc *connection);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Ui::DataBrowser* ui;
|
Ui::DataBrowser* ui;
|
||||||
@ -109,6 +113,7 @@ private:
|
|||||||
bool m_closingWindows;
|
bool m_closingWindows;
|
||||||
QSettings* m_settings;
|
QSettings* m_settings;
|
||||||
bool m_ownedSettings;
|
bool m_ownedSettings;
|
||||||
|
QString m_lastError;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -341,6 +341,23 @@ QString DataSourceManager::extractField(QString source)
|
|||||||
return source;
|
return source;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
QString DataSourceManager::replaceVariables(QString value){
|
||||||
|
QRegExp rx(Const::VARIABLE_RX);
|
||||||
|
|
||||||
|
if (value.contains(rx)){
|
||||||
|
int pos = -1;
|
||||||
|
while ((pos=rx.indexIn(value))!=-1){
|
||||||
|
QString var=rx.cap(0);
|
||||||
|
var.remove("$V{");
|
||||||
|
var.remove("}");
|
||||||
|
if (variableNames().contains(var)){
|
||||||
|
value.replace(pos,rx.cap(0).length(),variable(var).toString());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
|
||||||
QString DataSourceManager::replaceVariables(QString query, QMap<QString,QString> &aliasesToParam)
|
QString DataSourceManager::replaceVariables(QString query, QMap<QString,QString> &aliasesToParam)
|
||||||
{
|
{
|
||||||
QRegExp rx(Const::VARIABLE_RX);
|
QRegExp rx(Const::VARIABLE_RX);
|
||||||
@ -583,6 +600,15 @@ void DataSourceManager::addConnectionDesc(ConnectionDesc * connection)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool DataSourceManager::checkConnectionDesc(ConnectionDesc *connection)
|
||||||
|
{
|
||||||
|
if (connectConnection(connection)){
|
||||||
|
QSqlDatabase::removeDatabase(connection->name());
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
void DataSourceManager::addQueryDesc(QueryDesc *query)
|
void DataSourceManager::addQueryDesc(QueryDesc *query)
|
||||||
{
|
{
|
||||||
m_queries.append(query);
|
m_queries.append(query);
|
||||||
@ -633,10 +659,10 @@ bool DataSourceManager::connectConnection(ConnectionDesc *connectionDesc)
|
|||||||
if (!QSqlDatabase::contains(connectionDesc->name())){
|
if (!QSqlDatabase::contains(connectionDesc->name())){
|
||||||
{
|
{
|
||||||
QSqlDatabase db = QSqlDatabase::addDatabase(connectionDesc->driver(),connectionDesc->name());
|
QSqlDatabase db = QSqlDatabase::addDatabase(connectionDesc->driver(),connectionDesc->name());
|
||||||
db.setHostName(connectionDesc->host());
|
db.setHostName(replaceVariables(connectionDesc->host()));
|
||||||
db.setUserName(connectionDesc->userName());
|
db.setUserName(replaceVariables(connectionDesc->userName()));
|
||||||
db.setPassword(connectionDesc->password());
|
db.setPassword(replaceVariables(connectionDesc->password()));
|
||||||
db.setDatabaseName(connectionDesc->databaseName());
|
db.setDatabaseName(replaceVariables(connectionDesc->databaseName()));
|
||||||
connected=db.open();
|
connected=db.open();
|
||||||
if (!connected) lastError=db.lastError().text();
|
if (!connected) lastError=db.lastError().text();
|
||||||
}
|
}
|
||||||
|
@ -108,6 +108,7 @@ public:
|
|||||||
void connectAllDatabases();
|
void connectAllDatabases();
|
||||||
void addConnection(const QString& connectionName);
|
void addConnection(const QString& connectionName);
|
||||||
void addConnectionDesc(ConnectionDesc *);
|
void addConnectionDesc(ConnectionDesc *);
|
||||||
|
bool checkConnectionDesc(ConnectionDesc *connection);
|
||||||
void addQuery(const QString& name, const QString& sqlText, const QString& connectionName="");
|
void addQuery(const QString& name, const QString& sqlText, const QString& connectionName="");
|
||||||
void addSubQuery(const QString& name, const QString& sqlText, const QString& connectionName, const QString& masterDatasource);
|
void addSubQuery(const QString& name, const QString& sqlText, const QString& connectionName, const QString& masterDatasource);
|
||||||
void addProxy(const QString& name, QString master, QString detail, QList<FieldsCorrelation> fields);
|
void addProxy(const QString& name, QString master, QString detail, QList<FieldsCorrelation> fields);
|
||||||
@ -179,6 +180,7 @@ public:
|
|||||||
|
|
||||||
QString extractField(QString source);
|
QString extractField(QString source);
|
||||||
QString replaceVariables(QString query, QMap<QString, QString> &aliasesToParam);
|
QString replaceVariables(QString query, QMap<QString, QString> &aliasesToParam);
|
||||||
|
QString replaceVariables(QString value);
|
||||||
QString replaceFields(QString query, QMap<QString, QString> &aliasesToParam, QString masterDatasource = "");
|
QString replaceFields(QString query, QMap<QString, QString> &aliasesToParam, QString masterDatasource = "");
|
||||||
QSharedPointer<QAbstractItemModel> previewSQL(const QString& connectionName, const QString& sqlText, QString masterDatasource="");
|
QSharedPointer<QAbstractItemModel> previewSQL(const QString& connectionName, const QString& sqlText, QString masterDatasource="");
|
||||||
|
|
||||||
@ -206,6 +208,7 @@ protected:
|
|||||||
void setSystemVariable(const QString& name, const QVariant& value, RenderPass pass);
|
void setSystemVariable(const QString& name, const QVariant& value, RenderPass pass);
|
||||||
void setLastError(const QString& value);
|
void setLastError(const QString& value);
|
||||||
void invalidateLinkedDatasources(QString datasourceName);
|
void invalidateLinkedDatasources(QString datasourceName);
|
||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
void slotConnectionRenamed(const QString& oldName,const QString& newName);
|
void slotConnectionRenamed(const QString& oldName,const QString& newName);
|
||||||
private:
|
private:
|
||||||
|
Loading…
Reference in New Issue
Block a user