Integrate changes from olehs's repository:
https://github.com/olehs/SmtpClient-for-Qt
This commit is contained in:
parent
ace683a658
commit
b90aa7cfc3
@ -13,10 +13,10 @@ int main(int argc, char *argv[])
|
|||||||
MimeMessage message;
|
MimeMessage message;
|
||||||
|
|
||||||
EmailAddress sender("your_email_address@host.com", "Your Name");
|
EmailAddress sender("your_email_address@host.com", "Your Name");
|
||||||
message.setSender(&sender);
|
message.setSender(sender);
|
||||||
|
|
||||||
EmailAddress to("recipient@host.com", "Recipient's Name");
|
EmailAddress to("recipient@host.com", "Recipient's Name");
|
||||||
message.addRecipient(&to);
|
message.addRecipient(to);
|
||||||
|
|
||||||
message.setSubject("SmtpClient for Qt - Demo");
|
message.setSubject("SmtpClient for Qt - Demo");
|
||||||
|
|
||||||
|
@ -37,7 +37,7 @@ SendEmail::~SendEmail()
|
|||||||
delete ui;
|
delete ui;
|
||||||
}
|
}
|
||||||
|
|
||||||
EmailAddress* SendEmail::stringToEmail(const QString &str)
|
EmailAddress SendEmail::stringToEmail(const QString &str)
|
||||||
{
|
{
|
||||||
int p1 = str.indexOf("<");
|
int p1 = str.indexOf("<");
|
||||||
int p2 = str.indexOf(">");
|
int p2 = str.indexOf(">");
|
||||||
@ -45,11 +45,11 @@ EmailAddress* SendEmail::stringToEmail(const QString &str)
|
|||||||
if (p1 == -1)
|
if (p1 == -1)
|
||||||
{
|
{
|
||||||
// no name, only email address
|
// no name, only email address
|
||||||
return new EmailAddress(str);
|
return EmailAddress(str);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
return new EmailAddress(str.mid(p1 + 1, p2 - p1 - 1), str.left(p1));
|
return EmailAddress(str.mid(p1 + 1, p2 - p1 - 1), str.left(p1));
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -59,11 +59,8 @@ void SendEmail::on_addAttachment_clicked()
|
|||||||
QFileDialog dialog(this);
|
QFileDialog dialog(this);
|
||||||
dialog.setFileMode(QFileDialog::ExistingFiles);
|
dialog.setFileMode(QFileDialog::ExistingFiles);
|
||||||
|
|
||||||
|
|
||||||
if (dialog.exec())
|
if (dialog.exec())
|
||||||
ui->attachments->addItems(dialog.selectedFiles());
|
ui->attachments->addItems(dialog.selectedFiles());
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void SendEmail::on_sendEmail_clicked()
|
void SendEmail::on_sendEmail_clicked()
|
||||||
@ -75,7 +72,7 @@ void SendEmail::on_sendEmail_clicked()
|
|||||||
QString user = ui->username->text();
|
QString user = ui->username->text();
|
||||||
QString password = ui->password->text();
|
QString password = ui->password->text();
|
||||||
|
|
||||||
EmailAddress *sender = stringToEmail(ui->sender->text());
|
EmailAddress sender = stringToEmail(ui->sender->text());
|
||||||
|
|
||||||
QStringList rcptStringList = ui->recipients->text().split(';');
|
QStringList rcptStringList = ui->recipients->text().split(';');
|
||||||
|
|
||||||
|
@ -33,7 +33,7 @@ public:
|
|||||||
explicit SendEmail(QWidget *parent = 0);
|
explicit SendEmail(QWidget *parent = 0);
|
||||||
~SendEmail();
|
~SendEmail();
|
||||||
|
|
||||||
static EmailAddress * stringToEmail(const QString & str);
|
static EmailAddress stringToEmail(const QString & str);
|
||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
void on_addAttachment_clicked();
|
void on_addAttachment_clicked();
|
||||||
|
@ -26,10 +26,10 @@ int main(int argc, char *argv[])
|
|||||||
MimeMessage message;
|
MimeMessage message;
|
||||||
|
|
||||||
EmailAddress sender("your_email_address@host.com", "Your Name");
|
EmailAddress sender("your_email_address@host.com", "Your Name");
|
||||||
message.setSender(&sender);
|
message.setSender(sender);
|
||||||
|
|
||||||
EmailAddress to("recipient@host.com", "Recipient's Name");
|
EmailAddress to("recipient@host.com", "Recipient's Name");
|
||||||
message.addRecipient(&to);
|
message.addRecipient(to);
|
||||||
|
|
||||||
message.setSubject("SmtpClient for Qt - Demo");
|
message.setSubject("SmtpClient for Qt - Demo");
|
||||||
|
|
||||||
|
@ -27,10 +27,10 @@ int main(int argc, char *argv[])
|
|||||||
MimeMessage message;
|
MimeMessage message;
|
||||||
|
|
||||||
EmailAddress sender("your_email_address@host.com", "Your Name");
|
EmailAddress sender("your_email_address@host.com", "Your Name");
|
||||||
message.setSender(&sender);
|
message.setSender(sender);
|
||||||
|
|
||||||
EmailAddress to("recipient@host.com", "Recipient's Name");
|
EmailAddress to("recipient@host.com", "Recipient's Name");
|
||||||
message.addRecipient(&to);
|
message.addRecipient(to);
|
||||||
|
|
||||||
message.setSubject("SmtpClient for Qt - Example 3 - Html email with images");
|
message.setSubject("SmtpClient for Qt - Example 3 - Html email with images");
|
||||||
|
|
||||||
|
@ -21,9 +21,13 @@
|
|||||||
/* [1] Constructors and Destructors */
|
/* [1] Constructors and Destructors */
|
||||||
|
|
||||||
EmailAddress::EmailAddress(const QString & address, const QString & name)
|
EmailAddress::EmailAddress(const QString & address, const QString & name)
|
||||||
|
: address(address), name(name)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
EmailAddress::EmailAddress(const EmailAddress &other)
|
||||||
|
: address(other.address), name(other.name)
|
||||||
{
|
{
|
||||||
this->address = address;
|
|
||||||
this->name = name;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
EmailAddress::~EmailAddress()
|
EmailAddress::~EmailAddress()
|
||||||
@ -35,23 +39,13 @@ EmailAddress::~EmailAddress()
|
|||||||
|
|
||||||
/* [2] Getters and Setters */
|
/* [2] Getters and Setters */
|
||||||
|
|
||||||
void EmailAddress::setName(const QString & name)
|
|
||||||
{
|
|
||||||
this->name = name;
|
|
||||||
|
|
||||||
}
|
QString EmailAddress::getName() const
|
||||||
|
|
||||||
void EmailAddress::setAddress(const QString & address)
|
|
||||||
{
|
|
||||||
this->address = address;
|
|
||||||
}
|
|
||||||
|
|
||||||
const QString & EmailAddress::getName() const
|
|
||||||
{
|
{
|
||||||
return name;
|
return name;
|
||||||
}
|
}
|
||||||
|
|
||||||
const QString & EmailAddress::getAddress() const
|
QString EmailAddress::getAddress() const
|
||||||
{
|
{
|
||||||
return address;
|
return address;
|
||||||
}
|
}
|
||||||
|
@ -28,8 +28,8 @@ public:
|
|||||||
|
|
||||||
/* [1] Constructors and Destructors */
|
/* [1] Constructors and Destructors */
|
||||||
|
|
||||||
EmailAddress();
|
EmailAddress(const QString & address = "", const QString & name = "");
|
||||||
EmailAddress(const QString & address, const QString & name="");
|
EmailAddress(const EmailAddress &other);
|
||||||
|
|
||||||
~EmailAddress();
|
~EmailAddress();
|
||||||
|
|
||||||
@ -37,11 +37,9 @@ public:
|
|||||||
|
|
||||||
|
|
||||||
/* [2] Getters and Setters */
|
/* [2] Getters and Setters */
|
||||||
void setName(const QString & name);
|
|
||||||
void setAddress(const QString & address);
|
|
||||||
|
|
||||||
const QString & getName() const;
|
QString getAddress() const;
|
||||||
const QString & getAddress() const;
|
QString getName() const;
|
||||||
|
|
||||||
/* [2] --- */
|
/* [2] --- */
|
||||||
|
|
||||||
@ -50,8 +48,8 @@ private:
|
|||||||
|
|
||||||
/* [3] Private members */
|
/* [3] Private members */
|
||||||
|
|
||||||
QString name;
|
|
||||||
QString address;
|
QString address;
|
||||||
|
QString name;
|
||||||
|
|
||||||
/* [3] --- */
|
/* [3] --- */
|
||||||
};
|
};
|
||||||
|
@ -4,7 +4,6 @@ MimeBase64Formatter::MimeBase64Formatter(QIODevice *out) :
|
|||||||
MimeContentFormatter(out) {}
|
MimeContentFormatter(out) {}
|
||||||
|
|
||||||
qint64 MimeBase64Formatter::writeData(const char *data, qint64 maxLength) {
|
qint64 MimeBase64Formatter::writeData(const char *data, qint64 maxLength) {
|
||||||
qDebug("called");
|
|
||||||
int lines = (maxLength - 1) / lineLength + 1;
|
int lines = (maxLength - 1) / lineLength + 1;
|
||||||
for (int i = 1; i < lines; ++i) {
|
for (int i = 1; i < lines; ++i) {
|
||||||
output->write(data, lineLength);
|
output->write(data, lineLength);
|
||||||
|
@ -37,7 +37,7 @@ void MimeHtml::setHtml(const QString & html)
|
|||||||
this->text = html;
|
this->text = html;
|
||||||
}
|
}
|
||||||
|
|
||||||
const QString & MimeHtml::getHtml() const
|
QString MimeHtml::getHtml() const
|
||||||
{
|
{
|
||||||
return text;
|
return text;
|
||||||
}
|
}
|
||||||
|
@ -38,7 +38,7 @@ public:
|
|||||||
|
|
||||||
void setHtml(const QString & html);
|
void setHtml(const QString & html);
|
||||||
|
|
||||||
const QString& getHtml() const;
|
QString getHtml() const;
|
||||||
|
|
||||||
/* [2] --- */
|
/* [2] --- */
|
||||||
|
|
||||||
|
@ -23,7 +23,7 @@
|
|||||||
MimeInlineFile::MimeInlineFile(QFile *f)
|
MimeInlineFile::MimeInlineFile(QFile *f)
|
||||||
: MimeFile(f)
|
: MimeFile(f)
|
||||||
{
|
{
|
||||||
this->headerLines += "Content-Disposition: inline\r\n";
|
addHeaderLine("Content-Disposition: inline");
|
||||||
}
|
}
|
||||||
|
|
||||||
MimeInlineFile::~MimeInlineFile()
|
MimeInlineFile::~MimeInlineFile()
|
||||||
|
@ -49,12 +49,12 @@ void MimeMessage::setContent(MimePart *content) {
|
|||||||
this->content = content;
|
this->content = content;
|
||||||
}
|
}
|
||||||
|
|
||||||
void MimeMessage::setSender(EmailAddress* e)
|
void MimeMessage::setSender(const EmailAddress &sender)
|
||||||
{
|
{
|
||||||
this->sender = e;
|
this->sender = sender;
|
||||||
}
|
}
|
||||||
|
|
||||||
void MimeMessage::addRecipient(EmailAddress* rcpt, RecipientType type)
|
void MimeMessage::addRecipient(const EmailAddress &rcpt, RecipientType type)
|
||||||
{
|
{
|
||||||
switch (type)
|
switch (type)
|
||||||
{
|
{
|
||||||
@ -70,18 +70,23 @@ void MimeMessage::addRecipient(EmailAddress* rcpt, RecipientType type)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void MimeMessage::addTo(EmailAddress* rcpt) {
|
void MimeMessage::addTo(const EmailAddress &rcpt) {
|
||||||
this->recipientsTo << rcpt;
|
this->recipientsTo << rcpt;
|
||||||
}
|
}
|
||||||
|
|
||||||
void MimeMessage::addCc(EmailAddress* rcpt) {
|
void MimeMessage::addCc(const EmailAddress &rcpt) {
|
||||||
this->recipientsCc << rcpt;
|
this->recipientsCc << rcpt;
|
||||||
}
|
}
|
||||||
|
|
||||||
void MimeMessage::addBcc(EmailAddress* rcpt) {
|
void MimeMessage::addBcc(const EmailAddress &rcpt) {
|
||||||
this->recipientsBcc << rcpt;
|
this->recipientsBcc << rcpt;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void MimeMessage::addCustomHeader(const QString &header)
|
||||||
|
{
|
||||||
|
this->customHeaders << header;
|
||||||
|
}
|
||||||
|
|
||||||
void MimeMessage::setSubject(const QString & subject)
|
void MimeMessage::setSubject(const QString & subject)
|
||||||
{
|
{
|
||||||
this->subject = subject;
|
this->subject = subject;
|
||||||
@ -99,12 +104,12 @@ void MimeMessage::setHeaderEncoding(MimePart::Encoding hEnc)
|
|||||||
this->hEncoding = hEnc;
|
this->hEncoding = hEnc;
|
||||||
}
|
}
|
||||||
|
|
||||||
const EmailAddress & MimeMessage::getSender() const
|
EmailAddress MimeMessage::getSender() const
|
||||||
{
|
{
|
||||||
return *sender;
|
return sender;
|
||||||
}
|
}
|
||||||
|
|
||||||
const QList<EmailAddress*> & MimeMessage::getRecipients(RecipientType type) const
|
const QList<EmailAddress> & MimeMessage::getRecipients(RecipientType type) const
|
||||||
{
|
{
|
||||||
switch (type)
|
switch (type)
|
||||||
{
|
{
|
||||||
@ -118,7 +123,7 @@ const QList<EmailAddress*> & MimeMessage::getRecipients(RecipientType type) cons
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const QString & MimeMessage::getSubject() const
|
QString MimeMessage::getSubject() const
|
||||||
{
|
{
|
||||||
return subject;
|
return subject;
|
||||||
}
|
}
|
||||||
@ -148,23 +153,30 @@ QString MimeMessage::toString() const
|
|||||||
return QString(out.buffer());
|
return QString(out.buffer());
|
||||||
}
|
}
|
||||||
|
|
||||||
QByteArray MimeMessage::formatAddress(EmailAddress *address, MimePart::Encoding encoding) {
|
QByteArray MimeMessage::formatAddress(const EmailAddress &address, MimePart::Encoding encoding) {
|
||||||
QByteArray result;
|
QByteArray result;
|
||||||
if (!address->getName().isEmpty())
|
result.append(format(address.getName(), encoding));
|
||||||
|
result.append(" <" + address.getAddress() + ">");
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
QByteArray MimeMessage::format(const QString &text, MimePart::Encoding encoding)
|
||||||
|
{
|
||||||
|
QByteArray result;
|
||||||
|
if (!text.isEmpty())
|
||||||
{
|
{
|
||||||
switch (encoding)
|
switch (encoding)
|
||||||
{
|
{
|
||||||
case MimePart::Base64:
|
case MimePart::Base64:
|
||||||
result.append(" =?utf-8?B?" + address->getName().toLocal8Bit().toBase64() + "?=");
|
result.append(" =?utf-8?B?" + text.toUtf8().toBase64() + "?=");
|
||||||
break;
|
break;
|
||||||
case MimePart::QuotedPrintable:
|
case MimePart::QuotedPrintable:
|
||||||
result.append(" =?utf-8?Q?" + QuotedPrintable::encode(address->getName().toLocal8Bit()).toLocal8Bit().replace(' ', "_").replace(':',"=3A") + "?=");
|
result.append(" =?utf-8?Q?" + QuotedPrintable::encode(text.toUtf8()).toLocal8Bit().replace(' ', "_").replace(':',"=3A") + "?=");
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
result.append(" ").append(address->getName().toLocal8Bit());
|
result.append(" ").append(text.toLocal8Bit());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
result.append(" <" + address->getAddress() + ">");
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -202,22 +214,15 @@ void MimeMessage::writeToDevice(QIODevice &out) const {
|
|||||||
|
|
||||||
/* ------------ Subject ------------- */
|
/* ------------ Subject ------------- */
|
||||||
header.append("Subject: ");
|
header.append("Subject: ");
|
||||||
|
header.append(format(subject, hEncoding));
|
||||||
|
header.append("\r\n");
|
||||||
switch (hEncoding)
|
|
||||||
{
|
|
||||||
case MimePart::Base64:
|
|
||||||
header.append("=?utf-8?B?" + subject.toLocal8Bit().toBase64() + "?=");
|
|
||||||
break;
|
|
||||||
case MimePart::QuotedPrintable:
|
|
||||||
header.append("=?utf-8?Q?" + QuotedPrintable::encode(subject.toLocal8Bit()).toLocal8Bit().replace(' ', "_").replace(':',"=3A") + "?=");
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
header.append(subject);
|
|
||||||
}
|
|
||||||
/* ---------------------------------- */
|
/* ---------------------------------- */
|
||||||
|
|
||||||
|
foreach (QString hdr, customHeaders) {
|
||||||
|
header.append(hdr.toLocal8Bit());
|
||||||
header.append("\r\n");
|
header.append("\r\n");
|
||||||
|
}
|
||||||
|
|
||||||
header.append("MIME-Version: 1.0\r\n");
|
header.append("MIME-Version: 1.0\r\n");
|
||||||
|
|
||||||
out.write(header);
|
out.write(header);
|
||||||
|
@ -19,7 +19,7 @@
|
|||||||
#ifndef MIMEMESSAGE_H
|
#ifndef MIMEMESSAGE_H
|
||||||
#define MIMEMESSAGE_H
|
#define MIMEMESSAGE_H
|
||||||
|
|
||||||
#include <QList>
|
#include <QStringList>
|
||||||
#include <QTextStream>
|
#include <QTextStream>
|
||||||
|
|
||||||
#include "smtpmime_global.h"
|
#include "smtpmime_global.h"
|
||||||
@ -39,7 +39,7 @@ public:
|
|||||||
|
|
||||||
/* [1] Constructors and Destructors */
|
/* [1] Constructors and Destructors */
|
||||||
|
|
||||||
MimeMessage(bool createAutoMimeConent = true);
|
MimeMessage(bool createAutoMimeContent = true);
|
||||||
~MimeMessage();
|
~MimeMessage();
|
||||||
|
|
||||||
/* [1] --- */
|
/* [1] --- */
|
||||||
@ -47,19 +47,21 @@ public:
|
|||||||
|
|
||||||
/* [2] Getters and Setters */
|
/* [2] Getters and Setters */
|
||||||
|
|
||||||
void setSender(EmailAddress* e);
|
void setSender(const EmailAddress &sndr);
|
||||||
void addRecipient(EmailAddress* rcpt, RecipientType type = To);
|
void addRecipient(const EmailAddress &rcpt, RecipientType type = To);
|
||||||
void addTo(EmailAddress* rcpt);
|
void addTo(const EmailAddress &rcpt);
|
||||||
void addCc(EmailAddress* rcpt);
|
void addCc(const EmailAddress &rcpt);
|
||||||
void addBcc(EmailAddress* rcpt);
|
void addBcc(const EmailAddress &rcpt);
|
||||||
|
void addCustomHeader(const QString &hdr);
|
||||||
void setSubject(const QString &subject);
|
void setSubject(const QString &subject);
|
||||||
void addPart(MimePart* part);
|
void addPart(MimePart* part);
|
||||||
|
|
||||||
void setHeaderEncoding(MimePart::Encoding);
|
void setHeaderEncoding(MimePart::Encoding);
|
||||||
|
|
||||||
const EmailAddress & getSender() const;
|
EmailAddress getSender() const;
|
||||||
const QList<EmailAddress*> & getRecipients(RecipientType type = To) const;
|
const QList<EmailAddress> &getRecipients(RecipientType type = To) const;
|
||||||
const QString & getSubject() const;
|
QString getSubject() const;
|
||||||
|
const QStringList &getCustomHeaders() const;
|
||||||
const QList<MimePart*> & getParts() const;
|
const QList<MimePart*> & getParts() const;
|
||||||
|
|
||||||
MimePart& getContent();
|
MimePart& getContent();
|
||||||
@ -78,14 +80,16 @@ protected:
|
|||||||
|
|
||||||
/* [4] Protected members */
|
/* [4] Protected members */
|
||||||
|
|
||||||
EmailAddress* sender;
|
EmailAddress sender;
|
||||||
QList<EmailAddress*> recipientsTo, recipientsCc, recipientsBcc;
|
QList<EmailAddress> recipientsTo, recipientsCc, recipientsBcc;
|
||||||
QString subject;
|
QString subject;
|
||||||
|
QStringList customHeaders;
|
||||||
MimePart *content;
|
MimePart *content;
|
||||||
|
|
||||||
MimePart::Encoding hEncoding;
|
MimePart::Encoding hEncoding;
|
||||||
|
|
||||||
static QByteArray formatAddress(EmailAddress*, MimePart::Encoding);
|
static QByteArray format(const QString &text, MimePart::Encoding encoding);
|
||||||
|
static QByteArray formatAddress(const EmailAddress &address, MimePart::Encoding encoding);
|
||||||
|
|
||||||
/* [4] --- */
|
/* [4] --- */
|
||||||
|
|
||||||
|
@ -43,7 +43,9 @@ MimeMultiPart::MimeMultiPart(MultiPartType type)
|
|||||||
}
|
}
|
||||||
|
|
||||||
MimeMultiPart::~MimeMultiPart() {
|
MimeMultiPart::~MimeMultiPart() {
|
||||||
|
foreach (MimePart *part, parts) {
|
||||||
|
delete part;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void MimeMultiPart::addPart(MimePart *part) {
|
void MimeMultiPart::addPart(MimePart *part) {
|
||||||
|
@ -58,12 +58,12 @@ void MimePart::addHeaderLine(const QString & line)
|
|||||||
this->headerLines += line + "\r\n";
|
this->headerLines += line + "\r\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
const QString& MimePart::getHeader() const
|
QString MimePart::getHeader() const
|
||||||
{
|
{
|
||||||
return headerLines;
|
return headerLines;
|
||||||
}
|
}
|
||||||
|
|
||||||
const QByteArray& MimePart::getContent() const
|
QByteArray MimePart::getContent() const
|
||||||
{
|
{
|
||||||
return content;
|
return content;
|
||||||
}
|
}
|
||||||
@ -73,7 +73,7 @@ void MimePart::setContentId(const QString & cId)
|
|||||||
this->cId = cId;
|
this->cId = cId;
|
||||||
}
|
}
|
||||||
|
|
||||||
const QString & MimePart::getContentId() const
|
QString MimePart::getContentId() const
|
||||||
{
|
{
|
||||||
return this->cId;
|
return this->cId;
|
||||||
}
|
}
|
||||||
@ -83,7 +83,7 @@ void MimePart::setContentName(const QString & cName)
|
|||||||
this->cName = cName;
|
this->cName = cName;
|
||||||
}
|
}
|
||||||
|
|
||||||
const QString & MimePart::getContentName() const
|
QString MimePart::getContentName() const
|
||||||
{
|
{
|
||||||
return this->cName;
|
return this->cName;
|
||||||
}
|
}
|
||||||
@ -93,7 +93,7 @@ void MimePart::setContentType(const QString & cType)
|
|||||||
this->cType = cType;
|
this->cType = cType;
|
||||||
}
|
}
|
||||||
|
|
||||||
const QString & MimePart::getContentType() const
|
QString MimePart::getContentType() const
|
||||||
{
|
{
|
||||||
return this->cType;
|
return this->cType;
|
||||||
}
|
}
|
||||||
@ -103,7 +103,7 @@ void MimePart::setCharset(const QString & charset)
|
|||||||
this->cCharset = charset;
|
this->cCharset = charset;
|
||||||
}
|
}
|
||||||
|
|
||||||
const QString & MimePart::getCharset() const
|
QString MimePart::getCharset() const
|
||||||
{
|
{
|
||||||
return this->cCharset;
|
return this->cCharset;
|
||||||
}
|
}
|
||||||
|
@ -51,25 +51,25 @@ public:
|
|||||||
|
|
||||||
/* [2] Getters and Setters */
|
/* [2] Getters and Setters */
|
||||||
|
|
||||||
const QString& getHeader() const;
|
|
||||||
const QByteArray& getContent() const;
|
|
||||||
|
|
||||||
void setContent(const QByteArray & content);
|
void setContent(const QByteArray & content);
|
||||||
|
QByteArray getContent() const;
|
||||||
|
|
||||||
void setHeader(const QString & headerLines);
|
void setHeader(const QString & headerLines);
|
||||||
|
QString getHeader() const;
|
||||||
|
|
||||||
void addHeaderLine(const QString & line);
|
void addHeaderLine(const QString & line);
|
||||||
|
|
||||||
void setContentId(const QString & cId);
|
void setContentId(const QString & cId);
|
||||||
const QString & getContentId() const;
|
QString getContentId() const;
|
||||||
|
|
||||||
void setContentName(const QString & cName);
|
void setContentName(const QString & cName);
|
||||||
const QString & getContentName() const;
|
QString getContentName() const;
|
||||||
|
|
||||||
void setContentType(const QString & cType);
|
void setContentType(const QString & cType);
|
||||||
const QString & getContentType() const;
|
QString getContentType() const;
|
||||||
|
|
||||||
void setCharset(const QString & charset);
|
void setCharset(const QString & charset);
|
||||||
const QString & getCharset() const;
|
QString getCharset() const;
|
||||||
|
|
||||||
void setEncoding(Encoding enc);
|
void setEncoding(Encoding enc);
|
||||||
Encoding getEncoding() const;
|
Encoding getEncoding() const;
|
||||||
|
@ -33,7 +33,8 @@ SmtpClient::SmtpClient(const QString & host, int port, ConnectionType connection
|
|||||||
name("localhost"),
|
name("localhost"),
|
||||||
isReadyConnected(false),
|
isReadyConnected(false),
|
||||||
isAuthenticated(false),
|
isAuthenticated(false),
|
||||||
isMailSent(false)
|
isMailSent(false),
|
||||||
|
isReset(false)
|
||||||
{
|
{
|
||||||
setConnectionType(connectionType);
|
setConnectionType(connectionType);
|
||||||
|
|
||||||
@ -54,7 +55,7 @@ SmtpClient::~SmtpClient() {}
|
|||||||
/**
|
/**
|
||||||
* @brief Returns the host name of the server.
|
* @brief Returns the host name of the server.
|
||||||
*/
|
*/
|
||||||
const QString& SmtpClient::getHost() const
|
QString SmtpClient::getHost() const
|
||||||
{
|
{
|
||||||
return this->host;
|
return this->host;
|
||||||
}
|
}
|
||||||
@ -78,7 +79,7 @@ SmtpClient::ConnectionType SmtpClient::getConnectionType() const
|
|||||||
/**
|
/**
|
||||||
* @brief Returns the client's name.
|
* @brief Returns the client's name.
|
||||||
*/
|
*/
|
||||||
const QString& SmtpClient::getName() const
|
QString SmtpClient::getName() const
|
||||||
{
|
{
|
||||||
return this->name;
|
return this->name;
|
||||||
}
|
}
|
||||||
@ -94,7 +95,7 @@ void SmtpClient::setName(const QString &name)
|
|||||||
/**
|
/**
|
||||||
* @brief Returns the last response of the server.
|
* @brief Returns the last response of the server.
|
||||||
*/
|
*/
|
||||||
const QString & SmtpClient::getResponseText() const
|
QString SmtpClient::getResponseText() const
|
||||||
{
|
{
|
||||||
return responseText;
|
return responseText;
|
||||||
}
|
}
|
||||||
@ -160,19 +161,24 @@ void SmtpClient::quit()
|
|||||||
changeState(DisconnectingState);
|
changeState(DisconnectingState);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void SmtpClient::reset()
|
||||||
|
{
|
||||||
|
if (!isReadyConnected)
|
||||||
|
return;
|
||||||
|
|
||||||
|
isReset = false;
|
||||||
|
|
||||||
|
changeState(ResetState);
|
||||||
|
}
|
||||||
|
|
||||||
bool SmtpClient::waitForReadyConnected(int msec) {
|
bool SmtpClient::waitForReadyConnected(int msec) {
|
||||||
if (state == UnconnectedState)
|
if (state == UnconnectedState)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
QEventLoop loop;
|
|
||||||
QObject::connect(this, SIGNAL(readyConnected()), &loop, SLOT(quit()));
|
|
||||||
|
|
||||||
if (isReadyConnected)
|
if (isReadyConnected)
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
QTimer::singleShot(msec, &loop, SLOT(quit()));
|
waitForEvent(msec, SIGNAL(readyConnected()));
|
||||||
loop.exec();
|
|
||||||
|
|
||||||
return isReadyConnected;
|
return isReadyConnected;
|
||||||
}
|
}
|
||||||
@ -181,14 +187,10 @@ bool SmtpClient::waitForAuthenticated(int msec) {
|
|||||||
if (!isReadyConnected)
|
if (!isReadyConnected)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
QEventLoop loop;
|
|
||||||
QObject::connect(this, SIGNAL(authenticated()), &loop, SLOT(quit()));
|
|
||||||
|
|
||||||
if (isAuthenticated)
|
if (isAuthenticated)
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
QTimer::singleShot(msec, &loop, SLOT(quit()));
|
waitForEvent(msec, SIGNAL(authenticated()));
|
||||||
loop.exec();
|
|
||||||
|
|
||||||
return isAuthenticated;
|
return isAuthenticated;
|
||||||
}
|
}
|
||||||
@ -197,18 +199,27 @@ bool SmtpClient::waitForMailSent(int msec) {
|
|||||||
if (!isReadyConnected)
|
if (!isReadyConnected)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
QEventLoop loop;
|
|
||||||
QObject::connect(this, SIGNAL(mailSent()), &loop, SLOT(quit()));
|
|
||||||
|
|
||||||
if (isMailSent)
|
if (isMailSent)
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
QTimer::singleShot(msec, &loop, SLOT(quit()));
|
waitForEvent(msec, SIGNAL(mailSent()));
|
||||||
loop.exec();
|
|
||||||
|
|
||||||
return isMailSent;
|
return isMailSent;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool SmtpClient::waitForReset(int msec)
|
||||||
|
{
|
||||||
|
if (!isReadyConnected)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
if (isReset)
|
||||||
|
return true;
|
||||||
|
|
||||||
|
waitForEvent(msec, SIGNAL(mailReset()));
|
||||||
|
|
||||||
|
return isReset;
|
||||||
|
}
|
||||||
|
|
||||||
/* [3] --- */
|
/* [3] --- */
|
||||||
|
|
||||||
|
|
||||||
@ -276,8 +287,12 @@ void SmtpClient::changeState(SmtpClient::ClientState state) {
|
|||||||
socket->disconnectFromHost();
|
socket->disconnectFromHost();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case ResetState:
|
||||||
|
sendMessage("RSET");
|
||||||
|
break;
|
||||||
|
|
||||||
case _EHLO_State:
|
case _EHLO_State:
|
||||||
// Service ready. Send EHLO message and chage the state
|
// Service ready. Send EHLO message and change the state
|
||||||
sendMessage("EHLO " + name);
|
sendMessage("EHLO " + name);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -345,7 +360,7 @@ void SmtpClient::changeState(SmtpClient::ClientState state) {
|
|||||||
|
|
||||||
case _MAIL_1_RCPT_INIT:
|
case _MAIL_1_RCPT_INIT:
|
||||||
rcptType++;
|
rcptType++;
|
||||||
const QList<EmailAddress*> *addressList;
|
const QList<EmailAddress> *addressList;
|
||||||
switch (rcptType)
|
switch (rcptType)
|
||||||
{
|
{
|
||||||
case _TO:
|
case _TO:
|
||||||
@ -368,7 +383,7 @@ void SmtpClient::changeState(SmtpClient::ClientState state) {
|
|||||||
|
|
||||||
case _MAIL_2_RCPT:
|
case _MAIL_2_RCPT:
|
||||||
if (addressIt != addressItEnd) {
|
if (addressIt != addressItEnd) {
|
||||||
sendMessage("RCPT TO: <" + (*addressIt)->getAddress() + ">");
|
sendMessage("RCPT TO: <" + addressIt->getAddress() + ">");
|
||||||
addressIt++;
|
addressIt++;
|
||||||
} else {
|
} else {
|
||||||
changeState(_MAIL_1_RCPT_INIT);
|
changeState(_MAIL_1_RCPT_INIT);
|
||||||
@ -407,15 +422,26 @@ void SmtpClient::processResponse() {
|
|||||||
case ConnectedState:
|
case ConnectedState:
|
||||||
// Just connected to the server. Wait for 220 (Service ready)
|
// Just connected to the server. Wait for 220 (Service ready)
|
||||||
if (responseCode != 220) {
|
if (responseCode != 220) {
|
||||||
emit error(ServerError); return;
|
emitError(ServerError);
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
changeState(_EHLO_State);
|
changeState(_EHLO_State);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case ResetState:
|
||||||
|
if (responseCode != 250) {
|
||||||
|
emitError(ServerError);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
emit mailReset();
|
||||||
|
changeState(ReadyState);
|
||||||
|
break;
|
||||||
|
|
||||||
case _EHLO_State:
|
case _EHLO_State:
|
||||||
// The response code needs to be 250.
|
// The response code needs to be 250.
|
||||||
if (responseCode != 250) {
|
if (responseCode != 250) {
|
||||||
emit error(ServerError); return;
|
emitError(ServerError);
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
changeState((connectionType != TlsConnection) ? _READY_Connected : _TLS_State);
|
changeState((connectionType != TlsConnection) ? _READY_Connected : _TLS_State);
|
||||||
@ -425,7 +451,7 @@ void SmtpClient::processResponse() {
|
|||||||
case _TLS_0_STARTTLS:
|
case _TLS_0_STARTTLS:
|
||||||
// The response code needs to be 220.
|
// The response code needs to be 220.
|
||||||
if (responseCode != 220) {
|
if (responseCode != 220) {
|
||||||
emit error(ServerError);
|
emitError(ServerError);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
changeState(_TLS_1_ENCRYPT);
|
changeState(_TLS_1_ENCRYPT);
|
||||||
@ -434,7 +460,7 @@ void SmtpClient::processResponse() {
|
|||||||
case _TLS_2_EHLO:
|
case _TLS_2_EHLO:
|
||||||
// The response code needs to be 250.
|
// The response code needs to be 250.
|
||||||
if (responseCode != 250) {
|
if (responseCode != 250) {
|
||||||
emit error(ServerError);
|
emitError(ServerError);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
changeState(_READY_Encrypted);
|
changeState(_READY_Encrypted);
|
||||||
@ -444,7 +470,7 @@ void SmtpClient::processResponse() {
|
|||||||
case _AUTH_PLAIN_0:
|
case _AUTH_PLAIN_0:
|
||||||
// If the response is not 235 then the authentication was failed
|
// If the response is not 235 then the authentication was failed
|
||||||
if (responseCode != 235) {
|
if (responseCode != 235) {
|
||||||
emit error(AuthenticationError);
|
emitError(AuthenticationError);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
changeState(_READY_Authenticated);
|
changeState(_READY_Authenticated);
|
||||||
@ -452,7 +478,7 @@ void SmtpClient::processResponse() {
|
|||||||
|
|
||||||
case _AUTH_LOGIN_0:
|
case _AUTH_LOGIN_0:
|
||||||
if (responseCode != 334) {
|
if (responseCode != 334) {
|
||||||
emit error(AuthenticationError);
|
emitError(AuthenticationError);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
changeState(_AUTH_LOGIN_1_USER);
|
changeState(_AUTH_LOGIN_1_USER);
|
||||||
@ -460,7 +486,7 @@ void SmtpClient::processResponse() {
|
|||||||
|
|
||||||
case _AUTH_LOGIN_1_USER:
|
case _AUTH_LOGIN_1_USER:
|
||||||
if (responseCode != 334) {
|
if (responseCode != 334) {
|
||||||
emit error(AuthenticationError);
|
emitError(AuthenticationError);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
changeState(_AUTH_LOGIN_2_PASS);
|
changeState(_AUTH_LOGIN_2_PASS);
|
||||||
@ -468,7 +494,7 @@ void SmtpClient::processResponse() {
|
|||||||
|
|
||||||
case _AUTH_LOGIN_2_PASS:
|
case _AUTH_LOGIN_2_PASS:
|
||||||
if (responseCode != 235) {
|
if (responseCode != 235) {
|
||||||
emit error(AuthenticationError);
|
emitError(AuthenticationError);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
changeState(_READY_Authenticated);
|
changeState(_READY_Authenticated);
|
||||||
@ -477,7 +503,7 @@ void SmtpClient::processResponse() {
|
|||||||
/* --- MAIL --- */
|
/* --- MAIL --- */
|
||||||
case _MAIL_0_FROM:
|
case _MAIL_0_FROM:
|
||||||
if (responseCode != 250) {
|
if (responseCode != 250) {
|
||||||
emit error(MailSendingError);
|
emitError(MailSendingError);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
changeState(_MAIL_1_RCPT_INIT);
|
changeState(_MAIL_1_RCPT_INIT);
|
||||||
@ -485,7 +511,7 @@ void SmtpClient::processResponse() {
|
|||||||
|
|
||||||
case _MAIL_2_RCPT:
|
case _MAIL_2_RCPT:
|
||||||
if (responseCode != 250) {
|
if (responseCode != 250) {
|
||||||
emit error(MailSendingError);
|
emitError(MailSendingError);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
changeState(_MAIL_2_RCPT);
|
changeState(_MAIL_2_RCPT);
|
||||||
@ -493,7 +519,7 @@ void SmtpClient::processResponse() {
|
|||||||
|
|
||||||
case _MAIL_3_DATA:
|
case _MAIL_3_DATA:
|
||||||
if (responseCode != 354) {
|
if (responseCode != 354) {
|
||||||
emit error(MailSendingError);
|
emitError(MailSendingError);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
changeState(_MAIL_4_SEND_DATA);
|
changeState(_MAIL_4_SEND_DATA);
|
||||||
@ -501,7 +527,7 @@ void SmtpClient::processResponse() {
|
|||||||
|
|
||||||
case _MAIL_4_SEND_DATA:
|
case _MAIL_4_SEND_DATA:
|
||||||
if (responseCode != 250) {
|
if (responseCode != 250) {
|
||||||
emit error(MailSendingError);
|
emitError(MailSendingError);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
changeState(_READY_MailSent);
|
changeState(_READY_MailSent);
|
||||||
@ -523,6 +549,28 @@ void SmtpClient::sendMessage(const QString &text)
|
|||||||
socket->write(text.toUtf8() + "\r\n");
|
socket->write(text.toUtf8() + "\r\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void SmtpClient::emitError(SmtpClient::SmtpError e)
|
||||||
|
{
|
||||||
|
emit error(e);
|
||||||
|
}
|
||||||
|
|
||||||
|
void SmtpClient::waitForEvent(int msec, const char *successSignal)
|
||||||
|
{
|
||||||
|
QEventLoop loop;
|
||||||
|
QObject::connect(this, successSignal, &loop, SLOT(quit()));
|
||||||
|
QObject::connect(this, SIGNAL(error(SmtpClient::SmtpError)), &loop, SLOT(quit()));
|
||||||
|
|
||||||
|
if(msec > 0)
|
||||||
|
{
|
||||||
|
QTimer timer;
|
||||||
|
timer.setSingleShot(true);
|
||||||
|
connect(&timer, SIGNAL(timeout()), &loop, SLOT(quit()));
|
||||||
|
timer.start(msec);
|
||||||
|
}
|
||||||
|
|
||||||
|
loop.exec();
|
||||||
|
}
|
||||||
|
|
||||||
/* [4] --- */
|
/* [4] --- */
|
||||||
|
|
||||||
|
|
||||||
@ -551,8 +599,6 @@ void SmtpClient::socketStateChanged(QAbstractSocket::SocketState state) {
|
|||||||
void SmtpClient::socketError(QAbstractSocket::SocketError socketError) {
|
void SmtpClient::socketError(QAbstractSocket::SocketError socketError) {
|
||||||
#ifndef QT_NO_DEBUG
|
#ifndef QT_NO_DEBUG
|
||||||
qDebug() << "[Socket] ERROR:" << socketError;
|
qDebug() << "[Socket] ERROR:" << socketError;
|
||||||
#else
|
|
||||||
Q_UNUSED(socketError);
|
|
||||||
#endif
|
#endif
|
||||||
emit error(SocketError);
|
emit error(SocketError);
|
||||||
}
|
}
|
||||||
@ -583,13 +629,13 @@ void SmtpClient::socketReadyRead()
|
|||||||
|
|
||||||
// Check for server error
|
// Check for server error
|
||||||
if (responseCode / 100 == 4) {
|
if (responseCode / 100 == 4) {
|
||||||
emit error(ServerError);
|
emitError(ServerError);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Check for client error
|
// Check for client error
|
||||||
if (responseCode / 100 == 5) {
|
if (responseCode / 100 == 5) {
|
||||||
emit error(ClientError);
|
emitError(ClientError);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -66,6 +66,7 @@ public:
|
|||||||
AuthenticatingState = 4,
|
AuthenticatingState = 4,
|
||||||
MailSendingState = 5,
|
MailSendingState = 5,
|
||||||
DisconnectingState = 6,
|
DisconnectingState = 6,
|
||||||
|
ResetState = 7,
|
||||||
|
|
||||||
/* Internal States */
|
/* Internal States */
|
||||||
_EHLO_State = 50,
|
_EHLO_State = 50,
|
||||||
@ -102,7 +103,7 @@ public:
|
|||||||
|
|
||||||
/* [1] Constructors and Destructors */
|
/* [1] Constructors and Destructors */
|
||||||
|
|
||||||
SmtpClient(const QString & host = "locahost", int port = 25, ConnectionType ct = TcpConnection);
|
SmtpClient(const QString & host = "localhost", int port = 25, ConnectionType ct = TcpConnection);
|
||||||
|
|
||||||
~SmtpClient();
|
~SmtpClient();
|
||||||
|
|
||||||
@ -111,14 +112,14 @@ public:
|
|||||||
|
|
||||||
/* [2] Getters and Setters */
|
/* [2] Getters and Setters */
|
||||||
|
|
||||||
const QString& getHost() const;
|
QString getHost() const;
|
||||||
int getPort() const;
|
int getPort() const;
|
||||||
ConnectionType getConnectionType() const;
|
ConnectionType getConnectionType() const;
|
||||||
|
|
||||||
const QString& getName() const;
|
QString getName() const;
|
||||||
void setName(const QString &name);
|
void setName(const QString &name);
|
||||||
|
|
||||||
const QString & getResponseText() const;
|
QString getResponseText() const;
|
||||||
int getResponseCode() const;
|
int getResponseCode() const;
|
||||||
|
|
||||||
QTcpSocket* getSocket();
|
QTcpSocket* getSocket();
|
||||||
@ -132,10 +133,15 @@ public:
|
|||||||
void login(const QString &user, const QString &password, AuthMethod method = AuthLogin);
|
void login(const QString &user, const QString &password, AuthMethod method = AuthLogin);
|
||||||
void sendMail(const MimeMessage & email);
|
void sendMail(const MimeMessage & email);
|
||||||
void quit();
|
void quit();
|
||||||
|
void reset();
|
||||||
|
|
||||||
|
bool isConnected();
|
||||||
|
bool isLogged();
|
||||||
|
|
||||||
bool waitForReadyConnected(int msec = 30000);
|
bool waitForReadyConnected(int msec = 30000);
|
||||||
bool waitForAuthenticated(int msec = 30000);
|
bool waitForAuthenticated(int msec = 30000);
|
||||||
bool waitForMailSent(int msec = 30000);
|
bool waitForMailSent(int msec = 30000);
|
||||||
|
bool waitForReset(int msec = 30000);
|
||||||
|
|
||||||
/* [3] --- */
|
/* [3] --- */
|
||||||
|
|
||||||
@ -170,14 +176,15 @@ protected:
|
|||||||
bool isReadyConnected;
|
bool isReadyConnected;
|
||||||
bool isAuthenticated;
|
bool isAuthenticated;
|
||||||
bool isMailSent;
|
bool isMailSent;
|
||||||
|
bool isReset;
|
||||||
|
|
||||||
const MimeMessage *email;
|
const MimeMessage *email;
|
||||||
|
|
||||||
int rcptType;
|
int rcptType;
|
||||||
enum _RcptType { _TO = 1, _CC = 2, _BCC = 3};
|
enum _RcptType { _TO = 1, _CC = 2, _BCC = 3};
|
||||||
|
|
||||||
QList<EmailAddress*>::const_iterator addressIt;
|
QList<EmailAddress>::const_iterator addressIt;
|
||||||
QList<EmailAddress*>::const_iterator addressItEnd;
|
QList<EmailAddress>::const_iterator addressItEnd;
|
||||||
|
|
||||||
/* [4] --- */
|
/* [4] --- */
|
||||||
|
|
||||||
@ -188,6 +195,8 @@ protected:
|
|||||||
void changeState(ClientState state);
|
void changeState(ClientState state);
|
||||||
void processResponse();
|
void processResponse();
|
||||||
void sendMessage(const QString &text);
|
void sendMessage(const QString &text);
|
||||||
|
void emitError(SmtpClient::SmtpError e);
|
||||||
|
void waitForEvent(int msec, const char *successSignal);
|
||||||
|
|
||||||
/* [5] --- */
|
/* [5] --- */
|
||||||
|
|
||||||
@ -213,6 +222,7 @@ signals:
|
|||||||
void readyConnected();
|
void readyConnected();
|
||||||
void authenticated();
|
void authenticated();
|
||||||
void mailSent();
|
void mailSent();
|
||||||
|
void mailReset();
|
||||||
void disconnected();
|
void disconnected();
|
||||||
|
|
||||||
/* [7] --- */
|
/* [7] --- */
|
||||||
|
Loading…
Reference in New Issue
Block a user