3 # Convert /etc/passwd and /etc/shadow to userdb format.
5 # $Id: pw2userdb.in,v 1.5 2000/07/19 11:55:15 mrsam Exp $
7 # Copyright 1998 - 1999 Double Precision, Inc. See COPYING for
8 # distribution information.
13 # Some undocumented options here (for vchkpw2userdb)
16 die "Invalid options.\n" unless
17 GetOptions("passwd=s" => \$passwd, "shadow=s" => \$shadow,
18 "noshadow" => \$noshadow, "nouid" => \$nouid,
19 "domain=s" => \$domain, "vpopuid" => \$vpopuid );
21 ($dummy, $dummy, $fixed_uid, $fixed_gid)=getpwnam("vpopmail")
24 $passwd="/etc/passwd" unless $passwd =~ /./;
25 $shadow="/etc/shadow" unless $shadow =~ /./;
27 $domain="" unless $domain =~ /./;
28 $domain="\@$domain" if $domain =~ /./;
30 open(PASSWD, $passwd) || die "$!\n";
36 ($acct,$passwd,$uid,$gid,$name,$home,$shell)=split( /:/ );
38 ($uid,$gid)=($fixed_uid,$fixed_gid) if $vpopuid;
40 $PASSWORD{$acct}=$passwd if $passwd ne "x";
46 $name =~ s/\|/./g; # Just in case
51 if ( -f $shadow && ! $noshadow)
53 open (SHADOW, $shadow) || die "$!\n";
57 ($acct,$passwd,$dummy)=split(/:/);
58 $PASSWORD{$acct}=$passwd;
63 while ( defined ($key=each %UID))
65 print "$key$domain\tuid=$UID{$key}|gid=$GID{$key}|home=$HOME{$key}" .
66 ( $SHELL{$key} =~ /./ ? "|shell=$SHELL{$key}":"") .
67 ( $PASSWORD{$key} =~ /./ ? "|systempw=$PASSWORD{$key}":"") .
68 ( $GECOS{$key} =~ /./ ? "|gecos=$GECOS{$key}":"") .
70 print "$UID{$key}=\t$key\n" unless $nouid;