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