32a16dcd8d
Add check for public keys of all message recipients (to, cc, and bcc) before sending the message. Adds an OnFocusLost callback to header editors to facilitate a callback for checking keys whenever a new recipient is added (OnChange results in too many keyring checks). Once encryption is initially set, the callbacks are registered. If a public key is not available for any recipient, encryption is turned off. However, notably, the callbacks are still registered meaning as s soon as the user removes the recipients with missing keys, encryption is turned back on. Signed-off-by: Tim Culverhouse <tim@timculverhouse.com> Tested-by: Koni Marti <koni.marti@gmail.com>
34 lines
797 B
Go
34 lines
797 B
Go
package crypto
|
|
|
|
import (
|
|
"bytes"
|
|
"io"
|
|
"log"
|
|
|
|
"git.sr.ht/~rjarry/aerc/lib/crypto/gpg"
|
|
"git.sr.ht/~rjarry/aerc/lib/crypto/pgp"
|
|
"git.sr.ht/~rjarry/aerc/models"
|
|
"github.com/ProtonMail/go-crypto/openpgp"
|
|
"github.com/emersion/go-message/mail"
|
|
)
|
|
|
|
type Provider interface {
|
|
Decrypt(io.Reader, openpgp.PromptFunction) (*models.MessageDetails, error)
|
|
Encrypt(*bytes.Buffer, []string, string, openpgp.PromptFunction, *mail.Header) (io.WriteCloser, error)
|
|
Sign(*bytes.Buffer, string, openpgp.PromptFunction, *mail.Header) (io.WriteCloser, error)
|
|
ImportKeys(io.Reader) error
|
|
Init(*log.Logger) error
|
|
Close()
|
|
GetSignerKeyId(string) (string, error)
|
|
GetKeyId(string) (string, error)
|
|
}
|
|
|
|
func New(s string) Provider {
|
|
switch s {
|
|
case "gpg":
|
|
return &gpg.Mail{}
|
|
default:
|
|
return &pgp.Mail{}
|
|
}
|
|
}
|