NeoMutt  2025-12-11-435-g4ac674
Teaching an old dog new tricks
DOXYGEN
Loading...
Searching...
No Matches
Pgp Function API

Prototype for a Pgp Function. More...

+ Collaboration diagram for Pgp Function API:

Functions

static int op_exit (struct PgpData *pd, const struct KeyEvent *event)
 Exit this menu - Implements pgp_function_t -.
 
static int op_generic_select_entry (struct PgpData *pd, const struct KeyEvent *event)
 Select the current entry - Implements pgp_function_t -.
 
static int op_verify_key (struct PgpData *pd, const struct KeyEvent *event)
 Verify a PGP public key - Implements pgp_function_t -.
 
static int op_view_id (struct PgpData *pd, const struct KeyEvent *event)
 View the key's user id - Implements pgp_function_t -.
 

Detailed Description

Prototype for a Pgp Function.

Parameters
menuMenu
eventEvent to process
Return values
enumFunctionRetval
Precondition
menu is not NULL
event is not NULL

Function Documentation

◆ op_exit()

static int op_exit ( struct PgpData * pd,
const struct KeyEvent * event )
static

Exit this menu - Implements pgp_function_t -.

Definition at line 53 of file pgp_functions.c.

54{
55 pd->done = true;
56 return FR_SUCCESS;
57}
@ FR_SUCCESS
Valid function - successfully performed.
Definition dispatcher.h:40
bool done
Should we close the Dialog?

◆ op_generic_select_entry()

static int op_generic_select_entry ( struct PgpData * pd,
const struct KeyEvent * event )
static

Select the current entry - Implements pgp_function_t -.

Definition at line 62 of file pgp_functions.c.

63{
64 /* XXX make error reporting more verbose */
65
66 const int index = menu_get_index(pd->menu);
67 struct PgpUid **pkey = ARRAY_GET(pd->key_table, index);
68 if (!pkey)
69 return FR_ERROR;
70
72 {
73 if (!pgp_key_is_valid((*pkey)->parent))
74 {
75 mutt_error(_("This key can't be used: expired/disabled/revoked"));
76 return FR_ERROR;
77 }
78 }
79
80 if (OptPgpCheckTrust && (!pgp_id_is_valid((*pkey)) || !pgp_id_is_strong((*pkey))))
81 {
82 const char *str = "";
83 char buf2[1024] = { 0 };
84
85 if ((*pkey)->flags & KEYFLAG_CANTUSE)
86 {
87 str = _("ID is expired/disabled/revoked. Do you really want to use the key?");
88 }
89 else
90 {
91 switch ((*pkey)->trust & 0x03)
92 {
93 case 0:
94 str = _("ID has undefined validity. Do you really want to use the key?");
95 break;
96 case 1:
97 str = _("ID is not valid. Do you really want to use the key?");
98 break;
99 case 2:
100 str = _("ID is only marginally valid. Do you really want to use the key?");
101 break;
102 }
103 }
104
105 snprintf(buf2, sizeof(buf2), "%s", str);
106
107 if (query_yesorno(buf2, MUTT_NO) != MUTT_YES)
108 {
110 return FR_NO_ACTION;
111 }
112 }
113
114 pd->key = (*pkey)->parent;
115 pd->done = true;
116 return FR_SUCCESS;
117}
#define ARRAY_GET(head, idx)
Return the element at index.
Definition array.h:109
@ FR_ERROR
Valid function - error occurred.
Definition dispatcher.h:39
@ FR_NO_ACTION
Valid function - no action performed.
Definition dispatcher.h:38
bool OptPgpCheckTrust
(pseudo) used by dlg_pgp()
Definition globals.c:55
#define mutt_error(...)
Definition logging2.h:94
int menu_get_index(struct Menu *menu)
Get the current selection in the Menu.
Definition menu.c:164
#define _(a)
Definition message.h:28
void mutt_clear_error(void)
Clear the message line (bottom line of screen)
#define KEYFLAG_CANTUSE
Definition lib.h:147
bool pgp_id_is_valid(struct PgpUid *uid)
Is a PGP key valid.
Definition pgpkey.c:148
bool pgp_id_is_strong(struct PgpUid *uid)
Is a PGP key strong?
Definition pgpkey.c:135
bool pgp_key_is_valid(struct PgpKeyInfo *k)
Is a PGP key valid?
Definition pgpkey.c:103
@ MUTT_NO
User answered 'No', or assume 'No'.
Definition quad.h:38
@ MUTT_YES
User answered 'Yes', or assume 'Yes'.
Definition quad.h:39
enum QuadOption query_yesorno(const char *prompt, enum QuadOption def)
Ask the user a Yes/No question.
Definition question.c:326
struct Menu * menu
Pgp Menu.
struct PgpUidArray * key_table
Array of Keys.
struct PgpKeyInfo * key
Selected Key.
struct PgpKeyInfo * parent
Parent key.
Definition pgplib.h:58
PGP User ID.
Definition pgplib.h:36
+ Here is the call graph for this function:

◆ op_verify_key()

static int op_verify_key ( struct PgpData * pd,
const struct KeyEvent * event )
static

Verify a PGP public key - Implements pgp_function_t -.

Definition at line 122 of file pgp_functions.c.

