From 1fc4fd0a0c067cb9900c8ebda273d65e0d140fd3 Mon Sep 17 00:00:00 2001 From: Christian Mollekopf Date: Tue, 19 Dec 2017 09:38:53 +0100 Subject: Custom component metadata mechanism. --- accounts/maildir/CMakeLists.txt | 1 + accounts/maildir/metadata.json | 3 +++ framework/src/CMakeLists.txt | 3 --- framework/src/accounts/accountfactory.cpp | 18 +++++++++++++----- 4 files changed, 17 insertions(+), 8 deletions(-) create mode 100644 accounts/maildir/metadata.json diff --git a/accounts/maildir/CMakeLists.txt b/accounts/maildir/CMakeLists.txt index c396b6ba..76ae2c23 100644 --- a/accounts/maildir/CMakeLists.txt +++ b/accounts/maildir/CMakeLists.txt @@ -15,4 +15,5 @@ target_link_libraries(maildiraccountplugin ) install(TARGETS maildiraccountplugin DESTINATION ${QML_INSTALL_DIR}/org/kube/accounts/maildir) +install(FILES metadata.json DESTINATION ${QML_INSTALL_DIR}/org/kube/accounts/maildir) install_qml_account(maildir) diff --git a/accounts/maildir/metadata.json b/accounts/maildir/metadata.json new file mode 100644 index 00000000..9f9f106e --- /dev/null +++ b/accounts/maildir/metadata.json @@ -0,0 +1,3 @@ +{ + "RequiresKeyring": false +} diff --git a/framework/src/CMakeLists.txt b/framework/src/CMakeLists.txt index 09a4c22d..9d4e238e 100644 --- a/framework/src/CMakeLists.txt +++ b/framework/src/CMakeLists.txt @@ -12,9 +12,6 @@ set(CMAKE_CXX_VISIBILITY_PRESET default) include_directories(. domain/mime/mimetreeparser domain/ domain/mime) -set(SRCS -) - add_library(kubeframework SHARED settings/settings.cpp domain/maillistmodel.cpp diff --git a/framework/src/accounts/accountfactory.cpp b/framework/src/accounts/accountfactory.cpp index 2babeb5d..5d3c35fc 100644 --- a/framework/src/accounts/accountfactory.cpp +++ b/framework/src/accounts/accountfactory.cpp @@ -21,6 +21,8 @@ #include #include #include +#include +#include #include @@ -60,16 +62,22 @@ void AccountFactory::loadPackage() } return QString{}; }(); + mUiPath.clear(); + mLoginUi.clear(); + mRequiresKeyring = false; if (pluginPath.isEmpty()) { qWarning() << "Failed to load account package: " << "org.kube.accounts." + mAccountType; - mUiPath.clear(); - mLoginUi.clear(); - mRequiresKeyring = true; } else { mUiPath = pluginPath + "/AccountSettings.qml"; mLoginUi = pluginPath + "/Login.qml"; - //FIXME - mRequiresKeyring = true; + if (QFileInfo::exists(pluginPath + "/metadata.json")) { + QFile file{pluginPath + "/metadata.json"}; + file.open(QIODevice::ReadOnly); + auto json = QJsonDocument::fromJson(file.readAll()); + mRequiresKeyring = json.object().value("RequiresKeyring").toBool(true); + } else { + mRequiresKeyring = true; + } } emit accountLoaded(); } -- cgit v1.2.3