mirror of
https://github.com/profanity-im/profanity.git
synced 2024-12-04 14:46:46 -05:00
Added UI function to get PGP passphrase
This commit is contained in:
parent
dd346eefc4
commit
1f4fd0fcb3
@ -79,17 +79,20 @@ _p_gpg_free_pubkeyid(ProfPGPPubKeyId *pubkeyid)
|
||||
static gpgme_error_t *
|
||||
_p_gpg_passphrase_cb(void *hook, const char *uid_hint, const char *passphrase_info, int prev_was_bad, int fd)
|
||||
{
|
||||
cons_show("Passphrase callback");
|
||||
if (uid_hint) {
|
||||
cons_show(" uid_hind: %s", uid_hint);
|
||||
GString *pass_term = g_string_new("");
|
||||
|
||||
char *password = ui_ask_pgp_passphrase(uid_hint, prev_was_bad);
|
||||
if (password) {
|
||||
g_string_append(pass_term, password);
|
||||
free(password);
|
||||
}
|
||||
if (passphrase_info) {
|
||||
cons_show(" passphrase_info: %s", passphrase_info);
|
||||
}
|
||||
if (prev_was_bad) {
|
||||
cons_show(" prev_was_bad");
|
||||
}
|
||||
gpgme_io_writen(fd, "password\n", strlen("password\n"));
|
||||
|
||||
g_string_append(pass_term, "\n");
|
||||
|
||||
gpgme_io_writen(fd, pass_term->str, pass_term->len);
|
||||
|
||||
g_string_free(pass_term, TRUE);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
@ -2101,9 +2101,29 @@ ui_win_unread(int index)
|
||||
char *
|
||||
ui_ask_password(void)
|
||||
{
|
||||
status_bar_get_password();
|
||||
status_bar_update_virtual();
|
||||
return inp_get_password();
|
||||
status_bar_get_password();
|
||||
status_bar_update_virtual();
|
||||
return inp_get_password();
|
||||
}
|
||||
|
||||
char *
|
||||
ui_ask_pgp_passphrase(const char *hint, int prev_fail)
|
||||
{
|
||||
ProfWin *current = wins_get_current();
|
||||
|
||||
if (prev_fail) {
|
||||
win_print(current, '!', 0, NULL, 0, 0, NULL, "Incorrect passphrase");
|
||||
}
|
||||
|
||||
if (hint) {
|
||||
win_vprint(current, '!', 0, NULL, 0, 0, NULL, "Enter PGP key passphrase for %s", hint);
|
||||
} else {
|
||||
win_print(current, '!', 0, NULL, 0, 0, NULL, "Enter PGP key passphrase");
|
||||
}
|
||||
|
||||
status_bar_get_password();
|
||||
status_bar_update_virtual();
|
||||
return inp_get_password();
|
||||
}
|
||||
|
||||
void
|
||||
|
@ -102,6 +102,7 @@ win_type_t ui_win_type(int index);
|
||||
void ui_close_win(int index);
|
||||
int ui_win_unread(int index);
|
||||
char * ui_ask_password(void);
|
||||
char * ui_ask_pgp_passphrase(const char *hint, int prev_fail);
|
||||
|
||||
void ui_handle_stanza(const char * const msg);
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user