/* * Copyright (C) 2015 Aaron Seigo * Copyright (C) 2015 Christian Mollekopf * * 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 "sinksh_utils.h" #include "common/clientapi.h" #include "utils.h" namespace SinkshUtils { static QStringList s_types = QStringList() << "resource" << "folder" << "mail" << "event"; bool isValidStoreType(const QString &type) { return s_types.contains(type); } StoreBase &getStore(const QString &type) { if (type == "folder") { static Store store; return store; } else if (type == "mail") { static Store store; return store; } else if (type == "event") { static Store store; return store; } else if (type == "resource") { static Store store; return store; } //TODO: reinstate the warning+assert //Q_ASSERT(false); //qWarning() << "Trying to get a store that doesn't exist, falling back to event"; static Store store; return store; } QSharedPointer loadModel(const QString &type, Sink::Query query) { if (type == "folder") { query.requestedProperties << "name" << "parent"; } else if (type == "mail") { query.requestedProperties << "subject" << "folder" << "date"; } else if (type == "event") { query.requestedProperties << "summary"; } else if (type == "resource") { query.requestedProperties << "type"; } auto model = getStore(type).loadModel(query); Q_ASSERT(model); return model; } QStringList resourceIds(State &state) { QStringList resources; Sink::Query query; query.liveQuery = false; auto model = SinkshUtils::loadModel("resource", query); QObject::connect(model.data(), &QAbstractItemModel::rowsInserted, [model, &resources] (const QModelIndex &index, int start, int end) mutable { for (int i = start; i <= end; i++) { auto object = model->data(model->index(i, 0, index), Sink::Store::DomainObjectBaseRole).value(); resources << object->identifier(); } }); QObject::connect(model.data(), &QAbstractItemModel::dataChanged, [model, state](const QModelIndex &, const QModelIndex &, const QVector &roles) { if (roles.contains(Sink::Store::ChildrenFetchedRole)) { state.commandFinished(); } }); state.commandStarted(); return resources; } QStringList resourceCompleter(const QStringList &, const QString &fragment, State &state) { return Utils::filteredCompletions(resourceIds(state), fragment); } QStringList resourceOrTypeCompleter(const QStringList &commands, const QString &fragment, State &state) { static QStringList types = QStringList() << "resource" << "folder" << "mail" << "event"; if (commands.count() == 1) { return Utils::filteredCompletions(s_types, fragment); } return Utils::filteredCompletions(resourceIds(state), fragment); } QStringList typeCompleter(const QStringList &commands, const QString &fragment, State &state) { return Utils::filteredCompletions(s_types, fragment); } QMap keyValueMapFromArgs(const QStringList &args) { //TODO: this is not the most clever of algorithms. preserved during the port of commands // from sink_client ... we can probably do better, however ;) QMap map; for (int i = 0; i + 2 <= args.size(); i += 2) { map.insert(args.at(i), args.at(i + 1)); } return map; } }