988{
989 char *certfile = NULL;
990 struct Buffer *buf = NULL;
991
992 FILE *fp_out = NULL;
994 if (!fp_err)
995 {
997 goto done;
998 }
999
1001 if (!fp_out)
1002 {
1004 goto done;
1005 }
1006
1009 if (c_smime_ask_cert_label)
1010 {
1014 {
1015 goto done;
1016 }
1017 }
1018
1021 if (certfile)
1022 {
1024
1025 const struct Expando *c_smime_import_cert_command =
1027 FILE *fp_smime_in = NULL;
1028 pid_t pid =
smime_invoke(&fp_smime_in, NULL, NULL, -1, fileno(fp_out),
1029 fileno(fp_err), certfile, NULL, NULL, NULL, NULL,
1030 NULL, NULL, c_smime_import_cert_command);
1031 if (pid == -1)
1032 {
1033 mutt_message(
_(
"Error: unable to create OpenSSL subprocess"));
1034 goto done;
1035 }
1037 fputc('\n', fp_smime_in);
1039
1041
1044 }
1045
1046 fflush(fp_out);
1047 rewind(fp_out);
1048 fflush(fp_err);
1049 rewind(fp_err);
1050
1053
1054done:
1058}
bool buf_is_empty(const struct Buffer *buf)
Is the Buffer empty?
static const char * buf_string(const struct Buffer *buf)
Convert a buffer to a const char * "string".
bool cs_subset_bool(const struct ConfigSubset *sub, const char *name)
Get a boolean config item by name.
const struct Expando * cs_subset_expando(const struct ConfigSubset *sub, const char *name)
Get an Expando config item by name.
void mutt_endwin(void)
Shutdown curses.
#define MUTT_COMP_NO_FLAGS
No flags are set.
int mutt_file_copy_stream(FILE *fp_in, FILE *fp_out)
Copy the contents of one file into another.
void mutt_file_unlink(const char *s)
Delete a file, carefully.
#define mutt_file_fclose(FP)
int mw_get_field(const char *prompt, struct Buffer *buf, CompletionFlags complete, enum HistoryClass hclass, const struct CompleteOps *comp_api, void *cdata)
Ask the user for a string -.
#define mutt_message(...)
@ HC_OTHER
Miscellaneous strings.
#define FREE(x)
Free memory and set the pointer to NULL.
int filter_wait(pid_t pid)
Wait for the exit of a process and return its status.
struct Buffer * buf_pool_get(void)
Get a Buffer from the pool.
void buf_pool_release(struct Buffer **ptr)
Return a Buffer to the pool.
static char * smime_extract_certificate(const char *infile)
Extract an SMIME certificate from a file.
static pid_t smime_invoke(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, const char *cryptalg, const char *digestalg, const char *key, const char *certificates, const char *intermediates, const struct Expando *exp)
Run an SMIME command.
String manipulation buffer.
Container for Accounts, Notifications.
struct ConfigSubset * sub
Inherited config items.
#define mutt_file_mkstemp()