2022-04-21 16:01:55 -04:00
|
|
|
#include "MinecraftProfileStepMojang.h"
|
|
|
|
|
|
|
|
#include <QNetworkRequest>
|
|
|
|
|
2022-12-27 17:04:42 +01:00
|
|
|
#include "Logging.h"
|
2022-04-21 16:01:55 -04:00
|
|
|
#include "minecraft/auth/AuthRequest.h"
|
|
|
|
#include "minecraft/auth/Parsers.h"
|
2022-07-06 21:24:14 +02:00
|
|
|
#include "net/NetUtils.h"
|
2022-04-21 16:01:55 -04:00
|
|
|
|
2023-08-02 18:35:35 +02:00
|
|
|
MinecraftProfileStepMojang::MinecraftProfileStepMojang(AccountData* data) : AuthStep(data) {}
|
2022-04-21 16:01:55 -04:00
|
|
|
|
|
|
|
MinecraftProfileStepMojang::~MinecraftProfileStepMojang() noexcept = default;
|
|
|
|
|
2023-08-02 18:35:35 +02:00
|
|
|
QString MinecraftProfileStepMojang::describe()
|
|
|
|
{
|
2022-04-21 16:01:55 -04:00
|
|
|
return tr("Fetching the Minecraft profile.");
|
|
|
|
}
|
|
|
|
|
2023-08-02 18:35:35 +02:00
|
|
|
void MinecraftProfileStepMojang::perform()
|
|
|
|
{
|
2022-04-21 16:01:55 -04:00
|
|
|
if (m_data->minecraftProfile.id.isEmpty()) {
|
|
|
|
emit finished(AccountTaskState::STATE_FAILED_HARD, tr("A UUID is required to get the profile."));
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// use session server instead of profile due to profile endpoint being locked for locked Mojang accounts
|
|
|
|
QUrl url = QUrl("https://sessionserver.mojang.com/session/minecraft/profile/" + m_data->minecraftProfile.id);
|
|
|
|
QNetworkRequest req = QNetworkRequest(url);
|
2023-08-02 18:35:35 +02:00
|
|
|
AuthRequest* request = new AuthRequest(this);
|
2022-04-21 16:01:55 -04:00
|
|
|
connect(request, &AuthRequest::finished, this, &MinecraftProfileStepMojang::onRequestDone);
|
|
|
|
request->get(req);
|
|
|
|
}
|
|
|
|
|
2023-08-02 18:35:35 +02:00
|
|
|
void MinecraftProfileStepMojang::rehydrate()
|
|
|
|
{
|
2022-04-21 16:01:55 -04:00
|
|
|
// NOOP, for now. We only save bools and there's nothing to check.
|
|
|
|
}
|
|
|
|
|
2023-08-02 18:35:35 +02:00
|
|
|
void MinecraftProfileStepMojang::onRequestDone(QNetworkReply::NetworkError error,
|
|
|
|
QByteArray data,
|
|
|
|
QList<QNetworkReply::RawHeaderPair> headers)
|
|
|
|
{
|
|
|
|
auto requestor = qobject_cast<AuthRequest*>(QObject::sender());
|
2022-04-21 16:01:55 -04:00
|
|
|
requestor->deleteLater();
|
|
|
|
|
2022-12-27 17:04:42 +01:00
|
|
|
qCDebug(authCredentials()) << data;
|
2022-04-21 16:01:55 -04: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) {
|
2022-04-21 16:01:55 -04: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."));
|
2022-04-21 16:01:55 -04:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (error != QNetworkReply::NoError) {
|
|
|
|
qWarning() << "Error getting profile:";
|
|
|
|
qWarning() << " HTTP Status: " << requestor->httpStatus_;
|
|
|
|
qWarning() << " Internal error no.: " << error;
|
|
|
|
qWarning() << " Error string: " << requestor->errorString_;
|
|
|
|
|
|
|
|
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
|
|
|
}
|
2022-04-21 16:01:55 -04:00
|
|
|
return;
|
|
|
|
}
|
2023-08-02 18:35:35 +02:00
|
|
|
if (!Parsers::parseMinecraftProfileMojang(data, m_data->minecraftProfile)) {
|
2022-04-21 16:01:55 -04: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"));
|
2022-04-21 16:01:55 -04:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2023-08-02 18:35:35 +02:00
|
|
|
if (m_data->type == AccountType::Mojang) {
|
2022-04-21 16:01:55 -04: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."));
|
2022-04-21 16:01:55 -04:00
|
|
|
}
|