aboutsummaryrefslogtreecommitdiff
path: root/jobs/{{base}}.cpp.mustache
diff options
context:
space:
mode:
authorKitsune Ral <Kitsune-Ral@users.sf.net>2018-01-03 12:20:26 +0900
committerKitsune Ral <Kitsune-Ral@users.sf.net>2018-01-03 12:20:26 +0900
commit9aed9cc6327c3756a29d30b8538799be9dadd01a (patch)
treeacf963fee87f790facf449e08db6afd50a5e6602 /jobs/{{base}}.cpp.mustache
parent0a688331ec0d9d9c592e8c542946dbd66d9c6b2f (diff)
downloadlibquotient-9aed9cc6327c3756a29d30b8538799be9dadd01a.tar.gz
libquotient-9aed9cc6327c3756a29d30b8538799be9dadd01a.zip
Fully support content-repo API
That includes dealing with headers and raw (non-JSON) responses.
Diffstat (limited to 'jobs/{{base}}.cpp.mustache')
-rw-r--r--jobs/{{base}}.cpp.mustache49
1 files changed, 25 insertions, 24 deletions
diff --git a/jobs/{{base}}.cpp.mustache b/jobs/{{base}}.cpp.mustache
index b303c053..6621f173 100644
--- a/jobs/{{base}}.cpp.mustache
+++ b/jobs/{{base}}.cpp.mustache
@@ -1,10 +1,10 @@
{{#@filePartial}}preamble{{/@filePartial}}
-
#include "{{filenameBase}}.h"
-
+{{^allModels}}
#include "converters.h"
-{{#operations}}
-#include <QtCore/QStringBuilder>
+{{/allModels}}{{#operations}}
+{{#producesNotJson?}}#include <QtNetwork/QNetworkReply>
+{{/producesNotJson?}}#include <QtCore/QStringBuilder>
{{/operations}}
using namespace QMatrixClient;
{{#models.model}}{{^trivial?}}
@@ -50,14 +50,13 @@ namespace QMatrixClient
}
};
} // namespace QMatrixClient
-{{/ trivial?}}{{/models.model}}{{#responses}}{{#normalResponse?}}{{#properties?}}
+{{/ trivial?}}{{/models.model}}{{#responses}}{{#normalResponse?}}{{#allProperties?}}
class {{camelCaseOperationId}}Job::Private
{
- public:
- {{#properties}}{{dataType.name}} {{paramName}};{{#@join}}{{!EOL except the last line}}
- {{/@join}}{{/properties}}
+ public:{{#allProperties}}
+ {{dataType.name}} {{paramName}};{{/allProperties}}
};
-{{/ properties?}}{{/normalResponse?}}{{/responses}}
+{{/ allProperties?}}{{/normalResponse?}}{{/responses}}
{{camelCaseOperationId}}Job::{{camelCaseOperationId}}Job({{#allParams}}{{>maybeCrefType}} {{paramName}}{{#@join}}, {{/@join}}{{/allParams}})
: BaseJob(HttpVerb::{{#@cap}}{{#@tolower}}{{httpMethod}}{{/@tolower}}{{/@cap}}, "{{camelCaseOperationId}}Job",
basePath{{#pathParts}} % {{_}}{{/pathParts}},
@@ -65,30 +64,32 @@ class {{camelCaseOperationId}}Job::Private
{{#queryParams}}{ "{{baseName}}", toJson({{paramName}}).toString() }{{#@join}},
{{/@join}}{{/queryParams}}
}{{/queryParams?}}{{#skipAuth}}, Data { }, false{{/skipAuth}}
- ){{#responses}}{{#normalResponse?}}{{#properties?}}, d(new Private){{/properties?}}{{/normalResponse?}}{{/responses}}
+ ){{#responses}}{{#normalResponse?}}{{#allProperties?}}, d(new Private){{/allProperties?}}{{/normalResponse?}}{{/responses}}
{{#bodyParams?}}{
-{{#inlineBody}} setRequestData(Data({{paramName}}));{{/inlineBody}}{{!
+{{#headerParams?}}{{#headerParams}} setRequestHeader("{{baseName}}", {{paramName}}.toLatin1());
+{{/headerParams}}
+{{/headerParams?}}{{#inlineBody}} setRequestData(Data({{paramName}}));{{/inlineBody}}{{!
}}{{^inlineBody}} QJsonObject _data;{{#bodyParams}}
{{^required?}}{{#string?}} if (!{{paramName}}.isEmpty())
{{/string?}}{{/required?}} _data.insert("{{baseName}}", toJson({{paramName}}));{{/bodyParams}}
- setRequestData(_data);{{/inlineBody}}
+ setRequestData(_data);{{/inlineBody}}{{#produces?}}
+{{#produces}}
+ addExpectedContentType({{_}});{{/produces}}{{/produces?}}
}{{/bodyParams?}}{{^bodyParams?}}{ }{{/bodyParams?}}
-{{# responses}}{{#normalResponse?}}{{#properties?}}
-{{camelCaseOperationId}}Job::~{{camelCaseOperationId}}Job()
-{
- delete d;
-}
-{{# properties}}
+{{# responses}}{{#normalResponse?}}{{#allProperties?}}
+{{camelCaseOperationId}}Job::~{{camelCaseOperationId}}Job() = default;
+{{# allProperties}}
{{>qualifiedMaybeCrefType}} {{camelCaseOperationId}}Job::{{paramName}}() const
{
return d->{{paramName}};
}
-{{/ properties}}{{#returnFile?}}
-BaseJob::Status {{camelCaseOperationId}}Job::parseReply(QByteArray data)
+{{/ allProperties}}{{#producesNotJson?}}
+BaseJob::Status {{camelCaseOperationId}}Job::parseReply(QNetworkReply* reply)
{
- {{properties.nameCamelCase}} = data;
+ {{#headers}}d->{{paramName}} = reply->rawHeader("{{baseName}}"); {{! We don't check for required headers yet }}
+ {{/headers}}{{#properties}}d->{{paramName}} = reply->readAll();{{/properties}}
return Success;
-}{{/ returnFile?}}{{^returnFile?}}
+}{{/ producesNotJson?}}{{^producesNotJson?}}
BaseJob::Status {{camelCaseOperationId}}Job::parseJson(const QJsonDocument& data)
{
auto json = data.object();
@@ -97,5 +98,5 @@ BaseJob::Status {{camelCaseOperationId}}Job::parseJson(const QJsonDocument& data
"The key '{{baseName}}' not found in the response" };
{{/required?}}d->{{paramName}} = fromJson<{{dataType.name}}>(json.value("{{baseName}}"));
{{/ properties}}return Success;
-}{{/ returnFile?}}
-{{/properties?}}{{/normalResponse?}}{{/responses}}{{/operation}}{{/operations}}
+}{{/ producesNotJson?}}
+{{/allProperties?}}{{/normalResponse?}}{{/responses}}{{/operation}}{{/operations}}