forked from mirrors/linphone-iphone
227 lines
5.6 KiB
C++
227 lines
5.6 KiB
C++
/*
|
|
* db-session.cpp
|
|
* Copyright (C) 2010-2018 Belledonne Communications SARL
|
|
*
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU General Public License
|
|
* as published by the Free Software Foundation; either version 2
|
|
* of the License, or (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
*/
|
|
|
|
#include "linphone/utils/utils.h"
|
|
|
|
#include "db-session-p.h"
|
|
#include "logger/logger.h"
|
|
|
|
// =============================================================================
|
|
|
|
using namespace std;
|
|
|
|
LINPHONE_BEGIN_NAMESPACE
|
|
|
|
DbSession::DbSession () : ClonableObject(*new DbSessionPrivate) {}
|
|
|
|
DbSession::DbSession (const string &uri) : DbSession() {
|
|
#ifdef SOCI_ENABLED
|
|
try {
|
|
L_D();
|
|
d->backendSession = makeUnique<soci::session>(uri);
|
|
d->backend = !uri.find("mysql") ? DbSessionPrivate::Backend::Mysql : DbSessionPrivate::Backend::Sqlite3;
|
|
} catch (const exception &e) {
|
|
lWarning() << "Unable to build db session with uri: " << e.what();
|
|
}
|
|
#else
|
|
lWarning() << "Unable to build db session with uri: soci not enabled.";
|
|
#endif // ifdef SOCI_ENABLED
|
|
}
|
|
|
|
DbSession::operator bool () const {
|
|
L_D();
|
|
return d->backend != DbSessionPrivate::Backend::None;
|
|
}
|
|
|
|
L_USE_DEFAULT_CLONABLE_OBJECT_SHARED_IMPL(DbSession);
|
|
|
|
soci::session *DbSession::getBackendSession () const {
|
|
#ifdef SOCI_ENABLED
|
|
L_D();
|
|
return d->backendSession.get();
|
|
#else
|
|
return nullptr;
|
|
#endif // ifdef SOCI_ENABLED
|
|
}
|
|
|
|
string DbSession::primaryKeyStr (const string &type) const {
|
|
L_D();
|
|
|
|
switch (d->backend) {
|
|
case DbSessionPrivate::Backend::Mysql:
|
|
return " " + type + " AUTO_INCREMENT PRIMARY KEY";
|
|
case DbSessionPrivate::Backend::Sqlite3:
|
|
// See: ROWIDs and the INTEGER PRIMARY KEY
|
|
// https://www.sqlite.org/lang_createtable.html
|
|
return " INTEGER PRIMARY KEY ASC";
|
|
case DbSessionPrivate::Backend::None:
|
|
return "";
|
|
}
|
|
|
|
L_ASSERT(false);
|
|
return "";
|
|
}
|
|
|
|
string DbSession::primaryKeyRefStr (const string &type) const {
|
|
L_D();
|
|
|
|
switch (d->backend) {
|
|
case DbSessionPrivate::Backend::Mysql:
|
|
return " " + type;
|
|
case DbSessionPrivate::Backend::Sqlite3:
|
|
return " INTEGER";
|
|
case DbSessionPrivate::Backend::None:
|
|
return "";
|
|
}
|
|
|
|
L_ASSERT(false);
|
|
return "";
|
|
}
|
|
|
|
string DbSession::varcharPrimaryKeyStr (int length) const {
|
|
L_D();
|
|
|
|
switch (d->backend) {
|
|
case DbSessionPrivate::Backend::Mysql:
|
|
return " VARCHAR(" + Utils::toString(length) + ") PRIMARY KEY";
|
|
case DbSessionPrivate::Backend::Sqlite3:
|
|
return " VARCHAR(" + Utils::toString(length) + ") PRIMARY KEY";
|
|
case DbSessionPrivate::Backend::None:
|
|
return "";
|
|
}
|
|
|
|
L_ASSERT(false);
|
|
return "";
|
|
}
|
|
|
|
string DbSession::timestampType () const {
|
|
L_D();
|
|
|
|
switch (d->backend) {
|
|
case DbSessionPrivate::Backend::Mysql:
|
|
return " TIMESTAMP";
|
|
case DbSessionPrivate::Backend::Sqlite3:
|
|
return " DATE";
|
|
case DbSessionPrivate::Backend::None:
|
|
return "";
|
|
}
|
|
|
|
L_ASSERT(false);
|
|
return "";
|
|
}
|
|
|
|
string DbSession::noLimitValue () const {
|
|
L_D();
|
|
|
|
switch (d->backend) {
|
|
case DbSessionPrivate::Backend::Mysql:
|
|
return "9999999999999999999";
|
|
case DbSessionPrivate::Backend::Sqlite3:
|
|
return "-1";
|
|
case DbSessionPrivate::Backend::None:
|
|
return "";
|
|
}
|
|
|
|
L_ASSERT(false);
|
|
return "";
|
|
}
|
|
|
|
long long DbSession::getLastInsertId () const {
|
|
long long id = 0;
|
|
|
|
L_D();
|
|
|
|
string sql;
|
|
switch (d->backend) {
|
|
case DbSessionPrivate::Backend::Mysql:
|
|
sql = "SELECT LAST_INSERT_ID()";
|
|
break;
|
|
case DbSessionPrivate::Backend::Sqlite3:
|
|
sql = "SELECT last_insert_rowid()";
|
|
break;
|
|
case DbSessionPrivate::Backend::None:
|
|
break;
|
|
}
|
|
|
|
#ifdef SOCI_ENABLED
|
|
*d->backendSession << sql, soci::into(id);
|
|
#endif // ifdef SOCI_ENABLED
|
|
|
|
return id;
|
|
}
|
|
|
|
void DbSession::enableForeignKeys (bool status) {
|
|
#ifdef SOCI_ENABLED
|
|
L_D();
|
|
switch (d->backend) {
|
|
case DbSessionPrivate::Backend::Mysql:
|
|
*d->backendSession << string("SET FOREIGN_KEY_CHECKS = ") + (status ? "1" : "0");
|
|
break;
|
|
case DbSessionPrivate::Backend::Sqlite3:
|
|
*d->backendSession << string("PRAGMA foreign_keys = ") + (status ? "ON" : "OFF");
|
|
break;
|
|
case DbSessionPrivate::Backend::None:
|
|
break;
|
|
}
|
|
#endif // ifdef SOCI_ENABLED
|
|
}
|
|
|
|
bool DbSession::checkTableExists (const string &table) const {
|
|
#ifdef SOCI_ENABLED
|
|
L_D();
|
|
soci::session *session = d->backendSession.get();
|
|
switch (d->backend) {
|
|
case DbSessionPrivate::Backend::Mysql:
|
|
*session << "SHOW TABLES LIKE :table", soci::use(table);
|
|
return session->got_data() > 0;
|
|
case DbSessionPrivate::Backend::Sqlite3:
|
|
*session << "SELECT name FROM sqlite_master WHERE type='table' AND name=:table", soci::use(table);
|
|
return session->got_data() > 0;
|
|
case DbSessionPrivate::Backend::None:
|
|
return false;
|
|
}
|
|
L_ASSERT(false);
|
|
#else
|
|
(void)table;
|
|
#endif // ifdef SOCI_ENABLED
|
|
|
|
return false;
|
|
}
|
|
|
|
long long DbSession::resolveId (const soci::row &row, int col) const {
|
|
#ifdef SOCI_ENABLED
|
|
L_D();
|
|
switch (d->backend) {
|
|
case DbSessionPrivate::Backend::Mysql:
|
|
return static_cast<long long>(row.get<unsigned long long>(0));
|
|
case DbSessionPrivate::Backend::Sqlite3:
|
|
return static_cast<long long>(row.get<int>(0));
|
|
case DbSessionPrivate::Backend::None:
|
|
return 0;
|
|
}
|
|
L_ASSERT(false);
|
|
#else
|
|
(void)row;
|
|
(void)col;
|
|
#endif // ifdef SOCI_ENABLED
|
|
|
|
return 0;
|
|
}
|
|
|
|
LINPHONE_END_NAMESPACE
|