refactor: add logging category for credentials
Signed-off-by: Sefa Eyeoglu <contact@scrumplex.net>
This commit is contained in:
		@@ -27,6 +27,8 @@ set(CORE_SOURCES
 | 
			
		||||
    StringUtils.h
 | 
			
		||||
    StringUtils.cpp
 | 
			
		||||
    RuntimeContext.h
 | 
			
		||||
    Logging.h
 | 
			
		||||
    Logging.cpp
 | 
			
		||||
 | 
			
		||||
    # Basic instance manipulation tasks (derived from InstanceTask)
 | 
			
		||||
    InstanceCreationTask.h
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										22
									
								
								launcher/Logging.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								launcher/Logging.cpp
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,22 @@
 | 
			
		||||
// SPDX-License-Identifier: GPL-3.0-only
 | 
			
		||||
/*
 | 
			
		||||
 *  PolyMC - Minecraft Launcher
 | 
			
		||||
 *  Copyright (C) 2022 Sefa Eyeoglu <contact@scrumplex.net>
 | 
			
		||||
 *
 | 
			
		||||
 *  This program is free software: you can redistribute it and/or modify
 | 
			
		||||
 *  it under the terms of the GNU General Public License as published by
 | 
			
		||||
 *  the Free Software Foundation, version 3.
 | 
			
		||||
 *
 | 
			
		||||
 *  This program is distributed in the hope that it will be useful,
 | 
			
		||||
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
			
		||||
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | 
			
		||||
 *  GNU General Public License for more details.
 | 
			
		||||
 *
 | 
			
		||||
 *  You should have received a copy of the GNU General Public License
 | 
			
		||||
 *  along with this program.  If not, see <https://www.gnu.org/licenses/>.
 | 
			
		||||
 *
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#include "Logging.h"
 | 
			
		||||
 | 
			
		||||
Q_LOGGING_CATEGORY(authCredentials, "launcher.auth.credentials", QtWarningMsg)
 | 
			
		||||
							
								
								
									
										24
									
								
								launcher/Logging.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								launcher/Logging.h
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,24 @@
 | 
			
		||||
// SPDX-License-Identifier: GPL-3.0-only
 | 
			
		||||
/*
 | 
			
		||||
 *  PolyMC - Minecraft Launcher
 | 
			
		||||
 *  Copyright (C) 2022 Sefa Eyeoglu <contact@scrumplex.net>
 | 
			
		||||
 *
 | 
			
		||||
 *  This program is free software: you can redistribute it and/or modify
 | 
			
		||||
 *  it under the terms of the GNU General Public License as published by
 | 
			
		||||
 *  the Free Software Foundation, version 3.
 | 
			
		||||
 *
 | 
			
		||||
 *  This program is distributed in the hope that it will be useful,
 | 
			
		||||
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
			
		||||
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | 
			
		||||
 *  GNU General Public License for more details.
 | 
			
		||||
 *
 | 
			
		||||
 *  You should have received a copy of the GNU General Public License
 | 
			
		||||
 *  along with this program.  If not, see <https://www.gnu.org/licenses/>.
 | 
			
		||||
 *
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#pragma once
 | 
			
		||||
 | 
			
		||||
#include <QLoggingCategory>
 | 
			
		||||
 | 
			
		||||
Q_DECLARE_LOGGING_CATEGORY(authCredentials)
 | 
			
		||||
@@ -1,5 +1,6 @@
 | 
			
		||||
#include "Parsers.h"
 | 
			
		||||
#include "Json.h"
 | 
			
		||||
#include "Logging.h"
 | 
			
		||||
 | 
			
		||||
#include <QJsonDocument>
 | 
			
		||||
#include <QJsonArray>
 | 
			
		||||
@@ -75,9 +76,7 @@ bool getBool(QJsonValue value, bool & out) {
 | 
			
		||||
 | 
			
		||||
bool parseXTokenResponse(QByteArray & data, Katabasis::Token &output, QString name) {
 | 
			
		||||
    qDebug() << "Parsing" << name <<":";
 | 
			
		||||
#ifndef NDEBUG
 | 
			
		||||
    qDebug() << data;
 | 
			
		||||
#endif
 | 
			
		||||
    qCDebug(authCredentials()) << data;
 | 
			
		||||
    QJsonParseError jsonError;
 | 
			
		||||
    QJsonDocument doc = QJsonDocument::fromJson(data, &jsonError);
 | 
			
		||||
    if(jsonError.error) {
 | 
			
		||||
@@ -137,9 +136,7 @@ bool parseXTokenResponse(QByteArray & data, Katabasis::Token &output, QString na
 | 
			
		||||
 | 
			
		||||
bool parseMinecraftProfile(QByteArray & data, MinecraftProfile &output) {
 | 
			
		||||
    qDebug() << "Parsing Minecraft profile...";
 | 
			
		||||
#ifndef NDEBUG
 | 
			
		||||
    qDebug() << data;
 | 
			
		||||
#endif
 | 
			
		||||
    qCDebug(authCredentials()) << data;
 | 
			
		||||
 | 
			
		||||
    QJsonParseError jsonError;
 | 
			
		||||
    QJsonDocument doc = QJsonDocument::fromJson(data, &jsonError);
 | 
			
		||||
@@ -275,9 +272,7 @@ decoded base64 "value":
 | 
			
		||||
 | 
			
		||||
bool parseMinecraftProfileMojang(QByteArray & data, MinecraftProfile &output) {
 | 
			
		||||
    qDebug() << "Parsing Minecraft profile...";
 | 
			
		||||
#ifndef NDEBUG
 | 
			
		||||
    qDebug() << data;
 | 
			
		||||
#endif
 | 
			
		||||
    qCDebug(authCredentials()) << data;
 | 
			
		||||
 | 
			
		||||
    QJsonParseError jsonError;
 | 
			
		||||
    QJsonDocument doc = QJsonDocument::fromJson(data, &jsonError);
 | 
			
		||||
@@ -389,9 +384,7 @@ bool parseMinecraftProfileMojang(QByteArray & data, MinecraftProfile &output) {
 | 
			
		||||
 | 
			
		||||
bool parseMinecraftEntitlements(QByteArray & data, MinecraftEntitlement &output) {
 | 
			
		||||
    qDebug() << "Parsing Minecraft entitlements...";
 | 
			
		||||
#ifndef NDEBUG
 | 
			
		||||
    qDebug() << data;
 | 
			
		||||
#endif
 | 
			
		||||
    qCDebug(authCredentials()) << data;
 | 
			
		||||
 | 
			
		||||
    QJsonParseError jsonError;
 | 
			
		||||
    QJsonDocument doc = QJsonDocument::fromJson(data, &jsonError);
 | 
			
		||||
@@ -424,9 +417,7 @@ bool parseMinecraftEntitlements(QByteArray & data, MinecraftEntitlement &output)
 | 
			
		||||
 | 
			
		||||
bool parseRolloutResponse(QByteArray & data, bool& result) {
 | 
			
		||||
    qDebug() << "Parsing Rollout response...";
 | 
			
		||||
#ifndef NDEBUG
 | 
			
		||||
    qDebug() << data;
 | 
			
		||||
#endif
 | 
			
		||||
    qCDebug(authCredentials()) << data;
 | 
			
		||||
 | 
			
		||||
    QJsonParseError jsonError;
 | 
			
		||||
    QJsonDocument doc = QJsonDocument::fromJson(data, &jsonError);
 | 
			
		||||
@@ -455,9 +446,7 @@ bool parseRolloutResponse(QByteArray & data, bool& result) {
 | 
			
		||||
bool parseMojangResponse(QByteArray & data, Katabasis::Token &output) {
 | 
			
		||||
    QJsonParseError jsonError;
 | 
			
		||||
    qDebug() << "Parsing Mojang response...";
 | 
			
		||||
#ifndef NDEBUG
 | 
			
		||||
    qDebug() << data;
 | 
			
		||||
#endif
 | 
			
		||||
    qCDebug(authCredentials()) << data;
 | 
			
		||||
    QJsonDocument doc = QJsonDocument::fromJson(data, &jsonError);
 | 
			
		||||
    if(jsonError.error) {
 | 
			
		||||
        qWarning() << "Failed to parse response from api.minecraftservices.com/launcher/login as JSON: " << jsonError.errorString();
 | 
			
		||||
 
 | 
			
		||||
@@ -3,6 +3,7 @@
 | 
			
		||||
#include <QNetworkRequest>
 | 
			
		||||
#include <QUuid>
 | 
			
		||||
 | 
			
		||||
#include "Logging.h"
 | 
			
		||||
#include "minecraft/auth/AuthRequest.h"
 | 
			
		||||
#include "minecraft/auth/Parsers.h"
 | 
			
		||||
 | 
			
		||||
@@ -41,9 +42,7 @@ void EntitlementsStep::onRequestDone(
 | 
			
		||||
    auto requestor = qobject_cast<AuthRequest *>(QObject::sender());
 | 
			
		||||
    requestor->deleteLater();
 | 
			
		||||
 | 
			
		||||
#ifndef NDEBUG
 | 
			
		||||
    qDebug() << data;
 | 
			
		||||
#endif
 | 
			
		||||
    qCDebug(authCredentials()) << data;
 | 
			
		||||
 | 
			
		||||
    // TODO: check presence of same entitlementsRequestId?
 | 
			
		||||
    // TODO: validate JWTs?
 | 
			
		||||
 
 | 
			
		||||
@@ -2,9 +2,10 @@
 | 
			
		||||
 | 
			
		||||
#include <QNetworkRequest>
 | 
			
		||||
 | 
			
		||||
#include "Logging.h"
 | 
			
		||||
#include "minecraft/auth/AccountTask.h"
 | 
			
		||||
#include "minecraft/auth/AuthRequest.h"
 | 
			
		||||
#include "minecraft/auth/Parsers.h"
 | 
			
		||||
#include "minecraft/auth/AccountTask.h"
 | 
			
		||||
#include "net/NetUtils.h"
 | 
			
		||||
 | 
			
		||||
LauncherLoginStep::LauncherLoginStep(AccountData* data) : AuthStep(data) {
 | 
			
		||||
@@ -51,14 +52,10 @@ void LauncherLoginStep::onRequestDone(
 | 
			
		||||
    auto requestor = qobject_cast<AuthRequest *>(QObject::sender());
 | 
			
		||||
    requestor->deleteLater();
 | 
			
		||||
 | 
			
		||||
#ifndef NDEBUG
 | 
			
		||||
    qDebug() << data;
 | 
			
		||||
#endif
 | 
			
		||||
    qCDebug(authCredentials()) << data;
 | 
			
		||||
    if (error != QNetworkReply::NoError) {
 | 
			
		||||
        qWarning() << "Reply error:" << error;
 | 
			
		||||
#ifndef NDEBUG
 | 
			
		||||
        qDebug() << data;
 | 
			
		||||
#endif
 | 
			
		||||
        qCDebug(authCredentials()) << data;
 | 
			
		||||
        if (Net::isApplicationError(error)) {
 | 
			
		||||
            emit finished(
 | 
			
		||||
                AccountTaskState::STATE_FAILED_SOFT,
 | 
			
		||||
@@ -76,9 +73,7 @@ void LauncherLoginStep::onRequestDone(
 | 
			
		||||
 | 
			
		||||
    if(!Parsers::parseMojangResponse(data, m_data->yggdrasilToken)) {
 | 
			
		||||
        qWarning() << "Could not parse login_with_xbox response...";
 | 
			
		||||
#ifndef NDEBUG
 | 
			
		||||
        qDebug() << data;
 | 
			
		||||
#endif
 | 
			
		||||
        qCDebug(authCredentials()) << data;
 | 
			
		||||
        emit finished(
 | 
			
		||||
            AccountTaskState::STATE_FAILED_SOFT,
 | 
			
		||||
            tr("Failed to parse the Minecraft access token response.")
 | 
			
		||||
 
 | 
			
		||||
@@ -42,6 +42,7 @@
 | 
			
		||||
#include "minecraft/auth/Parsers.h"
 | 
			
		||||
 | 
			
		||||
#include "Application.h"
 | 
			
		||||
#include "Logging.h"
 | 
			
		||||
 | 
			
		||||
using OAuth2 = Katabasis::DeviceFlow;
 | 
			
		||||
using Activity = Katabasis::Activity;
 | 
			
		||||
@@ -117,14 +118,12 @@ void MSAStep::onOAuthActivityChanged(Katabasis::Activity activity) {
 | 
			
		||||
            // Succeeded or did not invalidate tokens
 | 
			
		||||
            emit hideVerificationUriAndCode();
 | 
			
		||||
            QVariantMap extraTokens = m_oauth2->extraTokens();
 | 
			
		||||
#ifndef NDEBUG
 | 
			
		||||
            if (!extraTokens.isEmpty()) {
 | 
			
		||||
                qDebug() << "Extra tokens in response:";
 | 
			
		||||
                qCDebug(authCredentials()) << "Extra tokens in response:";
 | 
			
		||||
                foreach (QString key, extraTokens.keys()) {
 | 
			
		||||
                    qDebug() << "\t" << key << ":" << extraTokens.value(key);
 | 
			
		||||
                    qCDebug(authCredentials()) << "\t" << key << ":" << extraTokens.value(key);
 | 
			
		||||
                }
 | 
			
		||||
            }
 | 
			
		||||
#endif
 | 
			
		||||
            emit finished(AccountTaskState::STATE_WORKING, tr("Got "));
 | 
			
		||||
            return;
 | 
			
		||||
        }
 | 
			
		||||
 
 | 
			
		||||
@@ -2,6 +2,7 @@
 | 
			
		||||
 | 
			
		||||
#include <QNetworkRequest>
 | 
			
		||||
 | 
			
		||||
#include "Logging.h"
 | 
			
		||||
#include "minecraft/auth/AuthRequest.h"
 | 
			
		||||
#include "minecraft/auth/Parsers.h"
 | 
			
		||||
#include "net/NetUtils.h"
 | 
			
		||||
@@ -40,9 +41,7 @@ void MinecraftProfileStep::onRequestDone(
 | 
			
		||||
    auto requestor = qobject_cast<AuthRequest *>(QObject::sender());
 | 
			
		||||
    requestor->deleteLater();
 | 
			
		||||
 | 
			
		||||
#ifndef NDEBUG
 | 
			
		||||
    qDebug() << data;
 | 
			
		||||
#endif
 | 
			
		||||
    qCDebug(authCredentials()) << data;
 | 
			
		||||
    if (error == QNetworkReply::ContentNotFoundError) {
 | 
			
		||||
        // NOTE: Succeed even if we do not have a profile. This is a valid account state.
 | 
			
		||||
        if(m_data->type == AccountType::Mojang) {
 | 
			
		||||
 
 | 
			
		||||
@@ -2,6 +2,7 @@
 | 
			
		||||
 | 
			
		||||
#include <QNetworkRequest>
 | 
			
		||||
 | 
			
		||||
#include "Logging.h"
 | 
			
		||||
#include "minecraft/auth/AuthRequest.h"
 | 
			
		||||
#include "minecraft/auth/Parsers.h"
 | 
			
		||||
#include "net/NetUtils.h"
 | 
			
		||||
@@ -43,9 +44,7 @@ void MinecraftProfileStepMojang::onRequestDone(
 | 
			
		||||
    auto requestor = qobject_cast<AuthRequest *>(QObject::sender());
 | 
			
		||||
    requestor->deleteLater();
 | 
			
		||||
 | 
			
		||||
#ifndef NDEBUG
 | 
			
		||||
    qDebug() << data;
 | 
			
		||||
#endif
 | 
			
		||||
    qCDebug(authCredentials()) << data;
 | 
			
		||||
    if (error == QNetworkReply::ContentNotFoundError) {
 | 
			
		||||
        // NOTE: Succeed even if we do not have a profile. This is a valid account state.
 | 
			
		||||
        if(m_data->type == AccountType::Mojang) {
 | 
			
		||||
 
 | 
			
		||||
@@ -4,6 +4,7 @@
 | 
			
		||||
#include <QJsonParseError>
 | 
			
		||||
#include <QJsonDocument>
 | 
			
		||||
 | 
			
		||||
#include "Logging.h"
 | 
			
		||||
#include "minecraft/auth/AuthRequest.h"
 | 
			
		||||
#include "minecraft/auth/Parsers.h"
 | 
			
		||||
#include "net/NetUtils.h"
 | 
			
		||||
@@ -58,9 +59,7 @@ void XboxAuthorizationStep::onRequestDone(
 | 
			
		||||
    auto requestor = qobject_cast<AuthRequest *>(QObject::sender());
 | 
			
		||||
    requestor->deleteLater();
 | 
			
		||||
 | 
			
		||||
#ifndef NDEBUG
 | 
			
		||||
    qDebug() << data;
 | 
			
		||||
#endif
 | 
			
		||||
    qCDebug(authCredentials()) << data;
 | 
			
		||||
    if (error != QNetworkReply::NoError) {
 | 
			
		||||
        qWarning() << "Reply error:" << error;
 | 
			
		||||
        if (Net::isApplicationError(error)) {
 | 
			
		||||
 
 | 
			
		||||
@@ -3,7 +3,7 @@
 | 
			
		||||
#include <QNetworkRequest>
 | 
			
		||||
#include <QUrlQuery>
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
#include "Logging.h"
 | 
			
		||||
#include "minecraft/auth/AuthRequest.h"
 | 
			
		||||
#include "minecraft/auth/Parsers.h"
 | 
			
		||||
#include "net/NetUtils.h"
 | 
			
		||||
@@ -56,9 +56,7 @@ void XboxProfileStep::onRequestDone(
 | 
			
		||||
 | 
			
		||||
    if (error != QNetworkReply::NoError) {
 | 
			
		||||
        qWarning() << "Reply error:" << error;
 | 
			
		||||
#ifndef NDEBUG
 | 
			
		||||
        qDebug() << data;
 | 
			
		||||
#endif
 | 
			
		||||
        qCDebug(authCredentials()) << data;
 | 
			
		||||
        if (Net::isApplicationError(error)) {
 | 
			
		||||
            emit finished(
 | 
			
		||||
                AccountTaskState::STATE_FAILED_SOFT,
 | 
			
		||||
@@ -74,9 +72,7 @@ void XboxProfileStep::onRequestDone(
 | 
			
		||||
        return;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
#ifndef NDEBUG
 | 
			
		||||
    qDebug() << "XBox profile: " << data;
 | 
			
		||||
#endif
 | 
			
		||||
    qCDebug(authCredentials()) << "XBox profile: " << data;
 | 
			
		||||
 | 
			
		||||
    emit finished(AccountTaskState::STATE_WORKING, tr("Got Xbox profile"));
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user