summaryrefslogtreecommitdiffstats
path: root/perl/ss.pl
blob: 6687d567d9d44c9a8b29dc76bcb444f4e8bf248f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
#!/usr/local/bin/perl

use ExtUtils::testlib;

use SSLeay;

$ssl_ctx=SSL::CTX->new("SSLv3_client");

#$ssl_ctx->set_options("-info_callback" =>
#	sub	{
#		print STDERR $_[0]->state()."\n";
#		}
#	);

$conn="localhost:4433";
$conn=$ARGV[0] if $#ARGV >= 0;

print $ssl_ctx."\n";
$bio=BIO->new_buffer_ssl_connect($ssl_ctx);
$bio->hostname($conn) || die $bio->error();

#$bio->set_callback(
#	sub	{
#		my($bio,$state,$cmd,$buf,$lart,$ret)=@_;
#		print STDERR "$state:$cmd\n";
#		return($ret);
#		}
#	);

#$b=$bio;
#do	{
#	print STDERR $b->type."\n";
#	} while ($b=$b->next_bio);

(($ret=$bio->syswrite("GET / HTTP/1.0\r\n\r\n")) > 0) || die $bio->error();
$bio->flush;

$data="";
while (1)
	{
	$ret=$bio->getline;
	$ret =~ s/[\r\n]//g;
	print STDERR "$ret\n";
	last if $ret eq "";
	$server=$1 if $ret=~ /^Server: (.*)/;
	}


print "server is $server\n";
$x509=$ssl->get_peer_certificate();
print "version     :".$x509->get_version()."\n";
print "serialNumber:".$x509->get_serialNumber()->bn2hex."\n";
print "subject     :".$x509->get_subject_name()."\n";
print "issuer      :". $x509->get_issuer_name()."\n";

$c=$ssl->get_current_cipher;
($i,$a)=$c->get_bits;
$v=$c->get_version;
$n=$c->get_name;

$ssl=$bio->get_ssl();
print "protocol=".$ssl->get_version."\n";
print "bits=$i($a) cipher type=$v cipher=$n\n";