import NP and *LK* from shadow file as * (no password)
[freeside.git] / bin / passwd.import
1 #!/usr/bin/perl -Tw
2 # $Id: passwd.import,v 1.9 2004-12-24 23:27:34 ivan Exp $
3
4 use strict;
5 use vars qw(%part_svc);
6 use Date::Parse;
7 use Term::Query qw(query);
8 use Net::SCP qw(iscp);
9 use FS::UID qw(adminsuidsetup datasrc);
10 use FS::Record qw(qsearch qsearchs);
11 use FS::svc_acct;
12 use FS::part_svc;
13
14 my $user = shift or die &usage;
15 adminsuidsetup $user;
16
17 push @FS::svc_acct::shells, qw(/bin/sync /sbin/shutdown /bin/halt /sbin/halt); #others?
18
19 my($spooldir)="/usr/local/etc/freeside/export.". datasrc;
20
21 #$FS::svc_acct::nossh_hack = 1;
22 $FS::svc_Common::noexport_hack = 1;
23
24 ###
25
26 %part_svc=map { $_->svcpart, $_ } qsearch('part_svc',{'svcdb'=>'svc_acct'});
27
28 die "No services with svcdb svc_acct!\n" unless %part_svc;
29
30 print "\n\n", &menu_svc, "\n", <<END;
31 Enter part number to import.
32 END
33 my($shell_svcpart)=&getpart;
34
35 print "\n\n", <<END;
36 Enter the location and name of your _user_ passwd file, for example
37 "mail.isp.com:/etc/passwd" or "nis.isp.com:/etc/global/passwd"
38 END
39 my($loc_passwd)=&getvalue(":");
40 iscp("root\@$loc_passwd", "$spooldir/passwd.import");
41
42 print "\n\n", <<END;
43 Enter the location and name of your _user_ shadow file, for example
44 "mail.isp.com:/etc/shadow" or "bsd.isp.com:/etc/master.passwd"
45 END
46 my($loc_shadow)=&getvalue(":");
47 iscp("root\@$loc_shadow", "$spooldir/shadow.import");
48
49 sub menu_svc {
50   ( join "\n", map "$_: ".$part_svc{$_}->svc, sort keys %part_svc ). "\n";
51 }
52 sub getpart {
53   $^W=0; # Term::Query isn't -w-safe
54   my $return = query "Enter part number:", 'irk', [ keys %part_svc ];
55   $^W=1;
56   $return;
57 }
58 sub getvalue {
59   my $prompt = shift;
60   $^W=0; # Term::Query isn't -w-safe
61   my $return = query $prompt, '';
62   $^W=1;
63   $return;
64 }
65
66 print "\n\n";
67
68 ###
69
70 open(PASSWD,"<$spooldir/passwd.import");
71 open(SHADOW,"<$spooldir/shadow.import");
72
73 my(%password);
74 while (<SHADOW>) {
75   chop;
76   my($username,$password)=split(/:/);
77   #$password =~ s/^\!$/\*/;
78   #$password =~ s/\!+/\*SUSPENDED\* /;
79   $password =~ s/^NP$/\*/;
80   $password =~ s/^\*LK\*$/\*/;
81   $password{$username}=$password;
82 }
83
84 while (<PASSWD>) {
85   chop;
86   my($username,$x,$uid,$gid,$finger,$dir,$shell) = split(/:/);
87   my $password = $password{$username};
88
89   my $svcpart = $shell_svcpart;
90
91   #if ( qsearchs('svc_acct', { 'username' => $username } ) ) {
92   #  warn "warning: $username already exists; skipping\n";
93   #  next;
94   #}
95
96   my($svc_acct) = new FS::svc_acct ({
97     'svcpart'   => $svcpart,
98     'username'  => $username,
99     '_password' => $password,
100     'uid'       => $uid,
101     'gid'       => $gid,
102     'finger'    => $finger,
103     'dir'       => $dir,
104     'shell'     => $shell,
105     #%{$allparam{$username}},
106   });
107   my($error);
108   $error=$svc_acct->insert;
109   if ( $error ) {
110     if ( $error =~ /duplicate/i ) {
111       warn "$username: $error";
112     } else {
113       die "$username: $error";
114     }
115   }
116
117 }
118
119 sub usage {
120   die "Usage:\n\n  passwd.import user\n";
121 }
122