summaryrefslogtreecommitdiffstats
path: root/logic/net/SkinDownload.cpp
blob: fa7be2b5f9f571667864cfd40d82121a0cef17aa (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
#include "MultiMC.h"
#include "SkinDownload.h"
#include "DownloadJob.h"
#include <pathutils.h>

#include <QImage>
#include <QPainter>
#include <QCryptographicHash>
#include <QFileInfo>
#include <QDateTime>
#include <logger/QsLog.h>

SkinDownload::SkinDownload(QString name)
{
	m_name = name;
	m_entry = MMC->metacache()->resolveEntry("skins", name + ".png");
	m_entry->stale = true;
	m_url = QUrl("http://skins.minecraft.net/MinecraftSkins/" + name + ".png");
}

void SkinDownload::start()
{
	auto job = new DownloadJob("Player skin: " + m_name);

	job->addCacheDownload(m_url, m_entry);
	m_job.reset(job);

	connect(m_job.get(), SIGNAL(started()), SLOT(downloadStarted()));
	connect(m_job.get(), SIGNAL(progress(qint64, qint64)), SLOT(downloadProgress(qint64, qint64)));
	connect(m_job.get(), SIGNAL(succeeded()), SLOT(downloadSucceeded()));
	connect(m_job.get(), SIGNAL(failed()), SLOT(downloadFailed()));

	m_job->start();
}

void SkinDownload::downloadStarted()
{
	//QLOG_INFO() << "Started skin download for " << m_name << ".";

	emit started();
}

void SkinDownload::downloadProgress(qint64 bytesReceived, qint64 bytesTotal)
{
	emit progress(bytesReceived, bytesTotal);
}

void SkinDownload::downloadSucceeded()
{
	//QLOG_INFO() << "Got skin for " << m_name << ", cropping.";

	emit succeeded();
}

void SkinDownload::downloadFailed()
{
	//QLOG_ERROR() << "Failed to download skin for: " << m_name;

	emit failed();
}