2017-10-17 15:09:55 -04:00
|
|
|
#ifndef _CRYPTO_H
|
|
|
|
#define _CRYPTO_H
|
|
|
|
|
|
|
|
#include <stdbool.h>
|
|
|
|
#include "gmime-extra.h"
|
2017-10-17 15:09:56 -04:00
|
|
|
#include "notmuch.h"
|
2017-10-17 15:09:55 -04:00
|
|
|
|
2019-03-02 16:26:06 -04:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2017-10-17 15:09:55 -04:00
|
|
|
typedef struct _notmuch_crypto {
|
|
|
|
bool verify;
|
2017-12-08 01:23:52 -05:00
|
|
|
notmuch_decryption_policy_t decrypt;
|
2017-10-17 15:09:55 -04:00
|
|
|
} _notmuch_crypto_t;
|
|
|
|
|
2017-11-30 03:59:27 -05:00
|
|
|
GMimeObject *
|
2017-12-08 01:23:58 -05:00
|
|
|
_notmuch_crypto_decrypt (bool *attempted,
|
|
|
|
notmuch_decryption_policy_t decrypt,
|
2017-12-08 01:23:53 -05:00
|
|
|
notmuch_message_t *message,
|
2017-11-30 03:59:27 -05:00
|
|
|
GMimeMultipartEncrypted *part,
|
|
|
|
GMimeDecryptResult **decrypt_result,
|
|
|
|
GError **err);
|
2017-10-17 15:09:55 -04:00
|
|
|
|
|
|
|
void
|
|
|
|
_notmuch_crypto_cleanup (_notmuch_crypto_t *crypto);
|
|
|
|
|
2019-05-25 14:04:03 -04:00
|
|
|
/* The user probably wants to know if the entire message was in the
|
|
|
|
* clear. When replying, the MUA probably wants to know whether there
|
|
|
|
* was any part decrypted in the message. And when displaying to the
|
|
|
|
* user, we probably only want to display "encrypted message" if the
|
|
|
|
* entire message was covered by encryption. */
|
|
|
|
typedef enum {
|
|
|
|
NOTMUCH_MESSAGE_DECRYPTED_NONE = 0,
|
|
|
|
NOTMUCH_MESSAGE_DECRYPTED_PARTIAL,
|
|
|
|
NOTMUCH_MESSAGE_DECRYPTED_FULL,
|
|
|
|
} _notmuch_message_decryption_status_t;
|
|
|
|
|
|
|
|
/* description of the cryptographic state of a given message overall;
|
|
|
|
* for use by simple user agents.
|
|
|
|
*/
|
|
|
|
typedef struct _notmuch_message_crypto {
|
|
|
|
/* encryption status: partial, full, none */
|
|
|
|
_notmuch_message_decryption_status_t decryption_status;
|
|
|
|
/* FIXME: can we show what key(s) a fully-encrypted message was
|
|
|
|
* encrypted to? This data is not necessarily cryptographically
|
|
|
|
* reliable; even when we decrypt, we might not know which public
|
|
|
|
* key was used (e.g. if we're using a session key). */
|
|
|
|
|
|
|
|
/* signature status of the whole message (either the whole message
|
|
|
|
* is signed, or it is not) -- this means that partially-signed
|
|
|
|
* messages will get no signature status. */
|
|
|
|
GMimeSignatureList * sig_list;
|
|
|
|
/* if part of the message was signed, and the MUA is clever, it
|
|
|
|
* can determine on its own exactly which part and try to make
|
|
|
|
* more sense of it. */
|
|
|
|
|
|
|
|
/* mark this flag once we encounter a payload (i.e. something that
|
|
|
|
* is not part of the cryptographic envelope) */
|
|
|
|
bool payload_encountered;
|
|
|
|
|
2019-05-26 18:15:55 -04:00
|
|
|
/* the value of any "Subject:" header in the cryptographic payload
|
|
|
|
* (the top level part within the crypto envelope), converted to
|
|
|
|
* UTF-8 */
|
|
|
|
char * payload_subject;
|
|
|
|
|
2019-05-25 14:04:03 -04:00
|
|
|
/* if both signed and encrypted, was the signature encrypted? */
|
|
|
|
bool signature_encrypted;
|
|
|
|
} _notmuch_message_crypto_t;
|
|
|
|
|
|
|
|
|
|
|
|
/* _notmuch_message_crypto_t objects should be released with
|
|
|
|
* talloc_free (), or they will be released along with their parent
|
|
|
|
* context.
|
|
|
|
*/
|
|
|
|
_notmuch_message_crypto_t *
|
|
|
|
_notmuch_message_crypto_new (void *ctx);
|
|
|
|
|
|
|
|
/* call potential_sig_list during a depth-first-search on a message to
|
|
|
|
* consider a particular signature as relevant for the message.
|
|
|
|
*/
|
|
|
|
notmuch_status_t
|
|
|
|
_notmuch_message_crypto_potential_sig_list (_notmuch_message_crypto_t *msg_crypto, GMimeSignatureList *sigs);
|
|
|
|
|
|
|
|
/* call successful_decryption during a depth-first-search on a message
|
|
|
|
* to indicate that a part was successfully decrypted.
|
|
|
|
*/
|
|
|
|
notmuch_status_t
|
|
|
|
_notmuch_message_crypto_successful_decryption (_notmuch_message_crypto_t *msg_crypto);
|
|
|
|
|
|
|
|
/* call potential_payload during a depth-first-search on a message
|
|
|
|
* when encountering a message part that is not part of the envelope.
|
|
|
|
*/
|
|
|
|
notmuch_status_t
|
|
|
|
_notmuch_message_crypto_potential_payload (_notmuch_message_crypto_t *msg_crypto, GMimeObject *payload, GMimeObject *parent, int childnum);
|
|
|
|
|
|
|
|
|
2019-03-02 16:26:06 -04:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
2017-10-17 15:09:55 -04:00
|
|
|
#endif
|