X-Git-Url: http://git.freeside.biz/gitweb/?p=freeside.git;a=blobdiff_plain;f=FS%2FFS%2Fsvc_cert.pm;h=88e4199e8e18472750b25e73de7b2ea77c39c917;hp=b77ff521de14411a46a133b6e0fcf00ac35f006c;hb=20f03d52cc6c930f610c0b4466eeeeda54fdbb40;hpb=e50b6ec8d63afe4c04ae33384758d8786fcc7cfe diff --git a/FS/FS/svc_cert.pm b/FS/FS/svc_cert.pm index b77ff521d..88e4199e8 100644 --- a/FS/FS/svc_cert.pm +++ b/FS/FS/svc_cert.pm @@ -303,9 +303,30 @@ sub generate_csr { $self->csr($csr); } -#sub check_csr { -# my $self = shift; -#} +sub check_csr { + my $self = shift; + + my $in = $self->csr; + + run( [qw( openssl req -subject -noout ), ], + '<'=>\$in, + '>pipe'=>\*OUT, '2>'=>'/dev/null' + ) + ;#or die "error running openssl: $!"; + + #subject=/CN=cn.example.com/ST=AK/O=Tofuy/OU=Soybean dept./C=US/L=Tofutown + my $line = ; + $line =~ /^subject=\/(.*)$/ or return (); + my $subj = $1; + + map { if ( /^\s*(\w+)=\s*(.*)\s*$/ ) { + ($1=>$2); + } else { + (); + } + } + split('/', $subj); +} sub generate_selfsigned { my $self = shift; @@ -324,8 +345,8 @@ sub generate_selfsigned { ) or die "error running openssl: $!"; #XXX error checking - my $csr = join('', ); - $self->certificate($csr); + my $certificate = join('', ); + $self->certificate($certificate); } #openssl x509 -in cert -noout -subject -issuer -dates -serial @@ -360,7 +381,7 @@ sub check_x509 { $hash{$f} = { map { if ( /^\s*(\w+)=\s*(.*)\s*$/ ) { ($1=>$2); } else { - (''=>''); + (); } } split('/', $hash{$f})