Bug 323168

Summary: GPG signature validation fails due to KMail modifying headers within received mails
Product: [Applications] kmail2 Reporter: Xavier Guerrin <xavier.kde>
Component: cryptoAssignee: kdepim bugs <kdepim-bugs>
Status: RESOLVED FIXED    
Severity: normal CC: aheinecke, beasley, ecthelion, florent, kde-bugs, msylwester, sknauss, sven
Priority: NOR    
Version: Git (master)   
Target Milestone: ---   
Platform: Debian unstable   
OS: Linux   
Latest Commit: Version Fixed In:
Sentry Crash Report:
Attachments: An mail gnerated by mutt without any errors
Example mail (from bank) as saved from gmail
Example mail as saved from kmail
Signed email example, saved by kmail 5.0.2
Valid signature of example mail

Description Xavier Guerrin 2013-08-04 21:28:00 UTC
Hello,

It appears KMail rewrites some headers within received mails before storing and displaying them.
Indeed, a two-parts multipart mail (the first part being the effective message, the second part being the related GPG signature) sent using another MUA (e.g. Mutt) and having the following header in the first part:
Content-Type: text/plain; charset=us-ascii
... gets rewritten at some point to:
Content-Type: text/plain; charset="us-ascii"
... i.e. KMail would add double-quotes to the charset value, probably in an attempt to "normalize" headers.
Alas, this has the immediate side-effect of breaking the GPG signature; KMail then displays the mail content within a red frame titled "Invalid signature" while the original message and signature were perfectly matching.

Reproducible: Always

Steps to Reproduce:
1. Get sent a signed mail with a quote-less Content-Type header in the signed part
2. Receive that mail with KMail (tested with the POPS protocol)
Actual Results:  
* Double quotes were added to the Content-Type header in the signed part
* The signature is considered invalid

Expected Results:  
* The mail should be left as untouched as possible
* The signature should be considered valid
Comment 1 Patrick Zimmermann 2013-08-26 21:36:14 UTC
Verified here.
Received message shows as invalid signature in kmail. When saving the message locally, extracting message text and signature and removing the quotes and newline at the end of the email text
gpg --verify sig text
works.
Comment 2 Patrick Zimmermann 2013-08-26 21:49:31 UTC
Forgot to say: version 4.11.00
Comment 3 Florent Bayle 2013-09-15 10:03:39 UTC
I can confirm that :

-Content-Type: text/plain; charset=iso-8859-1
+Content-Type: text/plain; charset="iso-8859-1"
 Content-Disposition: inline
 Content-Transfer-Encoding: quoted-printable

On a mail I just received.
Comment 4 Sven Eden 2013-09-26 13:56:33 UTC
I just received a Mail where KMail changed

Content-Type: multipart/signed; boundary="J/dobhs11T7y2rNN"; micalg=pgp-sha1; protocol="application/pgp-signature"

to
Content-Type: multipart/signed; boundary="J/dobhs11T7y2rNN"; micalg="pgp-sha1"; protocol="application/pgp-signature"

resulting in an invalid signature.
Comment 5 Sandro Knauß 2013-09-27 23:17:11 UTC
I can confirm this bug on master branch
Comment 6 Sandro Knauß 2013-10-06 21:16:44 UTC
Created attachment 82696 [details]
An mail gnerated by mutt without any errors
Comment 7 Sandro Knauß 2013-10-06 21:24:07 UTC
First we have to make sure that we are talking about the same signing protocol :)

I only tested now OpenPGP Mime:
I read the RFC 3156 "5. OpenPGP signed data" and it is totaly ok, that the signature get broken, if the header get changed, 'cause the header is part of the signed content. I can't generate any mail, that is shown broken, when i generate it with mutt (without manually modifing the header). 

Please test the attached mail generated by mutt. Can you please generate&upload an mail with broken signature ( use save from kmail)  and the original mail?
Comment 8 Michal Sylwester 2014-03-05 08:17:27 UTC
It's about SMIME not GPG, but I think it's same problem.

