*/
public MimeMessage createEncryptedMessage(UserProfile profile, MimeMessage mm) throws MessagingException, java.io.IOException, java.security.GeneralSecurityException {
if (cryptoType == NO_CRYPTO)
return mm;
Key signKey = null;
signKey = getSignatureKey();
if (signKey == null){
switch (cryptoType) {
case SMIME_SIGN:
case SMIME_BOTH:
signKey = profile.getEncryptionKey(EncryptionManager.SMIME, true);
break;
case PGP_SIGN:
case PGP_BOTH:
signKey = profile.getEncryptionKey(EncryptionManager.PGP, true);
break;
}
}
PookaEncryptionManager cryptoManager = Pooka.getCryptoManager();
InternetAddress from = (InternetAddress) mm.getFrom()[0];
// Find the keys to sign and encrypt the messages
if(signKey == null && (cryptoType == SMIME_SIGN || cryptoType == SMIME_BOTH)){
Key[] keys = cryptoManager.getPrivateKeysForAddress(from.getAddress(), EncryptionManager.SMIME, true);
if (keys == null || keys.length == 0) {
// show dialog
signKey = CryptoKeySelector.selectPrivateKey(Pooka.getProperty("Pooka.crypto.privateKey.forSign", "Select key to sign this message."), EncryptionManager.SMIME, true);
} else {
signKey = keys[0];
}
if (signKey == null) {
throw new GeneralSecurityException("No signature key selected.");
}
}
if(signKey == null && (cryptoType == PGP_SIGN || cryptoType == PGP_BOTH)){
Key[] keys = cryptoManager.getPrivateKeysForAddress(from.getAddress(), EncryptionManager.PGP, true);
if (keys == null || keys.length == 0) {
// show dialog
signKey = CryptoKeySelector.selectPrivateKey(Pooka.getProperty("Pooka.crypto.privateKey.forSign", "Select key to sign this message."), EncryptionManager.PGP, true);
} else {
signKey = keys[0];
}
if (signKey == null) {
throw new GeneralSecurityException("No signature key selected.");
}
}
List encKeys = new LinkedList();
//TODO: get the encKey from the available public keys
if (cryptoType == SMIME_ENCRYPT || cryptoType == SMIME_BOTH || cryptoType == PGP_ENCRYPT || cryptoType == PGP_BOTH) {
String type = (cryptoType == SMIME_ENCRYPT || cryptoType == SMIME_BOTH) ? EncryptionManager.SMIME : EncryptionManager.PGP;
// Get the public key of the senders
Address[] froms = mm.getFrom();
for (int i = 0; i < froms.length; i++) {
from = (InternetAddress) froms[i];
Key[] keys = cryptoManager.getPublicKeys(from.getAddress(), type, false);
if (keys != null && keys.length > 0) {
encKeys.add(keys[0]);
}
}
// Get the public key of the receivers
Address[] receivers = mm.getAllRecipients();
for (int i = 0; i < receivers.length; i++) {
InternetAddress rec = (InternetAddress) receivers[i];
Key[] keys = cryptoManager.getPublicKeys(rec.getAddress(), type, false);
if (keys != null && keys.length > 0) {
encKeys.add(keys[0]);
} else {
Key key = CryptoKeySelector.selectPublicKey(Pooka.getProperty("Pooka.crypto.publicKey.forEncrypt", "Select key to encrypt this message."), EncryptionManager.PGP, false);
if (key != null)
encKeys.add(key);
else
throw new GeneralSecurityException("found no certificate for " + rec.getAddress());
}