[libcalamaresui] Implement abstract doLogUpload() API
This is a "do the right thing" function, which then calls the implementation-specific code for each type.
This commit is contained in:
parent
1ff854f05d
commit
81badc36f4
@ -142,7 +142,8 @@ ViewManager::insertViewStep( int before, ViewStep* step )
|
|||||||
void
|
void
|
||||||
ViewManager::onInstallationFailed( const QString& message, const QString& details )
|
ViewManager::onInstallationFailed( const QString& message, const QString& details )
|
||||||
{
|
{
|
||||||
bool shouldOfferWebPaste = Calamares::Branding::instance()->uploadServer().first != Calamares::Branding::UploadServerType::None;
|
bool shouldOfferWebPaste
|
||||||
|
= Calamares::Branding::instance()->uploadServer().first != Calamares::Branding::UploadServerType::None;
|
||||||
|
|
||||||
cError() << "Installation failed:" << message;
|
cError() << "Installation failed:" << message;
|
||||||
cDebug() << Logger::SubEntry << "- message:" << message;
|
cDebug() << Logger::SubEntry << "- message:" << message;
|
||||||
@ -188,7 +189,7 @@ ViewManager::onInstallationFailed( const QString& message, const QString& detail
|
|||||||
connect( msgBox, &QMessageBox::buttonClicked, [msgBox]( QAbstractButton* button ) {
|
connect( msgBox, &QMessageBox::buttonClicked, [msgBox]( QAbstractButton* button ) {
|
||||||
if ( msgBox->buttonRole( button ) == QMessageBox::ButtonRole::YesRole )
|
if ( msgBox->buttonRole( button ) == QMessageBox::ButtonRole::YesRole )
|
||||||
{
|
{
|
||||||
QString pasteUrlMsg = CalamaresUtils::Paste::doLogUpload();
|
QString pasteUrlMsg = CalamaresUtils::Paste::doLogUpload( msgBox );
|
||||||
|
|
||||||
QString pasteUrlTitle = tr( "Install Log Paste URL" );
|
QString pasteUrlTitle = tr( "Install Log Paste URL" );
|
||||||
if ( pasteUrlMsg.isEmpty() )
|
if ( pasteUrlMsg.isEmpty() )
|
||||||
|
@ -36,14 +36,10 @@ logFileContents()
|
|||||||
return pasteSourceFile.read( 16384 /* bytes */ );
|
return pasteSourceFile.read( 16384 /* bytes */ );
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace CalamaresUtils
|
|
||||||
{
|
|
||||||
|
|
||||||
QString
|
static QString
|
||||||
ficheLogUpload( QObject* parent )
|
ficheLogUpload( const QUrl& serverUrl, QObject* parent )
|
||||||
{
|
{
|
||||||
auto [ type, serverUrl ] = Calamares::Branding::instance()->uploadServer();
|
|
||||||
|
|
||||||
QByteArray pasteData = logFileContents();
|
QByteArray pasteData = logFileContents();
|
||||||
if ( pasteData.isEmpty() )
|
if ( pasteData.isEmpty() )
|
||||||
{
|
{
|
||||||
@ -110,4 +106,24 @@ ficheLogUpload( QObject* parent )
|
|||||||
cDebug() << Logger::SubEntry << "Paste server results:" << pasteUrlMsg;
|
cDebug() << Logger::SubEntry << "Paste server results:" << pasteUrlMsg;
|
||||||
return pasteUrlMsg;
|
return pasteUrlMsg;
|
||||||
}
|
}
|
||||||
} // namespace CalamaresUtils
|
|
||||||
|
QString
|
||||||
|
CalamaresUtils::Paste::doLogUpload( QObject* parent )
|
||||||
|
{
|
||||||
|
auto [ type, serverUrl ] = Calamares::Branding::instance()->uploadServer();
|
||||||
|
if ( !serverUrl.isValid() )
|
||||||
|
{
|
||||||
|
cWarning() << "Upload configure with invalid URL";
|
||||||
|
return QString();
|
||||||
|
}
|
||||||
|
|
||||||
|
switch ( type )
|
||||||
|
{
|
||||||
|
case Calamares::Branding::UploadServerType::None:
|
||||||
|
cWarning() << "No upload configured.";
|
||||||
|
return QString();
|
||||||
|
case Calamares::Branding::UploadServerType::Fiche:
|
||||||
|
return ficheLogUpload( serverUrl, parent );
|
||||||
|
}
|
||||||
|
return QString();
|
||||||
|
}
|
||||||
|
@ -16,12 +16,15 @@ class QObject;
|
|||||||
|
|
||||||
namespace CalamaresUtils
|
namespace CalamaresUtils
|
||||||
{
|
{
|
||||||
|
namespace Paste
|
||||||
|
{
|
||||||
|
|
||||||
/** @brief Send the current log file to a pastebin
|
/** @brief Send the current log file to a pastebin
|
||||||
*
|
*
|
||||||
* Returns the (string) URL that the pastebin gives us.
|
* Returns the (string) URL that the pastebin gives us.
|
||||||
*/
|
*/
|
||||||
QString ficheLogUpload( QObject* parent );
|
QString doLogUpload( QObject* parent );
|
||||||
|
} // namespace Paste
|
||||||
|
|
||||||
} // namespace CalamaresUtils
|
} // namespace CalamaresUtils
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user