1
0
mirror of https://github.com/d47081/qBittorrent.git synced 2025-01-23 21:14:33 +00:00

Merge pull request #8515 from glassez/webapi

Fix Legacy Web API to be fully available
This commit is contained in:
Vladimir Golovnev 2018-03-01 09:44:06 +03:00 committed by GitHub
commit 9406b4b226
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 10 additions and 5 deletions

View File

@ -280,7 +280,6 @@ void WebApplication::doProcessRequest()
{"query/preferences", {"app", "preferences"}}, {"query/preferences", {"app", "preferences"}},
{"command/setPreferences", {"app", "setPreferences"}}, {"command/setPreferences", {"app", "setPreferences"}},
{"command/getSavePath", {"app", "defaultSavePath"}}, {"command/getSavePath", {"app", "defaultSavePath"}},
{"version/qbittorrent", {"app", "version"}},
{"query/getLog", {"log", "main"}}, {"query/getLog", {"log", "main"}},
{"query/getPeerLog", {"log", "peers"}}, {"query/getPeerLog", {"log", "peers"}},
@ -343,7 +342,8 @@ void WebApplication::doProcessRequest()
(*params)["deleteFiles"] = "true"; (*params)["deleteFiles"] = "true";
const QString hash {match.captured(QLatin1String("hash"))}; const QString hash {match.captured(QLatin1String("hash"))};
(*params)[QLatin1String("hash")] = hash; if (!hash.isEmpty())
(*params)[QLatin1String("hash")] = hash;
return true; return true;
}; };
@ -354,12 +354,17 @@ void WebApplication::doProcessRequest()
APIController *controller = m_apiControllers.value(scope); APIController *controller = m_apiControllers.value(scope);
if (!controller) { if (!controller) {
if (request().path == QLatin1String("/version/api")) { if (request().path == QLatin1String("/version/api")) {
print(QString(COMPAT_API_VERSION), Http::CONTENT_TYPE_TXT); print(QString::number(COMPAT_API_VERSION), Http::CONTENT_TYPE_TXT);
return; return;
} }
if (request().path == QLatin1String("/version/api_min")) { if (request().path == QLatin1String("/version/api_min")) {
print(QString(COMPAT_API_VERSION_MIN), Http::CONTENT_TYPE_TXT); print(QString::number(COMPAT_API_VERSION_MIN), Http::CONTENT_TYPE_TXT);
return;
}
if (request().path == QLatin1String("/version/qbittorrent")) {
print(QString(QBT_VERSION), Http::CONTENT_TYPE_TXT);
return; return;
} }

View File

@ -126,7 +126,7 @@ private:
Http::Environment m_env; Http::Environment m_env;
const QRegularExpression m_apiPathPattern {(QLatin1String("^/api/v2/(?<scope>[A-Za-z_][A-Za-z_0-9]*)/(?<action>[A-Za-z_][A-Za-z_0-9]*)$"))}; const QRegularExpression m_apiPathPattern {(QLatin1String("^/api/v2/(?<scope>[A-Za-z_][A-Za-z_0-9]*)/(?<action>[A-Za-z_][A-Za-z_0-9]*)$"))};
const QRegularExpression m_apiLegacyPathPattern {QLatin1String("^/(?<action>((sync|control|query)/[A-Za-z_][A-Za-z_0-9]*|login|logout))(/(?<hash>[^/]+))?$")}; const QRegularExpression m_apiLegacyPathPattern {QLatin1String("^/(?<action>((sync|command|query)/[A-Za-z_][A-Za-z_0-9]*|login|logout))(/(?<hash>[^/]+))?$")};
QHash<QString, APIController *> m_apiControllers; QHash<QString, APIController *> m_apiControllers;
QSet<QString> m_publicAPIs; QSet<QString> m_publicAPIs;