diff options
author | Javier S. Pedro <maemo@javispedro.com> | 2013-04-02 18:36:21 +0200 |
---|---|---|
committer | Javier S. Pedro <maemo@javispedro.com> | 2013-04-02 18:36:21 +0200 |
commit | ea2ac1ddd74c1d97f094a4e56f2c038b5fef6351 (patch) | |
tree | 92376ef4a33ef46d9ab6d464732e0ca06d2cee1e /fetchconfigaction.cpp | |
parent | 70afca89b21dda18dc5e94858bec472da9130cda (diff) | |
download | tapasboard-ea2ac1ddd74c1d97f094a4e56f2c038b5fef6351.tar.gz tapasboard-ea2ac1ddd74c1d97f094a4e56f2c038b5fef6351.zip |
add some support for smilies
Diffstat (limited to 'fetchconfigaction.cpp')
-rw-r--r-- | fetchconfigaction.cpp | 56 |
1 files changed, 56 insertions, 0 deletions
diff --git a/fetchconfigaction.cpp b/fetchconfigaction.cpp new file mode 100644 index 0000000..8c0ac63 --- /dev/null +++ b/fetchconfigaction.cpp @@ -0,0 +1,56 @@ +#include <QtCore/QDateTime> +#include <QtCore/QDebug> +#include <QtSql/QSqlQuery> + +#include "board.h" +#include "xmlrpcinterface.h" +#include "xmlrpcreply.h" +#include "fetchconfigaction.h" + +FetchConfigAction::FetchConfigAction(Board *board) : + Action(board) +{ +} + +bool FetchConfigAction::isSupersetOf(Action *action) const +{ + // If 'action' is also a fetch board config action then yes, this supersets 'action'. + return qobject_cast<FetchConfigAction*>(action) != 0; +} + +void FetchConfigAction::execute() +{ + _call = _board->service()->asyncCall("get_config"); + connect(_call, SIGNAL(finished(XmlRpcPendingCall*)), SLOT(handleFinishedCall())); +} + +void FetchConfigAction::handleFinishedCall() +{ + XmlRpcReply<QVariantMap> result(_call); + if (result.isValid()) { + QVariantMap map = result; + QSqlDatabase db = _board->database(); + db.transaction(); + QSqlQuery query(db); + + // Let's add some of our config settings + map["last_config_fetch"] = QDateTime::currentDateTimeUtc().toString(Qt::ISODate); + map["tapasboard_db_version"] = Board::CURRENT_DB_VERSION; + + query.prepare("INSERT OR REPLACE INTO config (key, value) VALUES (:key, :value)"); + for (QVariantMap::iterator i = map.begin(); i != map.end(); i++) { + query.bindValue(":key", i.key()); + query.bindValue(":value", i.value().toString()); + if (!query.exec()) { + qWarning() << "Failed to set config key:" << i.key(); + } + } + db.commit(); + _board->notifyConfigChanged(); + } else { + qWarning() << "Could not fetch board configuration"; + // TODO emit error ... + } + emit finished(this); + _call->deleteLater(); +} |