Skip to content
Snippets Groups Projects
Commit e1d7b913 authored by akiraohgaki's avatar akiraohgaki
Browse files

Get metadata

parent cf2169a9
No related branches found
No related tags found
No related merge requests found
...@@ -16,7 +16,7 @@ namespace Handlers { ...@@ -16,7 +16,7 @@ namespace Handlers {
XdgUrl::XdgUrl(const QString &xdgUrl, Core::Config *appConfig, Core::Config *userConfig, Core::Network *asyncNetwork, QObject *parent) : XdgUrl::XdgUrl(const QString &xdgUrl, Core::Config *appConfig, Core::Config *userConfig, Core::Network *asyncNetwork, QObject *parent) :
QObject(parent), _xdgUrl(xdgUrl), _appConfig(appConfig), _userConfig(userConfig), _asyncNetwork(asyncNetwork) QObject(parent), _xdgUrl(xdgUrl), _appConfig(appConfig), _userConfig(userConfig), _asyncNetwork(asyncNetwork)
{ {
_meta = _parse(); _metadata = _parse();
_destinations = _importDestinations(); _destinations = _importDestinations();
_archiveTypes = _importArchiveTypes(); _archiveTypes = _importArchiveTypes();
} }
...@@ -210,27 +210,32 @@ QString XdgUrl::getXdgUrl() ...@@ -210,27 +210,32 @@ QString XdgUrl::getXdgUrl()
return _xdgUrl; return _xdgUrl;
} }
QString XdgUrl::getMetadata()
{
return Utility::Json::convertObjToStr(_metadata);
}
bool XdgUrl::isValid() bool XdgUrl::isValid()
{ {
bool isValid = true; bool isValid = true;
if (_meta["scheme"].toString() != "xdg" && _meta["scheme"].toString() != "xdgs") { if (_metadata["scheme"].toString() != "xdg" && _metadata["scheme"].toString() != "xdgs") {
isValid = false; isValid = false;
} }
if (_meta["command"].toString() != "download" && _meta["command"].toString() != "install") { if (_metadata["command"].toString() != "download" && _metadata["command"].toString() != "install") {
isValid = false; isValid = false;
} }
if (!QUrl(_meta["url"].toString()).isValid()) { if (!QUrl(_metadata["url"].toString()).isValid()) {
isValid = false; isValid = false;
} }
if (!_destinations.contains(_meta["type"].toString())) { if (!_destinations.contains(_metadata["type"].toString())) {
isValid = false; isValid = false;
} }
if (_meta["filename"].toString().isEmpty()) { if (_metadata["filename"].toString().isEmpty()) {
isValid = false; isValid = false;
} }
......
...@@ -23,7 +23,7 @@ private: ...@@ -23,7 +23,7 @@ private:
Core::Config *_userConfig; Core::Config *_userConfig;
Core::Network *_asyncNetwork; Core::Network *_asyncNetwork;
QJsonObject _meta; QJsonObject _metadata;
QJsonObject _destinations; QJsonObject _destinations;
QJsonObject _archiveTypes; QJsonObject _archiveTypes;
...@@ -44,6 +44,7 @@ private slots: ...@@ -44,6 +44,7 @@ private slots:
public slots: public slots:
QString getXdgUrl(); QString getXdgUrl();
QString getMetadata();
bool isValid(); bool isValid();
bool process(); bool process();
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment