NeoMutt  2025-12-11-596-g7cc1dd
Teaching an old dog new tricks
DOXYGEN
Loading...
Searching...
No Matches
verify_one()

Check a signed MIME part against a signature. More...

+ Collaboration diagram for verify_one():

Functions

int pgp_gpgme_verify_one (struct Body *b, struct State *state, const char *tempfile)
 Check a signed MIME part against a signature - Implements CryptModuleSpecs::verify_one() -.
 
int smime_gpgme_verify_one (struct Body *b, struct State *state, const char *tempfile)
 Check a signed MIME part against a signature - Implements CryptModuleSpecs::verify_one() -.
 
int pgp_class_verify_one (struct Body *b, struct State *state, const char *tempfile)
 Check a signed MIME part against a signature - Implements CryptModuleSpecs::verify_one() -.
 
int smime_class_verify_one (struct Body *b, struct State *state, const char *tempfile)
 Check a signed MIME part against a signature - Implements CryptModuleSpecs::verify_one() -.
 

Detailed Description

Check a signed MIME part against a signature.

Parameters
bBody of the signed mail
stateState of text being processed
tempfFile containing the key
Return values
0Success
-1Error

Function Documentation

◆ pgp_gpgme_verify_one()

int pgp_gpgme_verify_one ( struct Body * b,
struct State * state,
const char * tempfile )

Check a signed MIME part against a signature - Implements CryptModuleSpecs::verify_one() -.

Definition at line 1706 of file crypt_gpgme.c.

1707{
1708 return verify_one(b, state, tempfile, false);
1709}
static int verify_one(struct Body *b, struct State *state, const char *tempfile, bool is_smime)
Do the actual verification step.
+ Here is the call graph for this function:

◆ smime_gpgme_verify_one()

int smime_gpgme_verify_one ( struct Body * b,
struct State * state,
const char * tempfile )

Check a signed MIME part against a signature - Implements CryptModuleSpecs::verify_one() -.

Definition at line 1714 of file crypt_gpgme.c.

1715{
1716 return verify_one(b, state, tempfile, true);
1717}
+ Here is the call graph for this function:

◆ pgp_class_verify_one()

int pgp_class_verify_one ( struct Body * b,
struct State * state,
const char * tempfile )

Check a signed MIME part against a signature - Implements CryptModuleSpecs::verify_one() -.

Definition at line 897 of file pgp.c.

898{
899 FILE *fp_pgp_out = NULL;
900 pid_t pid;
901 int badsig = -1;
902 struct Buffer *sigfile = buf_pool_get();
903
904 buf_printf(sigfile, "%s.asc", tempfile);
905
906 FILE *fp_sig = mutt_file_fopen(buf_string(sigfile), "w");
907 if (!fp_sig)
908 {
909 mutt_perror("%s", buf_string(sigfile));
910 goto cleanup;
911 }
912
913 if (!mutt_file_seek(state->fp_in, b->offset, SEEK_SET))
914 {
915 mutt_file_fclose(&fp_sig);
916 goto cleanup;
917 }
918 mutt_file_copy_bytes(state->fp_in, fp_sig, b->length);
919 mutt_file_fclose(&fp_sig);
920
921 FILE *fp_pgp_err = mutt_file_mkstemp();
922 if (!fp_pgp_err)
923 {
924 mutt_perror(_("Can't create temporary file"));
925 unlink(buf_string(sigfile));
926 goto cleanup;
927 }
928
929 crypt_current_time(state, "PGP");
930
931 pid = pgp_invoke_verify(NULL, &fp_pgp_out, NULL, -1, -1, fileno(fp_pgp_err),
932 tempfile, buf_string(sigfile));
933 if (pid != -1)
934 {
935 if (pgp_copy_checksig(fp_pgp_out, state->fp_out) >= 0)
936 badsig = 0;
937
938 mutt_file_fclose(&fp_pgp_out);
939 fflush(fp_pgp_err);
940 rewind(fp_pgp_err);
941
942 if (pgp_copy_checksig(fp_pgp_err, state->fp_out) >= 0)
943 badsig = 0;
944
945 const int rv = filter_wait(pid);
946 if (rv)
947 badsig = -1;
948
949 mutt_debug(LL_DEBUG1, "filter_wait returned %d\n", rv);
950 }
951
952 mutt_file_fclose(&fp_pgp_err);
953
954 state_attach_puts(state, _("[-- End of PGP output --]\n\n"));
955
957
958cleanup:
959 buf_pool_release(&sigfile);
960
961 mutt_debug(LL_DEBUG1, "returning %d\n", badsig);
962 return badsig;
963}
int buf_printf(struct Buffer *buf, const char *fmt,...)
Format a string overwriting a Buffer.
Definition buffer.c:161
static const char * buf_string(const struct Buffer *buf)
Convert a buffer to a const char * "string".
Definition buffer.h:96
void crypt_current_time(struct State *state, const char *app_name)
Print the current time.
Definition crypt.c:64
int mutt_file_copy_bytes(FILE *fp_in, FILE *fp_out, size_t size)
Copy some content from one file to another.
Definition file.c:192
bool mutt_file_seek(FILE *fp, LOFF_T offset, int whence)
Wrapper for fseeko with error handling.
Definition file.c:652
void mutt_file_unlink(const char *s)
Delete a file, carefully.
Definition file.c:156
#define mutt_file_fclose(FP)
Definition file.h:139
#define mutt_file_fopen(PATH, MODE)
Definition file.h:138
#define mutt_debug(LEVEL,...)
Definition logging2.h:91
#define mutt_perror(...)
Definition logging2.h:95
@ LL_DEBUG1
Log at debug level 1.
Definition logging2.h:45
int filter_wait(pid_t pid)
Wait for the exit of a process and return its status.
Definition filter.c:228
#define _(a)
Definition message.h:28
void state_attach_puts(struct State *state, const char *t)
Write a string to the state.
Definition state.c:104
static int pgp_copy_checksig(FILE *fp_in, FILE *fp_out)
Copy PGP output and look for signs of a good signature.
Definition pgp.c:250
pid_t pgp_invoke_verify(FILE **fp_pgp_in, FILE **fp_pgp_out, FILE **fp_pgp_err, int fd_pgp_in, int fd_pgp_out, int fd_pgp_err, const char *fname, const char *sig_fname)
Use PGP to verify a message.
Definition pgpinvoke.c:157
struct Buffer * buf_pool_get(void)
Get a Buffer from the pool.
Definition pool.c:91
void buf_pool_release(struct Buffer **ptr)
Return a Buffer to the pool.
Definition pool.c:111
LOFF_T offset
offset where the actual data begins
Definition body.h:52
LOFF_T length
length (in bytes) of attachment
Definition body.h:53
String manipulation buffer.
Definition buffer.h:36
FILE * fp_out
File to write to.
Definition state.h:50
FILE * fp_in
File to read from.
Definition state.h:49
#define mutt_file_mkstemp()
Definition tmp.h:36
+ Here is the call graph for this function:

◆ smime_class_verify_one()

int smime_class_verify_one ( struct Body * b,
struct State * state,
const char * tempfile )

Check a signed MIME part against a signature - Implements CryptModuleSpecs::verify_one() -.

Definition at line 1566 of file smime.c.

1567{
1568 FILE *fp = NULL, *fp_smime_out = NULL, *fp_smime_err = NULL;
1569 pid_t pid;
1570 int badsig = -1;
1571
1572 LOFF_T tmpoffset = 0;
1573 size_t tmplength = 0;
1574 int orig_type = b->type;
1575
1576 struct Buffer *signedfile = buf_pool_get();
1577
1578 buf_printf(signedfile, "%s.sig", tempfile);
1579
1580 /* decode to a tempfile, saving the original destination */
1581 fp = state->fp_out;
1582 state->fp_out = mutt_file_fopen(buf_string(signedfile), "w");
1583 if (!state->fp_out)
1584 {
1585 mutt_perror("%s", buf_string(signedfile));
1586 goto cleanup;
1587 }
1588 /* decoding the attachment changes the size and offset, so save a copy
1589 * of the "real" values now, and restore them after processing */
1590 tmplength = b->length;
1591 tmpoffset = b->offset;
1592
1593 /* if we are decoding binary bodies, we don't want to prefix each
1594 * line with the prefix or else the data will get corrupted. */
1595 const char *save_prefix = state->prefix;
1596 state->prefix = NULL;
1597
1598 mutt_decode_attachment(b, state);
1599
1600 b->length = ftello(state->fp_out);
1601 b->offset = 0;
1602 mutt_file_fclose(&state->fp_out);
1603
1604 /* restore final destination and substitute the tempfile for input */
1605 state->fp_out = fp;
1606 fp = state->fp_in;
1607 state->fp_in = mutt_file_fopen(buf_string(signedfile), "r");
1608
1609 /* restore the prefix */
1610 state->prefix = save_prefix;
1611
1612 b->type = orig_type;
1613
1614 fp_smime_err = mutt_file_mkstemp();
1615 if (!fp_smime_err)
1616 {
1617 mutt_perror(_("Can't create temporary file"));
1618 goto cleanup;
1619 }
1620
1621 crypt_current_time(state, "OpenSSL");
1622
1623 pid = smime_invoke_verify(NULL, &fp_smime_out, NULL, -1, -1, fileno(fp_smime_err),
1624 tempfile, buf_string(signedfile), 0);
1625 if (pid != -1)
1626 {
1627 fflush(fp_smime_out);
1628 mutt_file_fclose(&fp_smime_out);
1629
1630 if (filter_wait(pid))
1631 {
1632 badsig = -1;
1633 }
1634 else
1635 {
1636 char *line = NULL;
1637 size_t linelen;
1638
1639 fflush(fp_smime_err);
1640 rewind(fp_smime_err);
1641
1642 line = mutt_file_read_line(line, &linelen, fp_smime_err, NULL, MUTT_RL_NO_FLAGS);
1643 if (linelen && mutt_istr_equal(line, "verification successful"))
1644 badsig = 0;
1645
1646 FREE(&line);
1647 }
1648 }
1649
1650 fflush(fp_smime_err);
1651 rewind(fp_smime_err);
1652 mutt_file_copy_stream(fp_smime_err, state->fp_out);
1653 mutt_file_fclose(&fp_smime_err);
1654
1655 state_attach_puts(state, _("[-- End of OpenSSL output --]\n\n"));
1656
1657 mutt_file_unlink(buf_string(signedfile));
1658
1659 b->length = tmplength;
1660 b->offset = tmpoffset;
1661
1662 /* restore the original source stream */
1663 mutt_file_fclose(&state->fp_in);
1664 state->fp_in = fp;
1665
1666cleanup:
1667 buf_pool_release(&signedfile);
1668 return badsig;
1669}
int mutt_file_copy_stream(FILE *fp_in, FILE *fp_out)
Copy the contents of one file into another.
Definition file.c:222
char * mutt_file_read_line(char *line, size_t *size, FILE *fp, int *line_num, ReadLineFlags flags)
Read a line from a file.
Definition file.c:682
#define MUTT_RL_NO_FLAGS
No flags are set.
Definition file.h:40
void mutt_decode_attachment(const struct Body *b, struct State *state)
Decode an email's attachment.
Definition handler.c:1938
#define FREE(x)
Free memory and set the pointer to NULL.
Definition memory.h:68
bool mutt_istr_equal(const char *a, const char *b)
Compare two strings, ignoring case.
Definition string.c:677
static pid_t smime_invoke_verify(FILE **fp_smime_in, FILE **fp_smime_out, FILE **fp_smime_err, int fp_smime_infd, int fp_smime_outfd, int fp_smime_errfd, const char *fname, const char *sig_fname, int opaque)
Use SMIME to verify a file.
Definition smime.c:1524
unsigned int type
content-type primary type, ContentType
Definition body.h:40
const char * prefix
String to add to the beginning of each output line.
Definition state.h:51
+ Here is the call graph for this function: