2021-12-04 01:18:05 +01:00
|
|
|
#include "MinecraftProfileStep.h"
|
|
|
|
|
|
|
|
#include <QNetworkRequest>
|
|
|
|
|
2022-12-27 17:04:42 +01:00
|
|
|
#include "Logging.h"
|
2021-12-04 01:18:05 +01:00
|
|
|
#include "minecraft/auth/AuthRequest.h"
|
|
|
|
#include "minecraft/auth/Parsers.h"
|
2022-07-06 21:24:14 +02:00
|
|
|
#include "net/NetUtils.h"
|
2021-12-04 01:18:05 +01:00
|
|
|
|
2023-08-02 18:35:35 +02:00
|
|
|
MinecraftProfileStep::MinecraftProfileStep(AccountData* data) : AuthStep(data) {}
|
2021-12-04 01:18:05 +01:00
|
|
|
|
|
|
|
MinecraftProfileStep::~MinecraftProfileStep() noexcept = default;
|
|
|
|
|
2023-08-02 18:35:35 +02:00
|
|
|
QString MinecraftProfileStep::describe()
|
|
|
|
{
|
2021-12-04 01:18:05 +01:00
|
|
|
return tr("Fetching the Minecraft profile.");
|
|
|
|
}
|
|
|
|
|
2023-08-02 18:35:35 +02:00
|
|
|
void MinecraftProfileStep::perform()
|
|
|
|
{
|
2021-12-04 01:18:05 +01:00
|
|
|
auto url = QUrl("https://api.minecraftservices.com/minecraft/profile");
|
|
|
|
QNetworkRequest request = QNetworkRequest(url);
|
|
|
|
request.setHeader(QNetworkRequest::ContentTypeHeader, "application/json");
|
|
|
|
request.setRawHeader("Authorization", QString("Bearer %1").arg(m_data->yggdrasilToken.token).toUtf8());
|
|
|
|
|
2023-08-02 18:35:35 +02:00
|
|
|
AuthRequest* requestor = new AuthRequest(this);
|
2021-12-04 01:18:05 +01:00
|
|
|
connect(requestor, &AuthRequest::finished, this, &MinecraftProfileStep::onRequestDone);
|
|
|
|
requestor->get(request);
|
|
|
|
}
|
|
|
|
|
2023-08-02 18:35:35 +02:00
|
|
|
void MinecraftProfileStep::rehydrate()
|
|
|
|
{
|
2021-12-04 01:18:05 +01:00
|
|
|
// NOOP, for now. We only save bools and there's nothing to check.
|
|
|
|
}
|
|
|
|
|
2023-08-02 18:35:35 +02:00
|
|
|
void MinecraftProfileStep::onRequestDone(QNetworkReply::NetworkError error, QByteArray data, QList<QNetworkReply::RawHeaderPair> headers)
|
|
|
|
{
|
|
|
|
auto requestor = qobject_cast<AuthRequest*>(QObject::sender());
|
2021-12-04 01:18:05 +01:00
|
|
|
requestor->deleteLater();
|
|
|
|
|
2022-12-27 17:04:42 +01:00
|
|
|
qCDebug(authCredentials()) << data;
|
2021-12-04 01:18:05 +01:00
|
|
|
if (error == QNetworkReply::ContentNotFoundError) {
|
|
|
|
// NOTE: Succeed even if we do not have a profile. This is a valid account state.
|
2023-08-02 18:35:35 +02:00
|
|
|
if (m_data->type == AccountType::Mojang) {
|
2021-12-04 01:18:05 +01:00
|
|
|
m_data->minecraftEntitlement.canPlayMinecraft = false;
|
|
|
|
m_data->minecraftEntitlement.ownsMinecraft = false;
|
|
|
|
}
|
|
|
|
m_data->minecraftProfile = MinecraftProfile();
|
2023-08-02 18:35:35 +02:00
|
|
|
emit finished(AccountTaskState::STATE_SUCCEEDED, tr("Account has no Minecraft profile."));
|
2021-12-04 01:18:05 +01:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (error != QNetworkReply::NoError) {
|
2022-01-16 11:43:19 +01:00
|
|
|
qWarning() << "Error getting profile:";
|
|
|
|
qWarning() << " HTTP Status: " << requestor->httpStatus_;
|
|
|
|
qWarning() << " Internal error no.: " << error;
|
|
|
|
qWarning() << " Error string: " << requestor->errorString_;
|
|
|
|
|
2022-01-16 12:51:42 +01:00
|
|
|
qWarning() << " Response:";
|
|
|
|
qWarning() << QString::fromUtf8(data);
|
|
|
|
|
2022-07-06 21:24:14 +02:00
|
|
|
if (Net::isApplicationError(error)) {
|
2023-08-02 18:35:35 +02:00
|
|
|
emit finished(AccountTaskState::STATE_FAILED_SOFT,
|
|
|
|
tr("Minecraft Java profile acquisition failed: %1").arg(requestor->errorString_));
|
|
|
|
} else {
|
|
|
|
emit finished(AccountTaskState::STATE_OFFLINE,
|
|
|
|
tr("Minecraft Java profile acquisition failed: %1").arg(requestor->errorString_));
|
2022-07-06 21:24:14 +02:00
|
|
|
}
|
2021-12-04 01:18:05 +01:00
|
|
|
return;
|
|
|
|
}
|
2023-08-02 18:35:35 +02:00
|
|
|
if (!Parsers::parseMinecraftProfile(data, m_data->minecraftProfile)) {
|
2021-12-04 01:18:05 +01:00
|
|
|
m_data->minecraftProfile = MinecraftProfile();
|
2023-08-02 18:35:35 +02:00
|
|
|
emit finished(AccountTaskState::STATE_FAILED_SOFT, tr("Minecraft Java profile response could not be parsed"));
|
2021-12-04 01:18:05 +01:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2023-08-02 18:35:35 +02:00
|
|
|
if (m_data->type == AccountType::Mojang) {
|
2021-12-04 01:18:05 +01:00
|
|
|
auto validProfile = m_data->minecraftProfile.validity == Katabasis::Validity::Certain;
|
|
|
|
m_data->minecraftEntitlement.canPlayMinecraft = validProfile;
|
|
|
|
m_data->minecraftEntitlement.ownsMinecraft = validProfile;
|
|
|
|
}
|
2023-08-02 18:35:35 +02:00
|
|
|
emit finished(AccountTaskState::STATE_WORKING, tr("Minecraft Java profile acquisition succeeded."));
|
2021-12-04 01:18:05 +01:00
|
|
|
}
|