mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-18 14:17:03 +01:00
See ChangeLog: Sat Mar 20 11:53:40 CET 1999 Werner Koch
This commit is contained in:
parent
8d255ff264
commit
fb8dbdbd95
2
NEWS
2
NEWS
@ -6,6 +6,8 @@
|
|||||||
|
|
||||||
* --list-trust-path now has an optional --with-colons format.
|
* --list-trust-path now has an optional --with-colons format.
|
||||||
|
|
||||||
|
* New command --recv-keys to import keys from an keyserver.
|
||||||
|
|
||||||
|
|
||||||
Noteworthy changes in version 0.9.4
|
Noteworthy changes in version 0.9.4
|
||||||
-----------------------------------
|
-----------------------------------
|
||||||
|
20
THOUGHTS
20
THOUGHTS
@ -1,4 +1,24 @@
|
|||||||
|
|
||||||
|
|
||||||
|
EGD
|
||||||
|
====
|
||||||
|
Oh, and on embedding egd into the gpg package: I think if you just unpack it
|
||||||
|
into, say, util/egd/* then you can put something like this into configure.in:
|
||||||
|
|
||||||
|
AC_CHECK_PROG(perl_present, perl, true, false)
|
||||||
|
if $perl_present; then
|
||||||
|
AC_PATH_PROG(PERL, perl)
|
||||||
|
(cd util/egd; $PERL Makefile.PL FULLPERL=$PERL INSTALLBIN=$sbindir)
|
||||||
|
fi
|
||||||
|
AM_CONDITIONAL(WITH_EGD, $perl_present)
|
||||||
|
|
||||||
|
and add util/egd to the top-level Makefile directory list inside a WITH_EGD
|
||||||
|
conditional.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
====
|
||||||
|
|
||||||
/* we still have these if a signed signed more than one
|
/* we still have these if a signed signed more than one
|
||||||
* user ID. I don't think that is makes sense to sign
|
* user ID. I don't think that is makes sense to sign
|
||||||
* more than one user ID; an exception might be a user ID
|
* more than one user ID; an exception might be a user ID
|
||||||
|
6
TODO
6
TODO
@ -25,12 +25,14 @@
|
|||||||
* Add NO_PUBKEY and NO_SECKEY status lines.
|
* Add NO_PUBKEY and NO_SECKEY status lines.
|
||||||
* Add more NODATA status lines
|
* Add more NODATA status lines
|
||||||
|
|
||||||
* gpg --keyserver wwwkeys.us.pgp.net --importserver 0x12345678
|
* Solaris make as problems with the generated POTFILES - seems to be a
|
||||||
(or --importserver warner@lothar.com, etc)
|
gettext bug.
|
||||||
|
|
||||||
|
|
||||||
Nice to have
|
Nice to have
|
||||||
------------
|
------------
|
||||||
|
* replace the keyserver stuff either by a call to a specialized
|
||||||
|
utility or SOCKSify the stuff.
|
||||||
* Do a real fix for bug #7 or document that it is a PGP 5 error.
|
* Do a real fix for bug #7 or document that it is a PGP 5 error.
|
||||||
* clearsig: Keep lineendings while writing the output of a clearsig
|
* clearsig: Keep lineendings while writing the output of a clearsig
|
||||||
* preferences of hash algorithms are not yet used.
|
* preferences of hash algorithms are not yet used.
|
||||||
|
@ -1,3 +1,9 @@
|
|||||||
|
Sat Mar 20 11:44:21 CET 1999 Werner Koch <wk@isil.d.shuttle.de>
|
||||||
|
|
||||||
|
* rndlinux.c (tty_printf) [IS_MODULE]: Removed.
|
||||||
|
|
||||||
|
* rndegd.c (gather_random): Some fixes.
|
||||||
|
|
||||||
Wed Mar 17 13:09:03 CET 1999 Werner Koch <wk@isil.d.shuttle.de>
|
Wed Mar 17 13:09:03 CET 1999 Werner Koch <wk@isil.d.shuttle.de>
|
||||||
|
|
||||||
* rndegd.c (do_read): New.
|
* rndegd.c (do_read): New.
|
||||||
|
@ -82,6 +82,7 @@ do_read( int fd, void *buf, size_t nbytes )
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/* fixme: level 1 is not yet handled */
|
/* fixme: level 1 is not yet handled */
|
||||||
static int
|
static int
|
||||||
gather_random( void (*add)(const void*, size_t, int), int requester,
|
gather_random( void (*add)(const void*, size_t, int), int requester,
|
||||||
@ -138,14 +139,15 @@ gather_random( void (*add)(const void*, size_t, int), int requester,
|
|||||||
do_restart = 1;
|
do_restart = 1;
|
||||||
goto restart;
|
goto restart;
|
||||||
}
|
}
|
||||||
if( !n ) {
|
n = buffer[0];
|
||||||
g10_log_error("bad EGD reply: too short\n");
|
if( n ) {
|
||||||
do_restart = 1;
|
n = do_read( fd, buffer, n );
|
||||||
goto restart;
|
if( n == -1 ) {
|
||||||
}
|
g10_log_error("read error on EGD: %s\n", strerror(errno));
|
||||||
if( n > 1 ) {
|
do_restart = 1;
|
||||||
n--;
|
goto restart;
|
||||||
(*add)( buffer+1, n, requester );
|
}
|
||||||
|
(*add)( buffer, n, requester );
|
||||||
length -= n;
|
length -= n;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -172,11 +174,6 @@ gather_random( void (*add)(const void*, size_t, int), int requester,
|
|||||||
do_restart = 1;
|
do_restart = 1;
|
||||||
goto restart;
|
goto restart;
|
||||||
}
|
}
|
||||||
if( n != nbytes ) {
|
|
||||||
g10_log_error("bad EGD reply: too short %d/%d\n", nbytes, n );
|
|
||||||
do_restart = 1;
|
|
||||||
goto restart;
|
|
||||||
}
|
|
||||||
(*add)( buffer, n, requester );
|
(*add)( buffer, n, requester );
|
||||||
length -= n;
|
length -= n;
|
||||||
}
|
}
|
||||||
|
@ -48,14 +48,6 @@ static int open_device( const char *name, int minor );
|
|||||||
static int gather_random( void (*add)(const void*, size_t, int), int requester,
|
static int gather_random( void (*add)(const void*, size_t, int), int requester,
|
||||||
size_t length, int level );
|
size_t length, int level );
|
||||||
|
|
||||||
#ifdef IS_MODULE
|
|
||||||
static void tty_printf(const char *fmt, ... )
|
|
||||||
{
|
|
||||||
g10_log_info("tty_printf not available (%s)\n", fmt );
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/****************
|
/****************
|
||||||
* Used to open the Linux and xBSD /dev/random devices
|
* Used to open the Linux and xBSD /dev/random devices
|
||||||
@ -110,15 +102,24 @@ gather_random( void (*add)(const void*, size_t, int), int requester,
|
|||||||
tv.tv_usec = 0;
|
tv.tv_usec = 0;
|
||||||
if( !(rc=select(fd+1, &rfds, NULL, NULL, &tv)) ) {
|
if( !(rc=select(fd+1, &rfds, NULL, NULL, &tv)) ) {
|
||||||
if( !warn )
|
if( !warn )
|
||||||
tty_printf( _(
|
#ifdef IS_MODULE
|
||||||
"\n"
|
fprintf(stderr,
|
||||||
|
#else
|
||||||
|
tty_printf(
|
||||||
|
#endif
|
||||||
|
_("\n"
|
||||||
"Not enough random bytes available. Please do some other work to give\n"
|
"Not enough random bytes available. Please do some other work to give\n"
|
||||||
"the OS a chance to collect more entropy! (Need %d more bytes)\n"), length );
|
"the OS a chance to collect more entropy! (Need %d more bytes)\n"), length );
|
||||||
warn = 1;
|
warn = 1;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
else if( rc == -1 ) {
|
else if( rc == -1 ) {
|
||||||
tty_printf("select() error: %s\n", strerror(errno));
|
#ifdef IS_MODULE
|
||||||
|
fprintf(stderr,
|
||||||
|
#else
|
||||||
|
tty_printf(
|
||||||
|
#endif
|
||||||
|
"select() error: %s\n", strerror(errno));
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -209,6 +209,11 @@ B<--import>, B<--fast-import>
|
|||||||
the trustdb; this can be done at any time with the
|
the trustdb; this can be done at any time with the
|
||||||
command B<--update-trustdb>.
|
command B<--update-trustdb>.
|
||||||
|
|
||||||
|
B<--recv-keys> I<key_IDs>
|
||||||
|
Import the keys with the given key IDs from a HKP
|
||||||
|
keyserver. Option B<--keyserver> must be used to
|
||||||
|
give the name of this keyserver.
|
||||||
|
|
||||||
B<--export-ownertrust>
|
B<--export-ownertrust>
|
||||||
List the assigned ownertrust values in ASCII format
|
List the assigned ownertrust values in ASCII format
|
||||||
for backup purposes [B<gpgm> only].
|
for backup purposes [B<gpgm> only].
|
||||||
|
@ -1,3 +1,8 @@
|
|||||||
|
Sat Mar 20 11:44:21 CET 1999 Werner Koch <wk@isil.d.shuttle.de>
|
||||||
|
|
||||||
|
* g10.c (main): Added command --recv-keys
|
||||||
|
* hkp.c (hkp_import): New.
|
||||||
|
|
||||||
Wed Mar 17 13:09:03 CET 1999 Werner Koch <wk@isil.d.shuttle.de>
|
Wed Mar 17 13:09:03 CET 1999 Werner Koch <wk@isil.d.shuttle.de>
|
||||||
|
|
||||||
* trustdb.c (check_trust): add new arg add_fnc and changed all callers.
|
* trustdb.c (check_trust): add new arg add_fnc and changed all callers.
|
||||||
|
@ -85,6 +85,7 @@ enum cmd_and_opt_values { aNull = 0,
|
|||||||
aListSigs,
|
aListSigs,
|
||||||
aListSecretKeys,
|
aListSecretKeys,
|
||||||
aSendKeys,
|
aSendKeys,
|
||||||
|
aRecvKeys,
|
||||||
aExport,
|
aExport,
|
||||||
aExportAll,
|
aExportAll,
|
||||||
aExportSecret,
|
aExportSecret,
|
||||||
@ -189,6 +190,7 @@ static ARGPARSE_OPTS opts[] = {
|
|||||||
#endif
|
#endif
|
||||||
{ aExport, "export" , 256, N_("export keys") },
|
{ aExport, "export" , 256, N_("export keys") },
|
||||||
{ aSendKeys, "send-keys" , 256, N_("export keys to a key server") },
|
{ aSendKeys, "send-keys" , 256, N_("export keys to a key server") },
|
||||||
|
{ aRecvKeys, "recv-keys" , 256, N_("import keys from a key server") },
|
||||||
{ aExportAll, "export-all" , 256, "@" },
|
{ aExportAll, "export-all" , 256, "@" },
|
||||||
{ aExportSecret, "export-secret-keys" , 256, "@" },
|
{ aExportSecret, "export-secret-keys" , 256, "@" },
|
||||||
{ aImport, "import", 256 , N_("import/merge keys")},
|
{ aImport, "import", 256 , N_("import/merge keys")},
|
||||||
@ -649,6 +651,7 @@ main( int argc, char **argv )
|
|||||||
case aImport: set_cmd( &cmd, aImport); break;
|
case aImport: set_cmd( &cmd, aImport); break;
|
||||||
case aFastImport: set_cmd( &cmd, aFastImport); break;
|
case aFastImport: set_cmd( &cmd, aFastImport); break;
|
||||||
case aSendKeys: set_cmd( &cmd, aSendKeys); break;
|
case aSendKeys: set_cmd( &cmd, aSendKeys); break;
|
||||||
|
case aRecvKeys: set_cmd( &cmd, aRecvKeys); break;
|
||||||
case aExport: set_cmd( &cmd, aExport); break;
|
case aExport: set_cmd( &cmd, aExport); break;
|
||||||
case aExportAll: set_cmd( &cmd, aExportAll); break;
|
case aExportAll: set_cmd( &cmd, aExportAll); break;
|
||||||
case aListKeys: set_cmd( &cmd, aListKeys); break;
|
case aListKeys: set_cmd( &cmd, aListKeys); break;
|
||||||
@ -1108,11 +1111,14 @@ main( int argc, char **argv )
|
|||||||
case aExport:
|
case aExport:
|
||||||
case aExportAll:
|
case aExportAll:
|
||||||
case aSendKeys:
|
case aSendKeys:
|
||||||
|
case aRecvKeys:
|
||||||
sl = NULL;
|
sl = NULL;
|
||||||
for( ; argc; argc--, argv++ )
|
for( ; argc; argc--, argv++ )
|
||||||
add_to_strlist( &sl, *argv );
|
add_to_strlist( &sl, *argv );
|
||||||
if( cmd == aSendKeys )
|
if( cmd == aSendKeys )
|
||||||
hkp_export( sl );
|
hkp_export( sl );
|
||||||
|
else if( cmd == aRecvKeys )
|
||||||
|
hkp_import( sl );
|
||||||
else
|
else
|
||||||
export_pubkeys( sl, (cmd == aExport) );
|
export_pubkeys( sl, (cmd == aExport) );
|
||||||
free_strlist(sl);
|
free_strlist(sl);
|
||||||
|
30
g10/hkp.c
30
g10/hkp.c
@ -64,7 +64,9 @@ hkp_ask_import( u32 *keyid )
|
|||||||
opt.keyserver_name, (ulong)keyid[1] );
|
opt.keyserver_name, (ulong)keyid[1] );
|
||||||
rc = http_open_document( &hd, request, 0 );
|
rc = http_open_document( &hd, request, 0 );
|
||||||
if( rc ) {
|
if( rc ) {
|
||||||
log_info("can't get key from keyserver: %s\n", g10_errstr(rc) );
|
log_info("can't get key from keyserver: %s\n",
|
||||||
|
rc == G10ERR_NETWORK? strerror(errno)
|
||||||
|
: g10_errstr(rc) );
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
rc = import_keys_stream( hd.fp_read , 0 );
|
rc = import_keys_stream( hd.fp_read , 0 );
|
||||||
@ -76,6 +78,28 @@ hkp_ask_import( u32 *keyid )
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
int
|
||||||
|
hkp_import( STRLIST users )
|
||||||
|
{
|
||||||
|
if( !opt.keyserver_name ) {
|
||||||
|
log_error("no keyserver known (use option --keyserver)\n");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
for( ; users; users = users->next ) {
|
||||||
|
u32 kid[2];
|
||||||
|
int type = classify_user_id( users->d, kid, NULL, NULL, NULL );
|
||||||
|
if( type != 10 && type != 11 ) {
|
||||||
|
log_info("%s: not a valid key ID\n", users->d );
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
hkp_ask_import( kid );
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
int
|
int
|
||||||
hkp_export( STRLIST users )
|
hkp_export( STRLIST users )
|
||||||
{
|
{
|
||||||
@ -110,7 +134,9 @@ hkp_export( STRLIST users )
|
|||||||
rc = http_open( &hd, HTTP_REQ_POST, request , 0 );
|
rc = http_open( &hd, HTTP_REQ_POST, request , 0 );
|
||||||
if( rc ) {
|
if( rc ) {
|
||||||
log_error("can't connect to `%s': %s\n",
|
log_error("can't connect to `%s': %s\n",
|
||||||
opt.keyserver_name, g10_errstr(rc) );
|
opt.keyserver_name,
|
||||||
|
rc == G10ERR_NETWORK? strerror(errno)
|
||||||
|
: g10_errstr(rc) );
|
||||||
iobuf_close(temp);
|
iobuf_close(temp);
|
||||||
m_free( request );
|
m_free( request );
|
||||||
return rc;
|
return rc;
|
||||||
|
@ -23,6 +23,7 @@
|
|||||||
|
|
||||||
|
|
||||||
int hkp_ask_import( u32 *keyid );
|
int hkp_ask_import( u32 *keyid );
|
||||||
|
int hkp_import( STRLIST users );
|
||||||
int hkp_export( STRLIST users );
|
int hkp_export( STRLIST users );
|
||||||
|
|
||||||
|
|
||||||
|
13
g10/revoke.c
13
g10/revoke.c
@ -62,6 +62,19 @@ gen_revoke( const char *uname )
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* FIXME: ask for the reason of revocation
|
||||||
|
0x00 - No reason specified (key revocations or cert revocations)
|
||||||
|
Does not make sense!
|
||||||
|
|
||||||
|
0x01 - Key is superceded (key revocations)
|
||||||
|
0x02 - Key material has been compromised (key revocations)
|
||||||
|
0x03 - Key is no longer used (key revocations)
|
||||||
|
0x20 - User id information is no longer valid (cert revocations)
|
||||||
|
|
||||||
|
Following the revocation code is a string of octets which gives
|
||||||
|
information about the reason for revocation in human-readable form
|
||||||
|
*/
|
||||||
|
|
||||||
memset( &afx, 0, sizeof afx);
|
memset( &afx, 0, sizeof afx);
|
||||||
memset( &zfx, 0, sizeof zfx);
|
memset( &zfx, 0, sizeof zfx);
|
||||||
init_packet( &pkt );
|
init_packet( &pkt );
|
||||||
|
@ -1,3 +1,7 @@
|
|||||||
|
Sat Mar 20 11:44:21 CET 1999 Werner Koch <wk@isil.d.shuttle.de>
|
||||||
|
|
||||||
|
* http.c: Swapped to includes.
|
||||||
|
|
||||||
Tue Mar 2 16:44:57 CET 1999 Werner Koch <wk@isil.d.shuttle.de>
|
Tue Mar 2 16:44:57 CET 1999 Werner Koch <wk@isil.d.shuttle.de>
|
||||||
|
|
||||||
* strgutil.c (get_native_charset): New.
|
* strgutil.c (get_native_charset): New.
|
||||||
|
@ -29,8 +29,9 @@
|
|||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <sys/socket.h>
|
#include <sys/socket.h>
|
||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
#include <arpa/inet.h>
|
#include <time.h>
|
||||||
#include <netinet/in.h>
|
#include <netinet/in.h>
|
||||||
|
#include <arpa/inet.h>
|
||||||
#include <netdb.h>
|
#include <netdb.h>
|
||||||
|
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user