mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-03 12:11:33 +01:00
gpg: Fix --desig-revoke.
* g10/revoke.c (gen_desig_revoke): Add additional parameter ctrl. Check that the secret key is available. If not, display an error message. -- Signed-off-by: Neal H. Walfield <neal@g10code.com> Regression-due-to: 8459bcf9
This commit is contained in:
parent
a608ee750d
commit
c37621166e
10
g10/gpg.c
10
g10/gpg.c
@ -4179,11 +4179,11 @@ main (int argc, char **argv)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case aDesigRevoke:
|
case aDesigRevoke:
|
||||||
if( argc != 1 )
|
if (argc != 1)
|
||||||
wrong_args("--desig-revoke user-id");
|
wrong_args ("--desig-revoke user-id");
|
||||||
username = make_username(*argv);
|
username = make_username (*argv);
|
||||||
gen_desig_revoke( username, locusr );
|
gen_desig_revoke (ctrl, username, locusr);
|
||||||
xfree( username );
|
xfree (username);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case aDeArmor:
|
case aDeArmor:
|
||||||
|
@ -356,7 +356,7 @@ int enarmor_file( const char *fname );
|
|||||||
struct revocation_reason_info;
|
struct revocation_reason_info;
|
||||||
int gen_standard_revoke (PKT_public_key *psk, const char *cache_nonce);
|
int gen_standard_revoke (PKT_public_key *psk, const char *cache_nonce);
|
||||||
int gen_revoke( const char *uname );
|
int gen_revoke( const char *uname );
|
||||||
int gen_desig_revoke( const char *uname, strlist_t locusr);
|
int gen_desig_revoke (ctrl_t ctrl, const char *uname, strlist_t locusr);
|
||||||
int revocation_reason_build_cb( PKT_signature *sig, void *opaque );
|
int revocation_reason_build_cb( PKT_signature *sig, void *opaque );
|
||||||
struct revocation_reason_info *
|
struct revocation_reason_info *
|
||||||
ask_revocation_reason( int key_rev, int cert_rev, int hint );
|
ask_revocation_reason( int key_rev, int cert_rev, int hint );
|
||||||
|
13
g10/revoke.c
13
g10/revoke.c
@ -195,7 +195,7 @@ export_minimal_pk(IOBUF out,KBNODE keyblock,
|
|||||||
* Generate a revocation certificate for UNAME via a designated revoker
|
* Generate a revocation certificate for UNAME via a designated revoker
|
||||||
*/
|
*/
|
||||||
int
|
int
|
||||||
gen_desig_revoke( const char *uname, strlist_t locusr )
|
gen_desig_revoke (ctrl_t ctrl, const char *uname, strlist_t locusr)
|
||||||
{
|
{
|
||||||
int rc = 0;
|
int rc = 0;
|
||||||
armor_filter_context_t *afx;
|
armor_filter_context_t *afx;
|
||||||
@ -312,6 +312,13 @@ gen_desig_revoke( const char *uname, strlist_t locusr )
|
|||||||
tty_printf(_("(This is a sensitive revocation key)\n"));
|
tty_printf(_("(This is a sensitive revocation key)\n"));
|
||||||
tty_printf("\n");
|
tty_printf("\n");
|
||||||
|
|
||||||
|
rc = agent_probe_secret_key (ctrl, pk2);
|
||||||
|
if (rc)
|
||||||
|
{
|
||||||
|
tty_printf (_("Secret key is not available.\n"));
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
if( !cpr_get_answer_is_yes("gen_desig_revoke.okay",
|
if( !cpr_get_answer_is_yes("gen_desig_revoke.okay",
|
||||||
_("Create a designated revocation certificate for this key? (y/N) ")))
|
_("Create a designated revocation certificate for this key? (y/N) ")))
|
||||||
continue;
|
continue;
|
||||||
@ -321,10 +328,6 @@ gen_desig_revoke( const char *uname, strlist_t locusr )
|
|||||||
if( !reason )
|
if( !reason )
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
rc = -1;/*FIXME: check_secret_key (pk2, 0 );*/
|
|
||||||
if (rc)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
if( !opt.armor )
|
if( !opt.armor )
|
||||||
tty_printf(_("ASCII armored output forced.\n"));
|
tty_printf(_("ASCII armored output forced.\n"));
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user