# $Id$ # # Test of XML::Simple as a tool for encoding and decoding # # http://mirin.apnic.net/resourcecerts/wiki/index.php/IR-ISP_Definition # CMS wrapper for this (not yet written) would look something like: # # openssl smime -sign -nodetach -outform DER -in foo.xml -out foo.cms \ # -signer foo.cer -inkey foo.key # # openssl smime -verify -CApath . -inform DER -in foo.cms -out foo.xml eval 'exec perl -w -S $0 ${1+"$@"}' if 0; use strict; use XML::Simple; use Data::Dumper; my @xml = ('
','
','
[Certificate request] ','
[certificate] ','
','
','
[Readable text] '); my $xs = XML::Simple->new(KeepRoot => 1, ForceArray => [qw(list_class)], KeyAttr => [qw(header)], NormalizeSpace => 2); for my $xml (@xml) { my $x = $xs->XMLin($xml); my $t = $xs->XMLout($x); print("\n###\n", $xml, "\n", Dumper($x), "\n", $t); } __END__ # Test of IPC::Open2 # CMS wrapper for this (not yet written) would look something like: # # openssl smime -sign -nodetach -outform DER -in foo.xml -out foo.cms \ # -signer foo.cer -inkey foo.key # # openssl smime -verify -CApath . -inform DER -in foo.cms -out foo.xml eval 'exec perl -w -S $0 ${1+"$@"}' if 0; use strict; use IPC::Open2; my $xml = '
'; sub run2 { my $arg = shift; my $i; my $o; my $pid = open2($o, $i, @_) or die("Couldn't run @_"); print($i $arg) or die("Couldn't write to @_"); close($i) or die("Couldn't close @_"); my @res = <$o>; waitpid($pid, 0) or die("Couldn't reap @_"); return @res; } my $p7b = "-----BEGIN PKCS7-----\n"; my $p7e = "-----END PKCS7-----\n"; my $dir = "apacheca"; my $cer = "$dir/ISP4-EE.cer"; my $key = "$dir/ISP4-EE.key"; sub encode { my $arg = shift; my @res = run2($arg, qw(openssl smime -sign -nodetach -outform PEM -signer), $cer, q(-inkey), $key); die("Missing PKCS7 markers") unless $res[0] eq $p7b && $res[@res-1] eq $p7e; return join('', @res[1..@res-2]); } sub decode { my $arg = shift; my @res = run2($p7b . $arg . $p7e, qw(openssl smime -verify -inform PEM -CApath), $dir); return join('', @res); } print("1:\n", $xml, "\n"); my $cms = encode($xml); print("2:\n", $cms, "\n"); print("3:\n", decode($cms), "\n");