From 46f08114da8c99c47fbdfa075cfced633b8741e8 Mon Sep 17 00:00:00 2001 From: lieser Date: Thu, 12 Dec 2013 00:16:13 +0100 Subject: [PATCH] fixed verification of unsigned e-mails which are marked as should be signed by sign rules (#20) --- CHANGELOG.txt | 5 ++++ modules/dkimVerifier.jsm | 61 ++++++++++++++++++++++------------------ 2 files changed, 39 insertions(+), 27 deletions(-) diff --git a/CHANGELOG.txt b/CHANGELOG.txt index feca0b84..e33a6e7a 100644 --- a/CHANGELOG.txt +++ b/CHANGELOG.txt @@ -1,3 +1,8 @@ +1.0.3 [2013-12-12] +------------------ + - fixed bug in sign rules if from address contains capital letters + - fixed verification of unsigned e-mails which are marked as should be signed by sign rules + 1.0.2 [2013-11-22] ------------------ - fixed internal error if sign rules are disabled diff --git a/modules/dkimVerifier.jsm b/modules/dkimVerifier.jsm index a0b08f5b..c2747ddb 100644 --- a/modules/dkimVerifier.jsm +++ b/modules/dkimVerifier.jsm @@ -4,7 +4,7 @@ * Verifies the DKIM-Signatures as specified in RFC 6376 * http://tools.ietf.org/html/rfc6376 * - * Version: 1.0.1 (22 November 2013) + * Version: 1.0.2 (12 December 2013) * * Copyright (c) 2013 Philippe Lieser * @@ -948,34 +948,41 @@ var Verifier = (function() { * handeles Exeption */ function handleExeption(e, msg) { - if (e instanceof DKIM_SigError) { - // return result - msg.result = { - version : "1.1", - result : "PERMFAIL", - errorType : e.errorType, - SDID : msg.DKIMSignature.d, - selector : msg.DKIMSignature.s, - shouldBeSignedBy : msg.shouldBeSigned.sdid, - hideFail : msg.shouldBeSigned.hideFail, - }; - returnResult(msg); - - log.warn(exceptionToStr(e)); - } else { - // return result - msg.result = { - version : "1.0", - result : "TEMPFAIL", - errorType : e.errorType - }; - returnResult(msg); - - if (e instanceof DKIM_InternalError) { - log.error(exceptionToStr(e)); + try { + if (e instanceof DKIM_SigError) { + // return result + if (!msg.DKIMSignature) { + msg.DKIMSignature = {} + } + msg.result = { + version : "1.1", + result : "PERMFAIL", + errorType : e.errorType, + SDID : msg.DKIMSignature.d, + selector : msg.DKIMSignature.s, + shouldBeSignedBy : msg.shouldBeSigned.sdid, + hideFail : msg.shouldBeSigned.hideFail, + }; + returnResult(msg); + + log.warn(exceptionToStr(e)); } else { - log.fatal(exceptionToStr(e)); + // return result + msg.result = { + version : "1.0", + result : "TEMPFAIL", + errorType : e.errorType + }; + returnResult(msg); + + if (e instanceof DKIM_InternalError) { + log.error(exceptionToStr(e)); + } else { + log.fatal(exceptionToStr(e)); + } } + } catch (exception) { + log.fatal("handleExeption: "+exception); } }