summaryrefslogtreecommitdiff
path: root/plugin/src/Caelestia/requests.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'plugin/src/Caelestia/requests.cpp')
-rw-r--r--plugin/src/Caelestia/requests.cpp35
1 files changed, 35 insertions, 0 deletions
diff --git a/plugin/src/Caelestia/requests.cpp b/plugin/src/Caelestia/requests.cpp
new file mode 100644
index 0000000..2ceddb3
--- /dev/null
+++ b/plugin/src/Caelestia/requests.cpp
@@ -0,0 +1,35 @@
+#include "requests.hpp"
+
+#include <qnetworkaccessmanager.h>
+#include <qnetworkreply.h>
+#include <qnetworkrequest.h>
+
+namespace caelestia {
+
+Requests::Requests(QObject* parent)
+ : QObject(parent)
+ , m_manager(new QNetworkAccessManager(this)) {}
+
+void Requests::get(const QUrl& url, QJSValue onSuccess, QJSValue onError) const {
+ if (!onSuccess.isCallable()) {
+ qWarning() << "Requests::get: onSuccess is not callable";
+ return;
+ }
+
+ QNetworkRequest request(url);
+ auto reply = m_manager->get(request);
+
+ QObject::connect(reply, &QNetworkReply::finished, [reply, onSuccess, onError]() {
+ if (reply->error() == QNetworkReply::NoError) {
+ onSuccess.call({ QString(reply->readAll()) });
+ } else if (onError.isCallable()) {
+ onError.call({ reply->errorString() });
+ } else {
+ qWarning() << "Requests::get: request failed with error" << reply->errorString();
+ }
+
+ reply->deleteLater();
+ });
+}
+
+} // namespace caelestia