I'm having same problems with SMIME signed emails from my bank. Saving message and trying to verify using:
openssl smime -verify -in filename.txt
fails. When I try to verify the save the same message saved from gmail it is successful. 

The difference that seems significant in this case are extra newlines added before part separators. Removing the newlines makes the message pass the verification.
Comment 9 Michal Sylwester 2014-03-11 04:47:21 UTC
Created attachment 85521 [details]
Example mail (from bank) as saved from gmail

I've found one I can share. This message passes verification:
> openssl smime -verify -in alior-gm.txt 
.....
Verification successful
Comment 10 Michal Sylwester 2014-03-11 04:52:01 UTC
Created attachment 85522 [details]
Example mail as saved from kmail

Saved using save as from kmail - this one fails verification:
openssl smime -verify -in alior-km.mbox
(...)
Verification failure
Comment 11 Christian Boltz 2016-01-03 18:12:33 UTC
The requested information was provided long ago, back to confirmed.
Comment 12 Sandro Knauß 2016-01-04 10:26:45 UTC
Sorry, i forgot about this issue.Unfortunatelly i'll get for both Verification failed, because the mail is too old :

  % openssl smime -verify -in alior-km.mbox
  Verification failure
  139929104623248:error:21075075:PKCS7 routines:PKCS7_verify:certificate verify error:pk7_smime.c:319:Verify error:certificate has expired
  % openssl smime -verify -in alior-gm.mbox
  Verification failure
  139695521343120:error:21075075:PKCS7 routines:PKCS7_verify:certificate verify error:pk7_smime.c:319:Verify error:certificate has expired


maybe you can add a new one and/or test with the current version 4.14.X. because the adding newlines to the mail I have fixed for another bug, so maybe this one is solved in meanwhile too... (https://bugs.kde.org/331991).
Comment 13 Michal Sylwester 2016-01-04 11:08:17 UTC
Seems to work! When I save the email to file and try to verify it using openssl it validates. I still have some issue with kmail complaining about "Not enough information to check signature validity." but this seems to be unrelated to this particular bug, and possibly an issue with my system.

Just in case I'll also attach a newer signed email.
Comment 14 Michal Sylwester 2016-01-04 11:09:56 UTC
Created attachment 96442 [details]
Signed email example, saved by kmail 5.0.2
Comment 15 Sandro Knauß 2016-01-04 12:44:51 UTC
That's good to hear that the modifing mail issue is now solved.

Maybe Andre can give the nessary information, why we still see:

"Not enough information to check signature validity."

I am not using smime a lot myself, that's why I'm not that familiar with the statuses from smime.
Comment 16 Andre Heinecke 2016-01-04 13:18:46 UTC
Created attachment 96444 [details]
Valid signature of example mail

The error message is indeed horrible. Afaik it's intended to mean "GnuPG does not know whether or not it should trust the certificate so "Not enough information"".

You can get some more details from the Audit Log. My best bet would be though that you do not have the root certificate of the certificate chain for jp-bank.japanpost.jp marked as a trusted issuer. You can do that by adding the fingerprint to ~/.gnupg/trustlist.txt and restart the dirmngr service / gpgsm.

In Kleopatra this certificate would be shown in Other Certificates. There you can also use "Trust root certificate" by right clicking the root certificate. It should then show up under Trusted certificates.

Only messages that are signed by a certificate in the Trusted Certificates group show up as Green in KMail.

Attached is a screenshot showing that KMail generally can verify that mail correctly. I think this bug can be closed. Maybe a different bug for Kleopatra / S/MIME usability ;-)
Comment 17 Michal Sylwester 2016-01-04 22:24:16 UTC
Good tip, indeed kmail misses the root cert. I'll try to fix it once I find some more spare time.

Anyway, I agree, this is different story, and this bug can be closed.
Comment 18 Sandro Knauß 2016-01-05 09:00:28 UTC
@Andre: thanks for clearification.

@Michal: feel free to open a new bug about the bad UX.