openldap/contrib/slapd-modules/passwd/apr1-ltoa.pl
Devin J. Pohly fb5b3a0df2 ITS#6826 conversion scripts
These were provided as part of the original ITS but not previously committed.
Perl scripts to convert between Apache and OpenLDAP hash formats.
2016-04-11 13:35:39 +01:00

31 lines
836 B
Perl

#!/usr/bin/perl -w
# OpenLDAP {APR1} to Apache $apr1$ hash converter
# (C) 2011 Devin J. Pohly
# You may use this code freely. It would be nice to be credited.
use MIME::Base64;
while (<>) {
($user, $hash) = split(/:/, $_);
unless ($hash =~ /^{APR1}/) {
print STDERR "Not an Apache MD5 hash\n";
next;
}
chomp $hash;
$hash = decode_base64(substr($hash, 6));
($hash, $salt) = (substr($hash, 0, 16), substr($hash, 16));
$hash = $hash;
$hash =~ s/(.)(.)(.)(.)(.)(.)(.)(.)(.)(.)(.)(.)(.)(.)(.)(.)/$1$7$13$2$8$14$3$9$15$4$10$16$5$11$6\0\0$12/s;
$hash = encode_base64($hash);
chomp $hash;
$hash =~ s/(.)(.)(.)(.)/$4$3$2$1/gs;
unless ($hash =~ /AA$/) {
#print "Problem with hash\n";
next;
}
$hash =~ s/AA$//;
$hash =~ tr|A-Za-z0-9+/|./0-9A-Za-z|;
print "$user:\$apr1\$$salt\$$hash\n"
}