123{
124 FILE *fp_null = mutt_file_fopen("/dev/null", "w");
125 if (!fp_null)
126 {
127 mutt_perror(_("Can't open /dev/null"));
128 return FR_ERROR;
129 }
130 struct Buffer *tempfile = NULL;
131 tempfile = buf_pool_get();
132 buf_mktemp(tempfile);
133 FILE *fp_tmp = mutt_file_fopen(buf_string(tempfile), "w");
134 if (!fp_tmp)
135 {
136 mutt_perror(_("Can't create temporary file"));
137 mutt_file_fclose(&fp_null);
138 buf_pool_release(&tempfile);
139 return FR_ERROR;
140 }
141
142 mutt_message(_("Invoking PGP..."));
143
144 const int index = menu_get_index(pd->menu);
145 struct PgpUid **pkey = ARRAY_GET(pd->key_table, index);
146 if (!pkey)
147 {
148 mutt_file_fclose(&fp_tmp);
149 mutt_file_fclose(&fp_null);
150 return FR_ERROR;
151 }
152
153 char tmpbuf[256] = { 0 };
154 snprintf(tmpbuf, sizeof(tmpbuf), "0x%s",
155 pgp_fpr_or_lkeyid(pgp_principal_key((*pkey)->parent)));
156
157 pid_t pid = pgp_invoke_verify_key(NULL, NULL, NULL, -1, fileno(fp_tmp),
158 fileno(fp_null), tmpbuf);
159 if (pid == -1)
160 {
161 mutt_perror(_("Can't create filter"));
162 unlink(buf_string(tempfile));
163 mutt_file_fclose(&fp_tmp);
164 mutt_file_fclose(&fp_null);
165 }
166
167 filter_wait(pid);
168 mutt_file_fclose(&fp_tmp);
169 mutt_file_fclose(&fp_null);
171 char title[1024] = { 0 };
172 snprintf(title, sizeof(title), _("Key ID: 0x%s"),
173 pgp_keyid(pgp_principal_key((*pkey)->parent)));
174
175 struct PagerData pdata = { 0 };
176 struct PagerView pview = { &pdata };
177
178 pdata.fname = buf_string(tempfile);
179
180 pview.banner = title;
182 pview.mode = PAGER_MODE_OTHER;
183
184 mutt_do_pager(&pview, NULL);
185 buf_pool_release(&tempfile);
187 return FR_SUCCESS;
188}
static const char * buf_string(const struct Buffer *buf)
Convert a buffer to a const char * "string".
Definition buffer.h:96
int mutt_do_pager(struct PagerView *pview, struct Email *e)
Display some page-able text to the user (help or attachment)
Definition do_pager.c:122
#define mutt_file_fclose(FP)
Definition file.h:139
#define mutt_file_fopen(PATH, MODE)
Definition file.h:138
#define mutt_message(...)
Definition logging2.h:93
#define mutt_perror(...)
Definition logging2.h:95
#define MENU_REDRAW_FULL
Redraw everything.
Definition lib.h:60
void menu_queue_redraw(struct Menu *menu, MenuRedrawFlags redraw)
Queue a request for a redraw.
Definition menu.c:188
int filter_wait(pid_t pid)
Wait for the exit of a process and return its status.
Definition filter.c:220
#define MUTT_PAGER_NO_FLAGS
No flags are set.
Definition lib.h:62
@ PAGER_MODE_OTHER
Pager is invoked via 3rd path. Non-email content is likely to be shown.
Definition lib.h:142
char * pgp_keyid(struct PgpKeyInfo *k)
Get the ID of the main (parent) key.
Definition pgp.c:203
char * pgp_fpr_or_lkeyid(struct PgpKeyInfo *k)
Get the fingerprint or long keyid.
Definition pgp.c:233
pid_t pgp_invoke_verify_key(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 *uids)
Use PGP to verify a key.
Definition pgpinvoke.c:397
struct PgpKeyInfo * pgp_principal_key(struct PgpKeyInfo *key)
Get the main (parent) PGP key.
Definition pgpkey.c:91
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
String manipulation buffer.
Definition buffer.h:36
Data to be displayed by PagerView.
Definition lib.h:161
const char * fname
Name of the file to read.
Definition lib.h:165
Paged view into some data.
Definition lib.h:172
struct PagerData * pdata
Data that pager displays. NOTNULL.
Definition lib.h:173
enum PagerMode mode
Pager mode.
Definition lib.h:174
PagerFlags flags
Additional settings to tweak pager's function.
Definition lib.h:175
const char * banner
Title to display in status bar.
Definition lib.h:176
#define buf_mktemp(buf)
Definition tmp.h:33
+ Here is the call graph for this function:

◆ op_view_id()

static int op_view_id ( struct PgpData * pd,
const struct KeyEvent * event )
static

View the key's user id - Implements pgp_function_t -.

Definition at line 193 of file pgp_functions.c.

194{
195 const int index = menu_get_index(pd->menu);
196 struct PgpUid **pkey = ARRAY_GET(pd->key_table, index);
197 if (!pkey)
198 return FR_ERROR;
199
200 mutt_message("%s", NONULL((*pkey)->addr));
201 return FR_SUCCESS;
202}
#define NONULL(x)
Definition string2.h:44
+ Here is the call graph for this function: