mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-09 12:54:23 +01:00
wks: Allow reading of --install-key arguments from stdin.
* tools/wks-util.c (install_key_from_spec_file): New. (wks_cmd_install_key): Call it. * tools/gpg-wks-client.c (main): Allow --install-key w/o arguments. * tools/gpg-wks-server.c (main): Ditto. Signed-off-by: Werner Koch <wk@gnupg.org> (cherry picked from commit ba46a359b9d6549b74ec8401ea39bad434d87564)
This commit is contained in:
parent
bf29d7c822
commit
b6fd60dfa1
11
doc/wks.texi
11
doc/wks.texi
@ -95,8 +95,11 @@ local directory (see option @option{-C}) reflecting the structure of a
|
|||||||
WKD. The arguments are a file with the keyblock and the user-id to
|
WKD. The arguments are a file with the keyblock and the user-id to
|
||||||
install. If the first argument resembles a fingerprint the key is
|
install. If the first argument resembles a fingerprint the key is
|
||||||
taken from the current keyring; to force the use of a file, prefix the
|
taken from the current keyring; to force the use of a file, prefix the
|
||||||
first argument with "./". The command @option{--remove-key} removes a
|
first argument with "./". If no arguments are given the parameters
|
||||||
key from that directory, its only argument is a user-id.
|
are read from stdin; the expected format are lines with the
|
||||||
|
fingerprint and the mailbox separated by a space. The command
|
||||||
|
@option{--remove-key} removes a key from that directory, its only
|
||||||
|
argument is a user-id.
|
||||||
|
|
||||||
@command{gpg-wks-client} is not commonly invoked directly and thus it
|
@command{gpg-wks-client} is not commonly invoked directly and thus it
|
||||||
is not installed in the bin directory. Here is an example how it can
|
is not installed in the bin directory. Here is an example how it can
|
||||||
@ -280,7 +283,9 @@ The command @option{--install-key} manually installs a key into the
|
|||||||
WKD. The arguments are a file with the keyblock and the user-id to
|
WKD. The arguments are a file with the keyblock and the user-id to
|
||||||
install. If the first argument resembles a fingerprint the key is
|
install. If the first argument resembles a fingerprint the key is
|
||||||
taken from the current keyring; to force the use of a file, prefix the
|
taken from the current keyring; to force the use of a file, prefix the
|
||||||
first argument with "./".
|
first argument with "./". If no arguments are given the parameters
|
||||||
|
are read from stdin; the expected format are lines with the
|
||||||
|
fingerprint and the mailbox separated by a space.
|
||||||
|
|
||||||
The command @option{--remove-key} uninstalls a key from the WKD. The
|
The command @option{--remove-key} uninstalls a key from the WKD. The
|
||||||
process returns success in this case; to also print a diagnostic, use
|
process returns success in this case; to also print a diagnostic, use
|
||||||
|
@ -363,9 +363,12 @@ main (int argc, char **argv)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case aInstallKey:
|
case aInstallKey:
|
||||||
if (argc != 2)
|
if (!argc)
|
||||||
wrong_args ("--install-key FILE|FINGERPRINT USER-ID");
|
err = wks_cmd_install_key (NULL, NULL);
|
||||||
err = wks_cmd_install_key (*argv, argv[1]);
|
else if (argc == 2)
|
||||||
|
err = wks_cmd_install_key (*argv, argv[1]);
|
||||||
|
else
|
||||||
|
wrong_args ("--install-key [FILE|FINGERPRINT USER-ID]");
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case aRemoveKey:
|
case aRemoveKey:
|
||||||
|
@ -381,9 +381,12 @@ main (int argc, char **argv)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case aInstallKey:
|
case aInstallKey:
|
||||||
if (argc != 2)
|
if (!argc)
|
||||||
wrong_args ("--install-key FILE USER-ID");
|
err = wks_cmd_install_key (NULL, NULL);
|
||||||
err = wks_cmd_install_key (*argv, argv[1]);
|
else if (argc == 2)
|
||||||
|
err = wks_cmd_install_key (*argv, argv[1]);
|
||||||
|
else
|
||||||
|
wrong_args ("--install-key [FILE|FINGERPRINT USER-ID]");
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case aRemoveKey:
|
case aRemoveKey:
|
||||||
|
@ -855,8 +855,65 @@ wks_compute_hu_fname (char **r_fname, const char *addrspec)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/* Helper form wks_cmd_install_key. */
|
||||||
|
static gpg_error_t
|
||||||
|
install_key_from_spec_file (const char *fname)
|
||||||
|
{
|
||||||
|
gpg_error_t err;
|
||||||
|
estream_t fp;
|
||||||
|
char *line = NULL;
|
||||||
|
size_t linelen = 0;
|
||||||
|
char *fields[2];
|
||||||
|
unsigned int lnr = 0;
|
||||||
|
|
||||||
|
if (!fname || !strcmp (fname, ""))
|
||||||
|
fp = es_stdin;
|
||||||
|
else
|
||||||
|
fp = es_fopen (fname, "rb");
|
||||||
|
if (!fp)
|
||||||
|
{
|
||||||
|
err = gpg_error_from_syserror ();
|
||||||
|
log_error ("error reading '%s': %s\n", fname, gpg_strerror (err));
|
||||||
|
goto leave;
|
||||||
|
}
|
||||||
|
|
||||||
|
while (es_getline (&line, &linelen, fp) >= 0)
|
||||||
|
{
|
||||||
|
lnr++;
|
||||||
|
trim_spaces (line);
|
||||||
|
log_debug ("got line='%s'\n", line);
|
||||||
|
if (!*line || *line == '#')
|
||||||
|
continue;
|
||||||
|
if (split_fields (line, fields, DIM(fields)) < 2)
|
||||||
|
{
|
||||||
|
log_error ("error reading '%s': syntax error at line %u\n",
|
||||||
|
fname, lnr);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
err = wks_cmd_install_key (fields[0], fields[1]);
|
||||||
|
if (err)
|
||||||
|
goto leave;
|
||||||
|
}
|
||||||
|
if (es_ferror (fp))
|
||||||
|
{
|
||||||
|
err = gpg_error_from_syserror ();
|
||||||
|
log_error ("error reading '%s': %s\n", fname, gpg_strerror (err));
|
||||||
|
goto leave;
|
||||||
|
}
|
||||||
|
|
||||||
|
leave:
|
||||||
|
if (fp != es_stdin)
|
||||||
|
es_fclose (fp);
|
||||||
|
es_free (line);
|
||||||
|
return err;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/* Install a single key into the WKD by reading FNAME and extracting
|
/* Install a single key into the WKD by reading FNAME and extracting
|
||||||
* USERID. */
|
* USERID. If USERID is NULL FNAME is expected to be a list of fpr
|
||||||
|
* mbox lines and for each line the respective key will be
|
||||||
|
* installed. */
|
||||||
gpg_error_t
|
gpg_error_t
|
||||||
wks_cmd_install_key (const char *fname, const char *userid)
|
wks_cmd_install_key (const char *fname, const char *userid)
|
||||||
{
|
{
|
||||||
@ -871,6 +928,9 @@ wks_cmd_install_key (const char *fname, const char *userid)
|
|||||||
char *huname = NULL;
|
char *huname = NULL;
|
||||||
int any;
|
int any;
|
||||||
|
|
||||||
|
if (!userid)
|
||||||
|
return install_key_from_spec_file (fname);
|
||||||
|
|
||||||
addrspec = mailbox_from_userid (userid);
|
addrspec = mailbox_from_userid (userid);
|
||||||
if (!addrspec)
|
if (!addrspec)
|
||||||
{
|
{
|
||||||
|
Loading…
x
Reference in New Issue
Block a user