NeoMutt  2024-11-14-34-g5aaf0d
Teaching an old dog new tricks
DOXYGEN
Loading...
Searching...
No Matches
smime_invoke_import()

Add a certificate and update index file (externally) More...

+ Collaboration diagram for smime_invoke_import():

Functions

void smime_class_invoke_import (const char *infile, const char *mailbox)
 Add a certificate and update index file (externally) - Implements CryptModuleSpecs::smime_invoke_import() -.
 

Detailed Description

Add a certificate and update index file (externally)

Parameters
infileFile containing certificate
mailboxMailbox

Function Documentation

◆ smime_class_invoke_import()

void smime_class_invoke_import ( const char *  infile,
const char *  mailbox 
)

Add a certificate and update index file (externally) - Implements CryptModuleSpecs::smime_invoke_import() -.

Definition at line 1132 of file smime.c.

1133{
1134 char *certfile = NULL;
1135 struct Buffer *buf = NULL;
1136
1137 FILE *fp_out = NULL;
1138 FILE *fp_err = mutt_file_mkstemp();
1139 if (!fp_err)
1140 {
1141 mutt_perror(_("Can't create temporary file"));
1142 goto done;
1143 }
1144
1145 fp_out = mutt_file_mkstemp();
1146 if (!fp_out)
1147 {
1148 mutt_perror(_("Can't create temporary file"));
1149 goto done;
1150 }
1151
1152 buf = buf_pool_get();
1153 const bool c_smime_ask_cert_label = cs_subset_bool(NeoMutt->sub, "smime_ask_cert_label");
1154 if (c_smime_ask_cert_label)
1155 {
1156 if ((mw_get_field(_("Label for certificate: "), buf, MUTT_COMP_NO_FLAGS,
1157 HC_OTHER, NULL, NULL) != 0) ||
1158 buf_is_empty(buf))
1159 {
1160 goto done;
1161 }
1162 }
1163
1164 mutt_endwin();
1165 certfile = smime_extract_certificate(infile);
1166 if (certfile)
1167 {
1168 mutt_endwin();
1169
1170 const struct Expando *c_smime_import_cert_command =
1171 cs_subset_expando(NeoMutt->sub, "smime_import_cert_command");
1172 FILE *fp_smime_in = NULL;
1173 pid_t pid = smime_invoke(&fp_smime_in, NULL, NULL, -1, fileno(fp_out),
1174 fileno(fp_err), certfile, NULL, NULL, NULL, NULL,
1175 NULL, NULL, c_smime_import_cert_command);
1176 if (pid == -1)
1177 {
1178 mutt_message(_("Error: unable to create OpenSSL subprocess"));
1179 goto done;
1180 }
1181 fputs(buf_string(buf), fp_smime_in);
1182 fputc('\n', fp_smime_in);
1183 mutt_file_fclose(&fp_smime_in);
1184
1185 filter_wait(pid);
1186
1187 mutt_file_unlink(certfile);
1188 FREE(&certfile);
1189 }
1190
1191 fflush(fp_out);
1192 rewind(fp_out);
1193 fflush(fp_err);
1194 rewind(fp_err);
1195
1196 mutt_file_copy_stream(fp_out, stdout);
1197 mutt_file_copy_stream(fp_err, stdout);
1198
1199done:
1200 mutt_file_fclose(&fp_out);
1201 mutt_file_fclose(&fp_err);
1202 buf_pool_release(&buf);
1203}
bool buf_is_empty(const struct Buffer *buf)
Is the Buffer empty?
Definition: buffer.c:291
static const char * buf_string(const struct Buffer *buf)
Convert a buffer to a const char * "string".
Definition: buffer.h:96
bool cs_subset_bool(const struct ConfigSubset *sub, const char *name)
Get a boolean config item by name.
Definition: helpers.c:47
const struct Expando * cs_subset_expando(const struct ConfigSubset *sub, const char *name)
Get an Expando config item by name.
Definition: config_type.c:357
void mutt_endwin(void)
Shutdown curses.
Definition: curs_lib.c:151
int mutt_file_copy_stream(FILE *fp_in, FILE *fp_out)
Copy the contents of one file into another.
Definition: file.c:287
void mutt_file_unlink(const char *s)
Delete a file, carefully.
Definition: file.c:221
#define mutt_file_fclose(FP)
Definition: file.h:138
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 -.
Definition: window.c:274
#define mutt_message(...)
Definition: logging2.h:91
#define mutt_perror(...)
Definition: logging2.h:93
@ HC_OTHER
Miscellaneous strings.
Definition: lib.h:59
#define FREE(x)
Definition: memory.h:55
int filter_wait(pid_t pid)
Wait for the exit of a process and return its status.
Definition: filter.c:220
#define _(a)
Definition: message.h:28
#define MUTT_COMP_NO_FLAGS
No flags are set.
Definition: mutt.h:56
struct Buffer * buf_pool_get(void)
Get a Buffer from the pool.
Definition: pool.c:81
void buf_pool_release(struct Buffer **ptr)
Return a Buffer to the pool.
Definition: pool.c:94
static char * smime_extract_certificate(const char *infile)
Extract an SMIME certificate from a file.
Definition: smime.c:949
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.
Definition: smime.c:368
String manipulation buffer.
Definition: buffer.h:36
Parsed Expando trees.
Definition: expando.h:41
Container for Accounts, Notifications.
Definition: neomutt.h:42
struct ConfigSubset * sub
Inherited config items.
Definition: neomutt.h:46
#define mutt_file_mkstemp()
Definition: tmp.h:36
+ Here is the call graph for this function: