From 577703495e2ed11c4470f2636fae0c84f0c03bbd Mon Sep 17 00:00:00 2001 From: Guenter Knauf Date: Wed, 10 Apr 2013 00:20:37 +0200 Subject: Fixed lost OpenSSL output with "-t" - followup. The previously applied patch didnt work on Windows; we cant rely on shell commands like 'echo' since they act diffently on each platform and each shell. In order to keep this script platform-independent the code must only use pure Perl. --- lib/mk-ca-bundle.pl | 19 +++++++++++++------ 1 file changed, 13 insertions(+), 6 deletions(-) (limited to 'lib/mk-ca-bundle.pl') diff --git a/lib/mk-ca-bundle.pl b/lib/mk-ca-bundle.pl index 188c939cb..edede4261 100755 --- a/lib/mk-ca-bundle.pl +++ b/lib/mk-ca-bundle.pl @@ -124,7 +124,7 @@ print CRT <) { print CRT ("=" x length($caname) . "\n"); if (!$opt_t) { print CRT $pem; - } - if ($opt_t) { - my $openssl_output = `echo '$pem' | $openssl x509 -md5 -fingerprint -text -inform PEM` or - die "Couldn't run openssl : $?\n"; - print CRT $openssl_output; + } else { + my $pipe = "|$openssl x509 -md5 -fingerprint -text -inform PEM"; + if (!$stdout) { + $pipe .= " >> $crt.~"; + close(CRT) or die "Couldn't close $crt.~: $!"; + } + open(TMP, $pipe) or die "Couldn't open openssl pipe: $!"; + print TMP $pem; + close(TMP) or die "Couldn't close openssl pipe: $!"; + if (!$stdout) { + open(CRT, ">>$crt.~") or die "Couldn't open $crt.~: $!"; + } } print STDERR "Parsing: $caname\n" if ($opt_v); $certnum ++; -- cgit v1.2.3