349c4f26ce34c491991ffb6a023f052afa09ebd0
[freeside.git] / bin / svc_acct_sm.import
1 #!/usr/bin/perl -Tw
2 #
3 # $Id: svc_acct_sm.import,v 1.7 2000-06-29 10:51:52 ivan Exp $
4 #
5 # ivan@sisd.com 98-mar-9
6 #
7 # generalized svcparts ivan@sisd.com 98-mar-23
8
9 # You really need to enable ssh into a shell machine as this needs to rename
10 # .qmail-extension files.
11 #
12 # now an interactive script ivan@sisd.com 98-jun-30
13 #
14 # has an (untested) section for sendmail, s/warn/die/g and generates a program
15 # to run on your mail machine _later_ instead of ssh'ing for each user
16 # ivan@sisd.com 98-jul-13
17 #
18 # $Log: svc_acct_sm.import,v $
19 # Revision 1.7  2000-06-29 10:51:52  ivan
20 # oops, silly mistake
21 #
22 # Revision 1.6  2000/06/29 10:48:25  ivan
23 # make svc_acct_sm skip blank lines in sendmail import
24 #
25 # Revision 1.5  2000/02/03 05:16:52  ivan
26 # beginning of DNS and Apache support
27 #
28 # Revision 1.4  1999/03/25 08:42:20  ivan
29 # import stuff uses Term::Query and spits out (some kinds of) nonsensical input
30 #
31 # Revision 1.3  1999/03/24 00:51:55  ivan
32 # die if no relevant services... cvspain
33 #
34 # Revision 1.2  1998/12/10 07:23:18  ivan
35 # use FS::Conf, need user (for datasrc)
36 #
37
38 use strict;
39 use vars qw(%d_part_svc %m_part_svc);
40 use Term::Query qw(query);
41 use FS::SSH qw(iscp);
42 use FS::UID qw(adminsuidsetup datasrc);
43 use FS::Record qw(qsearch qsearchs);
44 use FS::svc_acct_sm;
45 use FS::svc_domain;
46 use FS::svc_acct;
47 use FS::part_svc;
48
49 my $user = shift or die &usage;
50 adminsuidsetup $user;
51
52 my($spooldir)="/usr/local/etc/freeside/export.". datasrc;
53
54 my(%mta) = (
55   1 => "qmail",
56   2 => "sendmail",
57 );
58
59 ###
60
61 %d_part_svc =
62   map { $_->svcpart, $_ } qsearch('part_svc',{'svcdb'=>'svc_domain'});
63 %m_part_svc =
64   map { $_->svcpart, $_ } qsearch('part_svc',{'svcdb'=>'svc_acct_sm'});
65
66 die "No services with svcdb svc_domain!\n" unless %d_part_svc;
67 die "No services with svcdb svc_svc_acct_sm!\n" unless %m_part_svc;
68
69 print "\n\n", 
70       ( join "\n", map "$_: ".$d_part_svc{$_}->svc, sort keys %d_part_svc ),
71       "\n\n";
72 $^W=0; #Term::Query isn't -w-safe
73 my $domain_svcpart = 
74   query "Enter part number for domains: ", 'irk', [ keys %d_part_svc ];
75 $^W=1;
76
77 print "\n\n", 
78       ( join "\n", map "$_: ".$m_part_svc{$_}->svc, sort keys %m_part_svc ),
79       "\n\n";
80 $^W=0; #Term::Query isn't -w-safe
81 my $mailalias_svcpart = 
82   query "Enter part number for mail aliases: ", 'irk', [ keys %m_part_svc ];
83 $^W=1;
84
85 print "\n\n", <<END;
86 Select your MTA from the following list.
87 END
88 print join "\n", map "$_: $mta{$_}", sort keys %mta;
89 print "\n\n";
90 $^W=0; #Term::Query isn't -w-safe
91 my $mta = query ":", 'irk', [ keys %mta ];
92 $^W=1;
93
94 if ( $mta{$mta} eq "qmail" ) {
95
96   print "\n\n", <<END;
97 Enter the location and name of your qmail control directory, for example
98 "mail.isp.com:/var/qmail/control"
99 END
100   my($control)=&getvalue(":");
101   iscp("root\@$control/rcpthosts","$spooldir/rcpthosts.import");
102 #  iscp("root\@$control/recipientmap","$spooldir/recipientmap.import");
103   iscp("root\@$control/virtualdomains","$spooldir/virtualdomains.import");
104
105 #  print "\n\n", <<END;
106 #Enter the name of the machine with your user .qmail files, for example
107 #"mail.isp.com"
108 #END
109 #  print ":";
110 #  my($shellmachine)=&getvalue;
111
112 } elsif ( $mta{$mta} eq "sendmail" ) {
113
114   print "\n\n", <<END;
115 Enter the location and name of your sendmail virtual user table, for example
116 "mail.isp.com:/etc/virtusertable"
117 END
118   my($virtusertable)=&getvalue(":");
119   iscp("root\@$virtusertable","$spooldir/virtusertable.import");
120
121   print "\n\n", <<END;
122 Enter the location and name of your sendmail.cw file, for example
123 "mail.isp.com:/etc/sendmail.cw"
124 END
125   my($sendmail_cw)=&getvalue(":");
126   iscp("root\@$sendmail_cw","$spooldir/sendmail.cw.import");
127
128 } else {
129   die "Unknown MTA!\n";
130 }
131
132 sub getvalue {
133   my $prompt = shift;
134   $^W=0; #Term::Query isn't -w-safe
135   my $data = query $prompt, '';
136   $^W=1;
137   $data;
138 }
139
140 print "\n\n";
141
142 ###
143
144 $FS::svc_domain::whois_hack=1;
145 $FS::svc_acct_sm::nossh_hack=1;
146
147 if ( $mta{$mta} eq "qmail" ) {
148   open(RCPTHOSTS,"<$spooldir/rcpthosts.import")
149     or die "Can't open $spooldir/rcpthosts.import: $!";
150 } elsif ( $mta{$mta} eq "sendmail" ) {
151   open(RCPTHOSTS,"<$spooldir/sendmail.cw.import")
152     or die "Can't open $spooldir/sendmail.cw.import: $!";
153 } else {
154   die "Unknown MTA!\n";
155 }
156
157 my(%svcnum);
158
159 while (<RCPTHOSTS>) {
160   next if /^(#|$)/;
161   next if $mta{$mta} eq 'sendmail' && /^\s*$/; #blank lines
162   /^\.?([\w\-\.]+)$/
163     #or do { warn "Strange rcpthosts/sendmail.cw line: $_"; next; };
164     or die "Strange rcpthosts/sendmail.cw line: $_";
165   my $domain = $1;
166   my($svc_domain);
167   unless ( $svc_domain = qsearchs('svc_domain', {'domain'=>$domain} ) ) {
168     $svc_domain = new FS::svc_domain ({
169       'domain'  => $domain,
170       'svcpart' => $domain_svcpart,
171       'action'  => 'N',
172     });
173     my $error = $svc_domain->insert;
174     #warn $error if $error;
175     die $error if $error;
176   }
177   $svcnum{$domain}=$svc_domain->svcnum;
178 }
179 close RCPTHOSTS; 
180
181 #these two loops have enough similar parts they should probably be merged
182 if ( $mta{$mta} eq "qmail" ) {
183
184   open(VD_FIX,">$spooldir/virtualdomains.FIX");
185   print VD_FIX "#!/usr/bin/perl\n";
186
187   open(VIRTUALDOMAINS,"<$spooldir/virtualdomains.import")
188     or die "Can't open $spooldir/virtualdomains.import: $!";
189   while (<VIRTUALDOMAINS>) {
190     next if /^#/;
191     /^\.?([\w\-\.]+):(\w+)(\-([\w\-\.]+))?$/
192       #or do { warn "Strange virtualdomains line: $_"; next; };
193       or die "Strange virtualdomains line: $_";
194     my($domain,$username,$dash_ext,$extension)=($1,$2,$3,$4);
195     $dash_ext ||= '';
196     $extension ||= '';
197     my($svc_acct)=qsearchs('svc_acct',{'username'=>$username});
198     unless ( $svc_acct ) {
199       #warn "Unknown user $username in virtualdomains; skipping\n";
200       #die "Unknown user $username in virtualdomains; skipping\n";
201       next;
202     }
203     if ( $domain ne $extension ) {
204       #warn "virtualdomains line $domain:$username$dash_ext changed to $domain:$username-$domain\n";
205       my($dir)=$svc_acct->dir;
206       my($qdomain)=$domain;
207       $qdomain =~ s/\./:/g; #see manpage for 'dot-qmail': EXTENSION ADDRESSES
208       #example to move .qmail files for virtual domains to their new location 
209       #dry run
210       #issh("root\@$shellmachine",'perl -e \'foreach $a (<'. $dir. '/.qmail'. $dash_ext. '-*>) { $old=$a; $a =~ s/\\.qmail'. $dash_ext. '\\-/\\.qmail\\-'. $qdomain. '\\-/; print " $old -> $a\n"; }\'');
211       #the real thing
212       #issh("root\@$shellmachine",'perl -e \'foreach $a (<'. $dir. '/.qmail'. $dash_ext. '-*>) { $old=$a; $a =~ s/\\.qmail'. $dash_ext. '\\-/\\.qmail\\-'. $qdomain. '\\-/; rename $old, $a; }\'');
213       print VD_FIX <<END;
214 foreach \$file (<$dir/.qmail$dash_ext-*>) {
215   \$old = \$file;
216   \$file =~ s/\.qmail$dash_ext\-/\.qmail\-$qdomain\-/;
217   rename \$old, \$file;
218 }
219 END
220     }
221
222     unless ( exists $svcnum{$domain} ) {
223       my($svc_domain) = new FS::svc_domain ({
224         'domain'  => $domain,
225         'svcpart' => $domain_svcpart,
226         'action'  => 'N',
227       });
228       my $error = $svc_domain->insert;
229       #warn $error if $error;
230       die $error if $error;
231       $svcnum{$domain}=$svc_domain->svcnum;
232     }
233
234     my($svc_acct_sm)=new FS::svc_acct_sm ({
235       'domsvc'  => $svcnum{$domain},
236       'domuid'  => $svc_acct->uid,
237       'domuser' => '*',
238       'svcpart' => $mailalias_svcpart,
239     });
240     my($error)='';
241     $error=$svc_acct_sm->insert;
242     #warn $error if $error;
243     die $error, ", domain $domain" if $error;
244   }
245   close VIRTUALDOMAINS;
246   close VD_FIX;
247
248 } elsif ( $mta{$mta} eq "sendmail" ) {
249
250   open(VIRTUSERTABLE,"<$spooldir/virtusertable.import")
251     or die "Can't open $spooldir/virtusertable.import: $!";
252   while (<VIRTUSERTABLE>) {
253     next if /^#/; #comments?
254     next if /^\s*$/; #blank lines
255     /^([\w\-\.]+)?\@([\w\-\.]+)\t([\w\-\.]+)$/
256       #or do { warn "Strange virtusertable line: $_"; next; };
257       or die "Strange virtusertable line: $_";
258     my($domuser,$domain,$username)=($1,$2,$3);
259     my($svc_acct)=qsearchs('svc_acct',{'username'=>$username});
260     unless ( $svc_acct ) {
261       #warn "Unknown user $username in virtusertable";
262       die "Unknown user $username in virtusertable";
263       next;
264     }
265     my($svc_acct_sm)=new FS::svc_acct_sm ({
266       'domsvc'  => $svcnum{$domain},
267       'domuid'  => $svc_acct->uid,
268       'domuser' => $domuser || '*',
269       'svcpart' => $mailalias_svcpart,
270     });
271     my($error)='';
272     $error=$svc_acct_sm->insert;
273     #warn $error if $error;
274     die $error if $error;
275   }
276   close VIRTUSERTABLE;
277
278 } else {
279   die "Unknown MTA!\n";
280 }
281
282 #open(RECIPIENTMAP,"<$spooldir/recipientmap.import");
283 #close RECIPIENTMAP;
284
285 print "\n\n", <<END if $mta{$mta} eq "qmail";
286 Don\'t forget to run $spooldir/virtualdomains.FIX before using
287 $spooldir/virtualdomains !
288 END
289
290 #
291
292 sub usage {
293   die "Usage:\n\n  svc_acct_sm.import user\n";
294 }
295