*** empty log message ***
[freeside.git] / bin / passwd.import
1 #!/usr/bin/perl -Tw
2 # $Id: passwd.import,v 1.1 2002-04-20 11:57:35 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);
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/shuddown /bin/halt); #others?
18
19 my($spooldir)="/usr/local/etc/freeside/export.". datasrc;
20
21 #$FS::svc_acct::nossh_hack = 1;
22 $FS::svc_acct::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)=$upassword{$username} || $password{$username};
86
87   $svcpart = $shell_svcpart;
88
89   my($svc_acct) = new FS::svc_acct ({
90     'svcpart'   => $svcpart,
91     'username'  => $username,
92     '_password' => $password,
93     'uid'       => $uid,
94     'gid'       => $gid,
95     'finger'    => $finger,
96     'dir'       => $dir,
97     'shell'     => $shell,
98     %{$allparam{$username}},
99   });
100   my($error);
101   $error=$svc_acct->insert;
102   die $error if $error;
103
104   delete $upassword{$username};
105 }
106
107 sub usage {
108   die "Usage:\n\n  passwd.import user\n";
109 }
110