diff options
author | Bodo Möller <bodo@openssl.org> | 2005-10-01 06:08:48 +0200 |
---|---|---|
committer | Bodo Möller <bodo@openssl.org> | 2005-10-01 06:08:48 +0200 |
commit | 13e4670c2947de4fad42bb6e9802c54e54f3053c (patch) | |
tree | 07273e8d4c17420f66f15333180c29fdecb5fbf5 /apps/ciphers.c | |
parent | Fix compilation without OPENSSL_NO_COMP :-) (diff) | |
download | openssl-13e4670c2947de4fad42bb6e9802c54e54f3053c.tar.xz openssl-13e4670c2947de4fad42bb6e9802c54e54f3053c.zip |
new option "openssl ciphers -V"
Diffstat (limited to 'apps/ciphers.c')
-rw-r--r-- | apps/ciphers.c | 33 |
1 files changed, 27 insertions, 6 deletions
diff --git a/apps/ciphers.c b/apps/ciphers.c index f5e8700a01..aa76ae2853 100644 --- a/apps/ciphers.c +++ b/apps/ciphers.c @@ -71,7 +71,8 @@ static const char *ciphers_usage[]={ "usage: ciphers args\n", -" -v - verbose mode, a textual listing of the ciphers in SSLeay\n", +" -v - verbose mode, a textual listing of the SSL/TLS ciphers in OpenSSL\n", +" -V - even more verbose\n", " -ssl2 - SSL2 mode\n", " -ssl3 - SSL3 mode\n", " -tls1 - TLS1 mode\n", @@ -83,7 +84,7 @@ int MAIN(int, char **); int MAIN(int argc, char **argv) { int ret=1,i; - int verbose=0; + int verbose=0,Verbose=0; const char **pp; const char *p; int badops=0; @@ -121,6 +122,8 @@ int MAIN(int argc, char **argv) { if (strcmp(*argv,"-v") == 0) verbose=1; + else if (strcmp(*argv,"-V") == 0) + verbose=Verbose=1; #ifndef OPENSSL_NO_SSL2 else if (strcmp(*argv,"-ssl2") == 0) meth=SSLv2_client_method(); @@ -179,15 +182,33 @@ int MAIN(int argc, char **argv) } BIO_printf(STDout,"\n"); } - else + else /* verbose */ { sk=SSL_get_ciphers(ssl); for (i=0; i<sk_SSL_CIPHER_num(sk); i++) { - BIO_puts(STDout,SSL_CIPHER_description( - sk_SSL_CIPHER_value(sk,i), - buf,sizeof buf)); + SSL_CIPHER *c; + + c = sk_SSL_CIPHER_value(sk,i); + + if (Verbose) + { + unsigned long id = c->id; + int id0 = (int)(id >> 24); + int id1 = (int)((id >> 16) & 0xffL); + int id2 = (int)((id >> 8) & 0xffL); + int id3 = (int)(i & 0xffL); + + if ((id & 0xff000000L) == 0x02000000L) + BIO_printf(STDout, " 0x%02X,0x%02X,0x%02X - ", id1, id2, id3); /* SSL2 cipher */ + else if ((id & 0xff000000L) == 0x03000000L) + BIO_printf(STDout, " 0x%02X,0x%02X - ", id2, id3); /* SSL3 cipher */ + else + BIO_printf(STDout, "0x%02X,0x%02X,0x%02X,0x%02X - ", id0, id1, id2, id3); /* whatever */ + } + + BIO_puts(STDout,SSL_CIPHER_description(c,buf,sizeof buf)); } } |