aboutsummaryrefslogtreecommitdiff
path: root/lib/csapi/keys.cpp
diff options
context:
space:
mode:
authorKitsune Ral <Kitsune-Ral@users.sf.net>2020-06-09 08:52:25 +0200
committerGitHub <noreply@github.com>2020-06-09 08:52:25 +0200
commit370d9b3e46332d38df8798cda208c534c58be808 (patch)
treef3db0cd7463468ff52c74446acd608356f8b8ab6 /lib/csapi/keys.cpp
parente1f5d0aa2c33e6da6c3a609c8bc7e0b5867e748d (diff)
parent10d9ac4673e374a9ac17ff492591136520337c4c (diff)
downloadlibquotient-370d9b3e46332d38df8798cda208c534c58be808.tar.gz
libquotient-370d9b3e46332d38df8798cda208c534c58be808.zip
Merge pull request #405 from quotient-im/kitsune-basejob-store-json-response
Store JSON response in BaseJob + tweaks to the generated code
Diffstat (limited to 'lib/csapi/keys.cpp')
-rw-r--r--lib/csapi/keys.cpp153
1 files changed, 13 insertions, 140 deletions
diff --git a/lib/csapi/keys.cpp b/lib/csapi/keys.cpp
index b1a947b3..34ab47c9 100644
--- a/lib/csapi/keys.cpp
+++ b/lib/csapi/keys.cpp
@@ -4,161 +4,48 @@
#include "keys.h"
-#include "converters.h"
-
#include <QtCore/QStringBuilder>
using namespace Quotient;
-static const auto basePath = QStringLiteral("/_matrix/client/r0");
-
-class UploadKeysJob::Private {
-public:
- QHash<QString, int> oneTimeKeyCounts;
-};
-
UploadKeysJob::UploadKeysJob(const Omittable<DeviceKeys>& deviceKeys,
const QHash<QString, QVariant>& oneTimeKeys)
: BaseJob(HttpVerb::Post, QStringLiteral("UploadKeysJob"),
- basePath % "/keys/upload")
- , d(new Private)
+ QStringLiteral("/_matrix/client/r0") % "/keys/upload")
{
QJsonObject _data;
addParam<IfNotEmpty>(_data, QStringLiteral("device_keys"), deviceKeys);
addParam<IfNotEmpty>(_data, QStringLiteral("one_time_keys"), oneTimeKeys);
- setRequestData(_data);
-}
-
-UploadKeysJob::~UploadKeysJob() = default;
-
-const QHash<QString, int>& UploadKeysJob::oneTimeKeyCounts() const
-{
- return d->oneTimeKeyCounts;
-}
-
-BaseJob::Status UploadKeysJob::parseJson(const QJsonDocument& data)
-{
- auto json = data.object();
- if (!json.contains("one_time_key_counts"_ls))
- return { IncorrectResponse,
- "The key 'one_time_key_counts' not found in the response" };
- fromJson(json.value("one_time_key_counts"_ls), d->oneTimeKeyCounts);
-
- return Success;
+ setRequestData(std::move(_data));
+ addExpectedKey("one_time_key_counts");
}
-// Converters
-namespace Quotient {
-
-template <>
-struct JsonObjectConverter<QueryKeysJob::UnsignedDeviceInfo> {
- static void fillFrom(const QJsonObject& jo,
- QueryKeysJob::UnsignedDeviceInfo& result)
- {
- fromJson(jo.value("device_display_name"_ls), result.deviceDisplayName);
- }
-};
-
-template <>
-struct JsonObjectConverter<QueryKeysJob::DeviceInformation> {
- static void fillFrom(const QJsonObject& jo,
- QueryKeysJob::DeviceInformation& result)
- {
- fillFromJson<DeviceKeys>(jo, result);
- fromJson(jo.value("unsigned"_ls), result.unsignedData);
- }
-};
-
-} // namespace Quotient
-
-class QueryKeysJob::Private {
-public:
- QHash<QString, QJsonObject> failures;
- QHash<QString, QHash<QString, DeviceInformation>> deviceKeys;
-};
-
QueryKeysJob::QueryKeysJob(const QHash<QString, QStringList>& deviceKeys,
Omittable<int> timeout, const QString& token)
: BaseJob(HttpVerb::Post, QStringLiteral("QueryKeysJob"),
- basePath % "/keys/query")
- , d(new Private)
+ QStringLiteral("/_matrix/client/r0") % "/keys/query")
{
QJsonObject _data;
addParam<IfNotEmpty>(_data, QStringLiteral("timeout"), timeout);
addParam<>(_data, QStringLiteral("device_keys"), deviceKeys);
addParam<IfNotEmpty>(_data, QStringLiteral("token"), token);
- setRequestData(_data);
-}
-
-QueryKeysJob::~QueryKeysJob() = default;
-
-const QHash<QString, QJsonObject>& QueryKeysJob::failures() const
-{
- return d->failures;
-}
-
-const QHash<QString, QHash<QString, QueryKeysJob::DeviceInformation>>&
-QueryKeysJob::deviceKeys() const
-{
- return d->deviceKeys;
+ setRequestData(std::move(_data));
}
-BaseJob::Status QueryKeysJob::parseJson(const QJsonDocument& data)
-{
- auto json = data.object();
- fromJson(json.value("failures"_ls), d->failures);
- fromJson(json.value("device_keys"_ls), d->deviceKeys);
-
- return Success;
-}
-
-class ClaimKeysJob::Private {
-public:
- QHash<QString, QJsonObject> failures;
- QHash<QString, QHash<QString, QVariant>> oneTimeKeys;
-};
-
ClaimKeysJob::ClaimKeysJob(
const QHash<QString, QHash<QString, QString>>& oneTimeKeys,
Omittable<int> timeout)
: BaseJob(HttpVerb::Post, QStringLiteral("ClaimKeysJob"),
- basePath % "/keys/claim")
- , d(new Private)
+ QStringLiteral("/_matrix/client/r0") % "/keys/claim")
{
QJsonObject _data;
addParam<IfNotEmpty>(_data, QStringLiteral("timeout"), timeout);
addParam<>(_data, QStringLiteral("one_time_keys"), oneTimeKeys);
- setRequestData(_data);
-}
-
-ClaimKeysJob::~ClaimKeysJob() = default;
-
-const QHash<QString, QJsonObject>& ClaimKeysJob::failures() const
-{
- return d->failures;
-}
-
-const QHash<QString, QHash<QString, QVariant>>& ClaimKeysJob::oneTimeKeys() const
-{
- return d->oneTimeKeys;
+ setRequestData(std::move(_data));
+ addExpectedKey("one_time_keys");
}
-BaseJob::Status ClaimKeysJob::parseJson(const QJsonDocument& data)
-{
- auto json = data.object();
- fromJson(json.value("failures"_ls), d->failures);
- fromJson(json.value("one_time_keys"_ls), d->oneTimeKeys);
-
- return Success;
-}
-
-class GetKeysChangesJob::Private {
-public:
- QStringList changed;
- QStringList left;
-};
-
-BaseJob::Query queryToGetKeysChanges(const QString& from, const QString& to)
+auto queryToGetKeysChanges(const QString& from, const QString& to)
{
BaseJob::Query _q;
addParam<>(_q, QStringLiteral("from"), from);
@@ -170,27 +57,13 @@ QUrl GetKeysChangesJob::makeRequestUrl(QUrl baseUrl, const QString& from,
const QString& to)
{
return BaseJob::makeRequestUrl(std::move(baseUrl),
- basePath % "/keys/changes",
+ QStringLiteral("/_matrix/client/r0")
+ % "/keys/changes",
queryToGetKeysChanges(from, to));
}
GetKeysChangesJob::GetKeysChangesJob(const QString& from, const QString& to)
: BaseJob(HttpVerb::Get, QStringLiteral("GetKeysChangesJob"),
- basePath % "/keys/changes", queryToGetKeysChanges(from, to))
- , d(new Private)
+ QStringLiteral("/_matrix/client/r0") % "/keys/changes",
+ queryToGetKeysChanges(from, to))
{}
-
-GetKeysChangesJob::~GetKeysChangesJob() = default;
-
-const QStringList& GetKeysChangesJob::changed() const { return d->changed; }
-
-const QStringList& GetKeysChangesJob::left() const { return d->left; }
-
-BaseJob::Status GetKeysChangesJob::parseJson(const QJsonDocument& data)
-{
- auto json = data.object();
- fromJson(json.value("changed"_ls), d->changed);
- fromJson(json.value("left"_ls), d->left);
-
- return Success;
-}