3 # WARNING: This doesn't handle Rob's address-database-enhanced Patron XML format, with such things as Change of Address information
9 use Time::HiRes qw/time/;
14 my $doc = XML::LibXML->new->parse_file($ARGV[0]);
49 print STDOUT join("\t", @base_elements);
50 foreach my $addr ( 1..3 ) {
51 print STDOUT "\t" . join("\t", @addr_elements);
55 for my $patron ( $doc->documentElement->childNodes ) {
56 next if ($patron->nodeType == 3);
58 my $bc = $patron->findvalue( 'user_id' );
59 if (exists($s_map{$bc})) {
61 warn "\n!!! already saw barcode $bc, skipping\n";
67 unless (defined($bc)) {
68 my $xml = $patron->toString;
69 warn "\n!!! no barcode found in UMS data, user number $count, xml => $xml \n";
74 foreach my $e ( @base_elements ) {
75 my $v = $patron->findvalue( $e );
76 if ( $v && ( $e eq 'birthdate' || $e eq 'user_priv_granted' || $e eq 'user_priv_expires' ) ) { $v = parse_date($v); }
77 print STDOUT ( $v ? $v : '' ) . "\t";
82 for my $addr ( $patron->findnodes( "Address" ) ) {
83 my $addr_type = $addr->getAttribute('addr_type');
84 $addresses{$addr_type} = $addr;
87 foreach my $t ( 1..3 ) {
89 foreach my $e ( @addr_elements ) {
90 my $v = $addresses{$t}->findvalue( $e );
91 print STDOUT ( $v ? $v : '' ) . "\t";
94 foreach ( @addr_elements ) { print STDOUT "\t"; }
108 if ($string eq 'NEVER') {
109 my (undef,undef,undef,$d,$m,$y) = localtime();
110 return sprintf('%04d-%02d-%02d', $y + 1920, $m + 1, $d);
111 } elsif (length($string) == 8 && $string =~ /^(\d{4})(\d{2})(\d{2})$/o) {
112 ($y,$m,$d) = ($1,$2,$3);
113 } elsif ($string =~ /(\d+)\D(\d+)\D(\d+)/o) { #looks like it's parsable
114 if ( length($3) > 2 ) { # looks like mm.dd.yyyy
115 if ( $1 < 99 && $2 < 99 && $1 > 0 && $2 > 0 && $3 > 0) {
116 if ($1 > 12 && $1 < 31 && $2 < 13) { # well, actually it looks like dd.mm.yyyy
117 ($y,$m,$d) = ($3,$2,$1);
118 } elsif ($2 > 12 && $2 < 31 && $1 < 13) {
119 ($y,$m,$d) = ($3,$1,$2);
122 } elsif ( length($1) > 3 ) { # format probably yyyy.mm.dd
123 if ( $3 < 99 && $2 < 99 && $1 > 0 && $2 > 0 && $3 > 0) {
124 if ($2 > 12 && $2 < 32 && $3 < 13) { # well, actually it looks like yyyy.dd.mm -- why, I don't konw
125 ($y,$m,$d) = ($1,$3,$2);
126 } elsif ($3 > 12 && $3 < 31 && $2 < 13) {
127 ($y,$m,$d) = ($1,$2,$3);
130 } elsif ( $1 < 99 && $2 < 99 && $3 < 99 && $1 > 0 && $2 > 0 && $3 > 0) {
131 if ($3 < 7) { # probably 2000 or greater, mm.dd.yy
133 if ($1 > 12 && $1 < 32 && $2 < 13) { # well, actually it looks like dd.mm.yyyy
135 } elsif ($2 > 12 && $2 < 32 && $1 < 13) {
138 } else { # probably before 2000, mm.dd.yy
140 if ($1 > 12 && $1 < 32 && $2 < 13) { # well, actually it looks like dd.mm.yyyy
142 } elsif ($2 > 12 && $2 < 32 && $1 < 13) {
150 if ($y && $m && $d) {
152 $date = sprintf('%04d-%02d-%-2d',$y, $m, $d)
153 if (new DateTime ( year => $y, month => $m, day => $d ));