rework edit/part_svc.cgi so it doesn't use a separate process/ file, this allows...
[freeside.git] / bin / passwd.import
1 #!/usr/bin/perl -Tw
2 # $Id: passwd.import,v 1.8 2003-06-12 14:08:00 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{$username}=$password;
80 }
81
82 while (<PASSWD>) {
83   chop;
84   my($username,$x,$uid,$gid,$finger,$dir,$shell) = split(/:/);
85   my $password = $password{$username};
86
87   my $svcpart = $shell_svcpart;
88
89   #if ( qsearchs('svc_acct', { 'username' => $username } ) ) {
90   #  warn "warning: $username already exists; skipping\n";
91   #  next;
92   #}
93
94   my($svc_acct) = new FS::svc_acct ({
95     'svcpart'   => $svcpart,
96     'username'  => $username,
97     '_password' => $password,
98     'uid'       => $uid,
99     'gid'       => $gid,
100     'finger'    => $finger,
101     'dir'       => $dir,
102     'shell'     => $shell,
103     #%{$allparam{$username}},
104   });
105   my($error);
106   $error=$svc_acct->insert;
107   if ( $error ) {
108     if ( $error =~ /duplicate/i ) {
109       warn "$username: $error";
110     } else {
111       die "$username: $error";
112     }
113   }
114
115 }
116
117 sub usage {
118   die "Usage:\n\n  passwd.import user\n";
119 }
120