Skip to content
This repository has been archived by the owner on Dec 12, 2024. It is now read-only.

Commit

Permalink
fix: moved onData to onConnect due to <nodemailer/smtp-server#155>
Browse files Browse the repository at this point in the history
  • Loading branch information
niftylettuce committed Aug 13, 2020
1 parent 84a7938 commit d07d7ab
Showing 1 changed file with 42 additions and 44 deletions.
86 changes: 42 additions & 44 deletions index.js
Original file line number Diff line number Diff line change
Expand Up @@ -888,7 +888,48 @@ class ForwardEmail {
async onConnect(session, fn) {
// set arrival date for future use by bounce handler
session.arrivalDate = Date.now();
fn();

try {
// check against blacklist
if (
validator.isFQDN(session.clientHostname) &&
this.isBlacklisted(session.clientHostname)
)
throw new CustomError(
`The domain ${session.clientHostname} is blacklisted by ${this.config.website}.`,
554
);
if (this.isBlacklisted(session.remoteAddress))
throw new CustomError(
`The IP address ${session.remoteAddress} is blacklisted by ${this.config.website}.`,
554
);

// validate against rate limiting
await this.validateRateLimit(session.remoteAddress);

//
// TODO: check blacklist against MAIL FROM
//
// ensure that it's not on the DNS blacklist
// X Spamhaus = zen.spamhaus.org
// - SpamCop = bl.spamcop.net
// - Barracuda = b.barracudacentral.org
// - Lashback = ubl.unsubscore.com
// - PSBL = psbl.surriel.com
//
// TODO: if someone hits the blacklist we should ratelimit them too
//
const message = await this.checkBlacklists(session.remoteAddress);
if (message) {
this.config.blacklist.push(session.remoteAddress);
throw new CustomError(message, 554);
}

fn();
} catch (err) {
fn(err);
}
}

async onData(stream, session, fn) {
Expand Down Expand Up @@ -941,47 +982,6 @@ class ForwardEmail {
//
const { mailFrom } = session.envelope;

try {
// check against blacklist
if (
validator.isFQDN(session.clientHostname) &&
this.isBlacklisted(session.clientHostname)
)
throw new CustomError(
`The domain ${session.clientHostname} is blacklisted by ${this.config.website}.`,
554
);
if (this.isBlacklisted(session.remoteAddress))
throw new CustomError(
`The IP address ${session.remoteAddress} is blacklisted by ${this.config.website}.`,
554
);

// validate against rate limiting
await this.validateRateLimit(session.remoteAddress);

//
// TODO: check blacklist against MAIL FROM
//
// ensure that it's not on the DNS blacklist
// X Spamhaus = zen.spamhaus.org
// - SpamCop = bl.spamcop.net
// - Barracuda = b.barracudacentral.org
// - Lashback = ubl.unsubscore.com
// - PSBL = psbl.surriel.com
//
// TODO: if someone hits the blacklist we should ratelimit them too
//
const message = await this.checkBlacklists(session.remoteAddress);
if (message) {
this.config.blacklist.push(session.remoteAddress);
throw new CustomError(message, 554);
}
} catch (err) {
stream.destroy(err);
return;
}

//
// read the message headers and message itself
//
Expand Down Expand Up @@ -1125,13 +1125,11 @@ class ForwardEmail {
//
let scan;

/*
try {
scan = await this.scanner.scan(originalRaw);
} catch (err) {
this.config.logger.fatal(err);
}
*/

if (_.isObject(scan) && _.isObject(scan.results)) {
//
Expand Down

0 comments on commit d07d7ab

Please sign in to comment.