summaryrefslogtreecommitdiffstats
path: root/logic/trans/TranslationDownloader.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'logic/trans/TranslationDownloader.cpp')
-rw-r--r--logic/trans/TranslationDownloader.cpp51
1 files changed, 51 insertions, 0 deletions
diff --git a/logic/trans/TranslationDownloader.cpp b/logic/trans/TranslationDownloader.cpp
new file mode 100644
index 00000000..d533a7a2
--- /dev/null
+++ b/logic/trans/TranslationDownloader.cpp
@@ -0,0 +1,51 @@
+#include "TranslationDownloader.h"
+#include "logic/net/NetJob.h"
+#include "logic/net/ByteArrayDownload.h"
+#include "logic/net/CacheDownload.h"
+#include "logic/net/URLConstants.h"
+#include "MultiMC.h"
+
+TranslationDownloader::TranslationDownloader()
+{
+}
+void TranslationDownloader::downloadTranslations()
+{
+ QLOG_DEBUG() << "Downloading Translations Index...";
+ m_index_job.reset(new NetJob("Translations Index"));
+ m_index_task = ByteArrayDownload::make(QUrl("http://files.multimc.org/translations/index"));
+ m_index_job->addNetAction(m_index_task);
+ connect(m_index_job.get(), &NetJob::failed, this, &TranslationDownloader::indexFailed);
+ connect(m_index_job.get(), &NetJob::succeeded, this, &TranslationDownloader::indexRecieved);
+ m_index_job->start();
+}
+void TranslationDownloader::indexRecieved()
+{
+ QLOG_DEBUG() << "Got translations index!";
+ m_dl_job.reset(new NetJob("Translations"));
+ QList<QByteArray> lines = m_index_task->m_data.split('\n');
+ for (const auto line : lines)
+ {
+ if (!line.isEmpty())
+ {
+ CacheDownloadPtr dl = CacheDownload::make(
+ QUrl(URLConstants::TRANSLATIONS_BASE_URL + line),
+ MMC->metacache()->resolveEntry("translations", "mmc_" + line));
+ m_dl_job->addNetAction(dl);
+ }
+ }
+ connect(m_dl_job.get(), &NetJob::succeeded, this, &TranslationDownloader::dlGood);
+ connect(m_dl_job.get(), &NetJob::failed, this, &TranslationDownloader::dlFailed);
+ m_dl_job->start();
+}
+void TranslationDownloader::dlFailed()
+{
+ QLOG_ERROR() << "Translations Download Failed!";
+}
+void TranslationDownloader::dlGood()
+{
+ QLOG_DEBUG() << "Got translations!";
+}
+void TranslationDownloader::indexFailed()
+{
+ QLOG_ERROR() << "Translations Index Download Failed!";
+}