Browse Source

Merge pull request #5549 from briankendall/smtp_ssl_bug_fixes

Fixes bug where sending email could silently fail
adaptive-webui-19844
sledgehammer999 8 years ago committed by GitHub
parent
commit
d411d8b3a1
  1. 16
      src/base/net/smtp.cpp
  2. 7
      src/base/net/smtp.h
  3. 1
      src/gui/optionsdlg.cpp

16
src/base/net/smtp.cpp

@ -97,6 +97,13 @@ Smtp::Smtp(QObject *parent) @@ -97,6 +97,13 @@ Smtp::Smtp(QObject *parent)
, m_useSsl(false)
, m_authType(AuthPlain)
{
static bool needToRegisterMetaType = true;
if (needToRegisterMetaType) {
qRegisterMetaType<QAbstractSocket::SocketError>();
needToRegisterMetaType = false;
}
#ifndef QT_NO_OPENSSL
m_socket = new QSslSocket(this);
#else
@ -105,6 +112,7 @@ Smtp::Smtp(QObject *parent) @@ -105,6 +112,7 @@ Smtp::Smtp(QObject *parent)
connect(m_socket, SIGNAL(readyRead()), SLOT(readyRead()));
connect(m_socket, SIGNAL(disconnected()), SLOT(deleteLater()));
connect(m_socket, SIGNAL(error(QAbstractSocket::SocketError)), SLOT(error(QAbstractSocket::SocketError)));
// Test hmacMD5 function (http://www.faqs.org/rfcs/rfc2202.html)
Q_ASSERT(hmacMD5("Jefe", "what do ya want for nothing?").toHex()
@ -525,3 +533,11 @@ QString Smtp::getCurrentDateTime() const @@ -525,3 +533,11 @@ QString Smtp::getCurrentDateTime() const
QString ret = weekDayStr + ", " + dayStr + " " + monthStr + " " + yearStr + " " + timeStr + " " + timeOffsetStr;
return ret;
}
void Smtp::error(QAbstractSocket::SocketError socketError)
{
// Getting a remote host closed error is apparently normal, even when successfully sending
// an email
if (socketError != QAbstractSocket::RemoteHostClosedError)
logError(m_socket->errorString());
}

7
src/base/net/smtp.h

@ -39,6 +39,8 @@ @@ -39,6 +39,8 @@
#include <QObject>
#include <QByteArray>
#include <QHash>
#include <QAbstractSocket>
#include <QMetaType>
QT_BEGIN_NAMESPACE
class QTextStream;
@ -64,6 +66,7 @@ namespace Net @@ -64,6 +66,7 @@ namespace Net
private slots:
void readyRead();
void error(QAbstractSocket::SocketError socketError);
private:
enum States
@ -123,4 +126,8 @@ namespace Net @@ -123,4 +126,8 @@ namespace Net
};
}
#ifndef QBT_USES_QT5
Q_DECLARE_METATYPE(QAbstractSocket::SocketError)
#endif
#endif

1
src/gui/optionsdlg.cpp

@ -149,6 +149,7 @@ OptionsDialog::OptionsDialog(QWidget *parent) @@ -149,6 +149,7 @@ OptionsDialog::OptionsDialog(QWidget *parent)
#if defined(QT_NO_OPENSSL)
m_ui->checkWebUiHttps->setVisible(false);
m_ui->checkSmtpSSL->setVisible(false);
#endif
#ifndef Q_OS_WIN

Loading…
Cancel
Save