Skip to content
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

Open
nathinthesky opened this issue Dec 11, 2020 · 12 comments
Open

Encrypt mail with multiple certificate #297

nathinthesky opened this issue Dec 11, 2020 · 12 comments

Comments

@nathinthesky
Copy link

hello,

more a question for a new feature than an issue. Is it planned to implement encrypted mail for multiple recipients ?

Thanks !

@bbottema
Copy link
Owner

bbottema commented Dec 15, 2020

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.

@nathinthesky
Copy link
Author

Sorry for delay to answer.
To encrypt mail for multiple recipients, you have to encrypt it with each recipient certificate (public key), then, they will be able to decrypt the mail on their side with their private key.
I'll will try to work with you on this !

@bbottema
Copy link
Owner

bbottema commented Apr 10, 2021

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!

@nathinthesky
Copy link
Author

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).

@bbottema
Copy link
Owner

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?

@nathinthesky
Copy link
Author

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).

@bbottema
Copy link
Owner

I think certificates has to be done explicitely set in emailBuilder (no default value)

So no use case whatsoever to allow a default. Ever. (just double checking)

@nathinthesky
Copy link
Author

Sign -> can set a default to sign email
Encrypt -> no default value (as it is recipient dependant)

@rover886
Copy link
Contributor

rover886 commented Mar 3, 2022

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 :

  1. Fetch each recipient certificate (X509Certificate) from LDAP
  2. By using list of X509Certificate and SMIMEEnvelopedGenerator from org.bouncycastle.mail.smime, MimeBodyPart is encrypted

Here is the code for encrypting MimeMessage object

public MimeMessage encryptMessage(MimeMessage message, List<X509Certificate> recipientCertList) 
{
	
	try {
		Security.addProvider(new BouncyCastleProvider());
		
		// Create the generator for creating an smime/encrypted message
		SMIMEEnvelopedGenerator  generator = new SMIMEEnvelopedGenerator();
		
		//Add Recipient Public Certificates.
		for (X509Certificate cert : recipientCertList) {
			generator.addRecipientInfoGenerator(new JceKeyTransRecipientInfoGenerator(cert)
					.setProvider(BouncyCastleProvider.PROVIDER_NAME));
		}

		MimeBodyPart msg = new MimeBodyPart();
		msg.setContent(message.getContent(), message.getContentType());
		
		MimeBodyPart mp = generator.generate(msg, new JceCMSContentEncryptorBuilder(CMSAlgorithm.AES256_CBC)
				.setProvider(BouncyCastleProvider.PROVIDER_NAME).build());
		message.setContent(mp.getContent(), mp.getContentType());
		message.saveChanges();
		
		return message;
	} catch (Exception e) {
		throw new EmailGenericException(e);
	}
	
	
}

After this function just use Transport.send(); with returned message object. And if messages signing is also need to be done then that has to be done first then encryption. Moreover if DKIM signing should also be the last step. So the flow will always be S/MIME sign --> S/MIME encryption --> DKIM sign.

@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.

@bbottema
Copy link
Owner

bbottema commented Feb 22, 2023

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.

And if messages signing is also need to be done then that has to be done first then encryption. Moreover if DKIM signing should also be the last step. So the flow will always be S/MIME sign --> S/MIME encryption --> DKIM sign.

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.

bbottema added a commit that referenced this issue Feb 26, 2023
…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
@jgprospect
Copy link

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?

bbottema added a commit that referenced this issue Mar 25, 2024
…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.
@jgprospect
Copy link

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!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

4 participants