-
-
Notifications
You must be signed in to change notification settings - Fork 272
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Encrypt mail with multiple certificate #297
Comments
My knowledge on this is limited, but I think it should already work with multiple recipients, if their keys were signed with a shared CA certificate. Or something like that. |
Sorry for delay to answer. |
At one of the companies I worked, they configured a single (CA?) cert, which was used to sign (encrypt?) all emails without needing recipients individual public keys. Is your use case actually really a common one? Seems like a hassle! |
I think my case is a common one. Usually, a company has its own CA, they use it to sign internal certificates. Each employee then has a key pair (private and public key). Let's say I want to send an encrypted mail to Alice and I want her to be the only one to be able to decrypt it. I encrypt it with her public key. The only person able to decrypt the sent mail is the one with the corresponding private key (=Alice). Now, I want to send an encrypted mail to Alice and Bob (at the same time, = multiple recipients). If I encrypt it only with Alice public key, only Alice will be able to read it. Bob can't. That's why I need to encrypt it twice : one time with Alice's public key, one time with Bob's one. Right now, if I want to do that with simple-java-mail, I have to send 2 distincts emails instead of one. I don't know the company you're talking about but if you use only one certificate (you usually don't use a CA for that) to encrypt each email, that means, everybody share the private key and everybody can decrypt them. The same if everybody use the same key to sign each email, you can't be sure of who really send it. Usually, you sign it with your private key. But maybe that's what they intended to do... By the way, in the lib, sign case is ok because you always sign a mail once (= with one private key). |
Ahh then that might have been the case at the company I worked for at the time. You made a convincing case, one question: this change would mean being able to sign on a per-email basis (so using EmailBuilder). Would it ever make sense to be able to do it on Mailer level as well, affecting all emails that don't have their own key added for signing/encrypting? |
you mean to encrypt on a per-email basis ? Not sure to understand your question: "do it on Mailer level... emails that don't have their own key added for signing/encrypting" As encryption is for a specific recipient, I think certificates has to be done explicitely set in emailBuilder (no default value). For signing, it can be configured as default (as you can choose to sign all your email). |
So no use case whatsoever to allow a default. Ever. (just double checking) |
Sign -> can set a default to sign email |
Yes, I am also having the same use case as @nathinthesky explained, encrypting message for each recipient. I just ported my code from Commons Apache to Simple Java Mail and come to know that it is not possible 😞 With Commons Apache we used to encrypt mail in following way :
Here is the code for encrypting
After this function just use @bbottema Really looking forward to have this facility to encrypt message per recipient into this library. Also, if I get any rough idea where would the most of the changes will come then I can create PR for the same. |
I had no idea that was even possible with LDAP. That's pretty cool actually. As I'm winding down on the open issues, I am looking into some of the older reports, such as this one, so I think I'm going to start work on this soon.
Correct, this is how Simple Java Mail already has implemented this. What I'm going to do is to allow both default signing or encrypting on Mailer level as well as on Email level and then everyone can figure out there own use case and use the library as they see fit. |
…ke sure they don't get a default value #447: Added value-overriding control for individual properties, to make sure they don't get overridden #297: Streamlined how defaults/overrides are determined by EmailGovernance and MiscUtil #297: Removed the signByDefault methods from Mailer; signWithSmime on Email already works on for the defaults Email reference #446: Added missing config properties for DKIM
I also would like to send an encrypted email to multiple recipients that is also signed. Any idea if/when this might make it in? |
…Recipient and Recipients level on top of Email and Mailer level. Updated both Recipient and Recipients APIs to include S/MIME encryption as a feature. This adds to the existing levels for S/MIME encryption which were Email and Mailer. The changes ensure a flexible, layered approach to managing S/MIME encryption, offering specific controls at each level. Order of precedence has now been established to clarify encryption priority.
bbottema, the documentation you reference to RecipientBuilder looks great. I have version 8.12.4 but I don't see RecipientBuilder in the jar. I also have the SMIME module and the core module and I don't see it listed anywhere. Am I looking in the wrong place? How should I get this functionality? Thanks! |
hello,
more a question for a new feature than an issue. Is it planned to implement encrypted mail for multiple recipients ?
Thanks !
The text was updated successfully, but these errors were encountered: