X-Git-Url: http://git.madism.org/?p=apps%2Fmadmutt.git;a=blobdiff_plain;f=lib-crypt%2Fpgp.c;h=85725d7c749d1790ce9951bdf2ecd5fa9f2110df;hp=b29d35b882a7eec5d999fb23469e24700a187e7e;hb=b62cf5fb77a75e17b176141d232655e5bd8b7fe1;hpb=a16b0e24a0e811e35943c9f2d553a02d156d4961 diff --git a/lib-crypt/pgp.c b/lib-crypt/pgp.c index b29d35b..85725d7 100644 --- a/lib-crypt/pgp.c +++ b/lib-crypt/pgp.c @@ -29,8 +29,8 @@ #include #include #include +#include -#include "mx.h" #include "handler.h" #include "pgp.h" #include "copy.h" @@ -266,8 +266,8 @@ int pgp_application_pgp_handler (BODY * m, STATE * s) have_any_sigs = have_any_sigs || (clearsign && (s->flags & M_VERIFY)); /* Copy PGP material to temporary file */ - mutt_mktemp (tmpfname); - if ((tmpfp = safe_fopen (tmpfname, "w+")) == NULL) { + tmpfp = m_tempfile(tmpfname, sizeof(tmpfname), NONULL(Tempdir), NULL); + if (tmpfp == NULL) { mutt_perror (tmpfname); return (-1); } @@ -295,16 +295,16 @@ int pgp_application_pgp_handler (BODY * m, STATE * s) /* Invoke PGP if needed */ if (!clearsign || (s->flags & M_VERIFY)) { - mutt_mktemp (outfile); - if ((pgpout = safe_fopen (outfile, "w+")) == NULL) { - mutt_perror (tmpfname); + pgpout = m_tempfile(outfile, sizeof(outfile), NONULL(Tempdir), NULL); + if (pgpout == NULL) { + mutt_perror (outfile); return (-1); } if ((thepid = pgp_invoke_decode (&pgpin, NULL, &pgperr, -1, fileno (pgpout), -1, tmpfname, needpass)) == -1) { - safe_fclose (&pgpout); + m_fclose(&pgpout); maybe_goodsig = 0; pgpin = NULL; pgperr = NULL; @@ -322,14 +322,14 @@ int pgp_application_pgp_handler (BODY * m, STATE * s) fprintf (pgpin, "%s\n", PgpPass); } - safe_fclose (&pgpin); + m_fclose(&pgpin); if (s->flags & M_DISPLAY) { crypt_current_time (s, "PGP"); rc = pgp_copy_checksig (pgperr, s->fpout); } - safe_fclose (&pgperr); + m_fclose(&pgperr); rv = mutt_wait_filter (thepid); if (s->flags & M_DISPLAY) { @@ -430,11 +430,11 @@ out: m->goodsig = (maybe_goodsig && have_any_sigs); if (tmpfp) { - safe_fclose (&tmpfp); + m_fclose(&tmpfp); mutt_unlink (tmpfname); } if (pgpout) { - safe_fclose (&pgpout); + m_fclose(&pgpout); mutt_unlink (outfile); } @@ -486,7 +486,7 @@ static int pgp_check_traditional_one_body (FILE * fp, BODY * b, key = 1; } } - safe_fclose (&tfp); + m_fclose(&tfp); unlink (tempfile); if (!enc && !sgn && !key) @@ -547,8 +547,8 @@ int pgp_verify_one (BODY * sigbdy, STATE * s, const char *tempfile) mutt_copy_bytes (s->fpin, fp, sigbdy->length); fclose (fp); - mutt_mktemp (pgperrfile); - if (!(pgperr = safe_fopen (pgperrfile, "w+"))) { + pgperr = m_tempfile(pgperrfile, sizeof(pgperrfile), NONULL(Tempdir), NULL); + if (pgperr == NULL) { mutt_perror (pgperrfile); unlink (sigfile); return -1; @@ -563,7 +563,7 @@ int pgp_verify_one (BODY * sigbdy, STATE * s, const char *tempfile) badsig = 0; - safe_fclose (&pgpout); + m_fclose(&pgpout); fflush (pgperr); rewind (pgperr); @@ -574,7 +574,7 @@ int pgp_verify_one (BODY * sigbdy, STATE * s, const char *tempfile) badsig = -1; } - safe_fclose (&pgperr); + m_fclose(&pgperr); state_attach_puts (_("[-- End of PGP output --]\n\n"), s); @@ -593,8 +593,8 @@ static void pgp_extract_keys_from_attachment (FILE * fp, BODY * top) FILE *tempfp; char tempfname[_POSIX_PATH_MAX]; - mutt_mktemp (tempfname); - if (!(tempfp = safe_fopen (tempfname, "w"))) { + tempfp = m_tempfile(tempfname, sizeof(tempfname), NONULL(Tempdir), NULL); + if (tempfp == NULL) { mutt_perror (tempfname); return; } @@ -648,15 +648,15 @@ BODY *pgp_decrypt_part (BODY * a, STATE * s, FILE * fpout, BODY * p) pid_t thepid; int rv; - mutt_mktemp (pgperrfile); - if ((pgperr = safe_fopen (pgperrfile, "w+")) == NULL) { + pgperr = m_tempfile(pgperrfile, sizeof(pgperrfile), NONULL(Tempdir), NULL); + if (pgperr == NULL) { mutt_perror (pgperrfile); return NULL; } unlink (pgperrfile); - mutt_mktemp (pgptmpfile); - if ((pgptmp = safe_fopen (pgptmpfile, "w")) == NULL) { + pgptmp = m_tempfile(pgptmpfile, sizeof(pgptmpfile), NONULL(Tempdir), NULL); + if (pgptmp == NULL) { mutt_perror (pgptmpfile); fclose (pgperr); return NULL; @@ -756,8 +756,8 @@ int pgp_decrypt_mime (FILE * fpin, FILE ** fpout, BODY * b, BODY ** cur) p_clear(&s, 1); s.fpin = fpin; - mutt_mktemp (tempfile); - if ((*fpout = safe_fopen (tempfile, "w+")) == NULL) { + *fpout = m_tempfile(tempfile, sizeof(tempfile), NONULL(Tempdir), NULL); + if (*fpout == NULL) { mutt_perror (tempfile); return (-1); } @@ -797,8 +797,8 @@ int pgp_encrypted_handler (BODY * a, STATE * s) */ a = a->next; - mutt_mktemp (tempfile); - if ((fpout = safe_fopen (tempfile, "w+")) == NULL) { + fpout = m_tempfile(tempfile, sizeof(tempfile), NONULL(Tempdir), NULL); + if (fpout == NULL) { if (s->flags & M_DISPLAY) state_attach_puts (_ ("[-- Error: could not create temporary file! --]\n"), @@ -867,13 +867,13 @@ BODY *pgp_sign_message (BODY * a) convert_to_7bit (a); /* Signed data _must_ be in 7-bit format. */ - mutt_mktemp (sigfile); - if ((fp = safe_fopen (sigfile, "w")) == NULL) { + fp = m_tempfile(sigfile, sizeof(sigfile), NONULL(Tempdir), NULL); + if (fp == NULL) { return (NULL); } - mutt_mktemp (signedfile); - if ((sfp = safe_fopen (signedfile, "w")) == NULL) { + sfp = m_tempfile(signedfile, sizeof(signedfile), NONULL(Tempdir), NULL); + if (sfp == NULL) { mutt_perror (signedfile); fclose (fp); unlink (sigfile); @@ -1113,27 +1113,28 @@ BODY *pgp_encrypt_message (BODY * a, char *keylist, int sign) int empty = 0; pid_t thepid; - mutt_mktemp (tempfile); - if ((fpout = safe_fopen (tempfile, "w+")) == NULL) { + fpout = m_tempfile(tempfile, sizeof(tempfile), NONULL(Tempdir), NULL); + if (fpout == NULL) { mutt_perror (tempfile); return (NULL); } - mutt_mktemp (pgperrfile); - if ((pgperr = safe_fopen (pgperrfile, "w+")) == NULL) { + pgperr = m_tempfile(pgperrfile, sizeof(pgperrfile), NONULL(Tempdir), NULL); + if (pgperr == NULL) { mutt_perror (pgperrfile); - unlink (tempfile); fclose (fpout); + unlink (tempfile); return NULL; } unlink (pgperrfile); - mutt_mktemp (pgpinfile); - if ((fptmp = safe_fopen (pgpinfile, "w")) == NULL) { + fptmp = m_tempfile(pgpinfile, sizeof(pgpinfile), NONULL(Tempdir), NULL); + if (fptmp == NULL) { mutt_perror (pgpinfile); - unlink (tempfile); fclose (fpout); + unlink (tempfile); fclose (pgperr); + unlink (pgperrfile); return NULL; } @@ -1251,8 +1252,8 @@ BODY *pgp_traditional_encryptsign (BODY * a, int flags, char *keylist) return NULL; } - mutt_mktemp (pgpinfile); - if ((pgpin = safe_fopen (pgpinfile, "w")) == NULL) { + pgpin = m_tempfile(pgpinfile, sizeof(pgpinfile), NONULL(Tempdir), NULL); + if (pgpin == NULL) { mutt_perror (pgpinfile); fclose (fp); return NULL; @@ -1289,19 +1290,23 @@ BODY *pgp_traditional_encryptsign (BODY * a, int flags, char *keylist) send_charset = "us-ascii"; mutt_copy_stream (fp, pgpin); } - safe_fclose (&fp); + m_fclose(&fp); fclose (pgpin); - mutt_mktemp (pgpoutfile); - mutt_mktemp (pgperrfile); - if ((pgpout = safe_fopen (pgpoutfile, "w+")) == NULL || - (pgperr = safe_fopen (pgperrfile, "w+")) == NULL) { + pgpout = m_tempfile(pgpoutfile, sizeof(pgpoutfile), NONULL(Tempdir), NULL); + pgperr = m_tempfile(pgperrfile, sizeof(pgperrfile), NONULL(Tempdir), NULL); + if (pgpout == NULL || pgperr == NULL) { mutt_perror (pgpout ? pgperrfile : pgpoutfile); + fclose (pgpin); unlink (pgpinfile); if (pgpout) { fclose (pgpout); unlink (pgpoutfile); } + if (pgperr) { + fclose(pgperr); + unlink(pgperrfile); + } return NULL; }