15767c15157c236e00bf98b860c2c831036b6693
[freeside.git] / fs_signup / FS-SignupClient / cgi / signup.cgi
1 #!/usr/bin/perl -Tw
2 #
3 # $Id: signup.cgi,v 1.2 1999-12-17 12:03:03 ivan Exp $
4
5 use strict;
6 use vars qw( @payby $cgi $locales $packages $pops $r $error
7              $last $first $ss $company $address1 $address2 $city $state $county
8              $country $zip $daytime $night $fax $invoicing_list $payby $payinfo
9              $paydate $payname $pkgpart $username $password $popnum
10              $ieak_docroot $ieak_baseurl );
11 use subs qw( print_form print_okay expselect );
12
13 use CGI;
14 use CGI::Carp qw(fatalsToBrowser);
15 use HTTP::Headers::UserAgent 2.00;
16 use FS::SignupClient qw( signup_info new_customer );
17
18 #acceptable payment methods
19 #
20 #@payby = qw( CARD BILL COMP );
21 #@payby = qw( CARD BILL );
22 @payby = qw( CARD );
23
24 #to enable ieak signups, you need to specify a directory in the web server's
25 #document space and the equivalent base URL
26 #
27 $ieak_docroot = "/var/www/sisd.420.am/freeside/ieak";
28 $ieak_baseurl = "http://sisd.420.am/freeside/ieak";
29
30 #srand (time ^ $$ ^ unpack "%L*", `ps axww | gzip`);
31
32 ( $locales, $packages, $pops ) = signup_info();
33
34 $cgi = new CGI;
35
36 if ( defined $cgi->param('magic') ) {
37   if ( $cgi->param('magic') eq 'process' ) {
38
39     $cgi->param('state') =~ /^(\w*)( \(([\w ]+)\))? ?\/ ?(\w+)$/
40       or die "Oops, illegal \"state\" param: ". $cgi->param('state');
41     $state = $1;
42     $county = $3 || '';
43     $country = $4;
44
45     $payby = $cgi->param('payby');
46     $payinfo = $cgi->param( $payby. '_payinfo' );
47     $paydate =
48       $cgi->param( $payby. '_month' ). '-'. $cgi->param( $payby. '_year' );
49     $payname = $cgi->param( $payby. '_payname' );
50
51     if ( $invoicing_list = $cgi->param('invoicing_list') ) {
52       $invoicing_list .= ', POST' if $cgi->param('invoicing_list_POST');
53     } else {
54       $invoicing_list = 'POST';
55     }
56
57     ( $error = new_customer ( {
58       'last'           => $last            = $cgi->param('last'),
59       'first'          => $first           = $cgi->param('first'),
60       'ss'             => $ss              = $cgi->param('ss'),
61       'company'        => $company         = $cgi->param('company'),
62       'address1'       => $address1        = $cgi->param('address1'),
63       'address2'       => $address2        = $cgi->param('address2'),
64       'city'           => $city            = $cgi->param('city'),
65       'county'         => $county,
66       'state'          => $state,
67       'zip'            => $zip             = $cgi->param('zip'),
68       'country'        => $country,
69       'daytime'        => $daytime         = $cgi->param('daytime'),
70       'night'          => $night           = $cgi->param('night'),
71       'fax'            => $fax             = $cgi->param('fax'),
72       'payby'          => $payby,
73       'payinfo'        => $payinfo,
74       'paydate'        => $paydate,
75       'payname'        => $payname,
76       'invoicing_list' => $invoicing_list,
77       'pkgpart'        => $pkgpart         = $cgi->param('pkgpart'),
78       'username'       => $username        = $cgi->param('username'),
79       '_password'      => $password        = $cgi->param('_password'),
80       'popnum'         => $popnum          = $cgi->param('popnum'),
81     } ) )
82       ? print_form()
83       : print_okay();
84   } else {
85     die "unrecognized magic: ". $cgi->param('magic');
86   }
87 } else {
88   $error = '';
89   $last = '';
90   $first = '';
91   $ss = '';
92   $company = '';
93   $address1 = '';
94   $address2 = '';
95   $city = '';
96   $state = '';
97   $county = '';
98   $country = '';
99   $zip = '';
100   $daytime = '';
101   $night = '';
102   $fax = '';
103   $invoicing_list = '';
104   $payby = '';
105   $payinfo = '';
106   $paydate = '';
107   $payname = '';
108   $pkgpart = '';
109   $username = '';
110   $password = '';
111   $popnum = '';
112
113   print_form;
114 }
115
116 sub print_form {
117
118   my $r = qq!<font color="#ff0000">*</font>!;
119   my $self_url = $cgi->self_url;
120
121   print $cgi->header( '-expires' => 'now' ), <<END;
122 <HTML><HEAD><TITLE>ISP Signup form</TITLE></HEAD>
123 <BODY BGCOLOR="#e8e8e8"><FONT SIZE=7>ISP Signup form</FONT><BR><BR>
124 END
125
126   print qq!<FONT SIZE="+1" COLOR="#ff0000">Error: $error</FONT>! if $error;
127
128   print <<END;
129 <FORM ACTION="$self_url" METHOD=POST>
130 <INPUT TYPE="hidden" NAME="magic" VALUE="process">
131 Contact Information
132 <TABLE BGCOLOR="#c0c0c0" BORDER=0 CELLSPACING=0 WIDTH="100%">
133 <TR>
134   <TH ALIGN="right">${r}Contact name<BR>(last, first)</TH>
135   <TD COLSPAN=3><INPUT TYPE="text" NAME="last" VALUE="$last">,
136                 <INPUT TYPE="text" NAME="first" VALUE="$first"></TD>
137   <TD ALIGN="right">SS#</TD>
138   <TD><INPUT TYPE="text" NAME="ss" SIZE=11 VALUE="$ss"></TD>
139 </TR>
140 <TR>
141   <TD ALIGN="right">Company</TD>
142   <TD COLSPAN=5><INPUT TYPE="text" NAME="company" SIZE=70 VALUE="$company"></TD>
143 </TR>
144 <TR>
145   <TH ALIGN="right">${r}Address</TH>
146   <TD COLSPAN=5><INPUT TYPE="text" NAME="address1" SIZE=70 VALUE="$address1"></TD>
147 </TR>
148 <TR>
149   <TD ALIGN="right">&nbsp;</TD>
150   <TD COLSPAN=5><INPUT TYPE="text" NAME="address2" SIZE=70 VALUE="$address2"></TD>
151 </TR>
152 <TR>
153   <TH ALIGN="right">${r}City</TH>
154   <TD><INPUT TYPE="text" NAME="city" VALUE="$city"></TD>
155   <TH ALIGN="right">${r}State/Country</TH>
156   <TD><SELECT NAME="state" SIZE="1">
157 END
158
159   foreach ( @{$locales} ) {
160     print "<OPTION";
161     print " SELECTED" if ( $state eq $_->{'state'}
162                            && $county eq $_->{'county'}
163                            && $country eq $_->{'country'}
164                          );
165     print ">", $_->{'state'};
166     print " (",$_->{'county'},")" if $_->{'county'};
167     print " / ", $_->{'country'};
168   }
169
170   print <<END;
171   </SELECT></TD>
172   <TH>${r}Zip</TH>
173   <TD><INPUT TYPE="text" NAME="zip" SIZE=10 VALUE="$zip"></TD>
174 </TR>
175 <TR>
176   <TD ALIGN="right">Day Phone</TD>
177   <TD COLSPAN=5><INPUT TYPE="text" NAME="daytime" VALUE="$daytime" SIZE=18></TD>
178 </TR>
179 <TR>
180   <TD ALIGN="right">Night Phone</TD>
181   <TD COLSPAN=5><INPUT TYPE="text" NAME="night" VALUE="$night" SIZE=18></TD>
182 </TR>
183 <TR>
184   <TD ALIGN="right">Fax</TD>
185   <TD COLSPAN=5><INPUT TYPE="text" NAME="fax" VALUE="$fax" SIZE=12></TD>
186 </TR>
187 </TABLE>$r required fields<BR>
188 <BR>Billing information<TABLE BGCOLOR="#c0c0c0" BORDER=0 CELLSPACING=0 WIDTH="100%">
189 <TR><TD>
190 END
191
192   print qq!<INPUT TYPE="checkbox" NAME="invoicing_list_POST" VALUE="POST"!;
193   my @invoicing_list = split(', ', $invoicing_list );
194   print ' CHECKED'
195     if ! @invoicing_list || grep { $_ eq 'POST' } @invoicing_list;
196   print '>Postal mail invoice</TD></TR><TR><TD>Email invoice ',
197          qq!<INPUT TYPE="text" NAME="invoicing_list" VALUE="!,
198          join(', ', grep { $_ ne 'POST' } @invoicing_list ),
199          qq!"></TD></TR>!;
200
201   print <<END;
202 <TR><TD>Billing type</TD></TR></TABLE>
203 <TABLE BGCOLOR="#c0c0c0" BORDER=1 WIDTH="100%">
204 <TR>
205 END
206
207   my %payby = (
208     'CARD' => qq!Credit card<BR>${r}<INPUT TYPE="text" NAME="CARD_payinfo" VALUE="" MAXLENGTH=19><BR>${r}Exp !. expselect("CARD"). qq!<BR>${r}Name on card<BR><INPUT TYPE="text" NAME="CARD_payname" VALUE="">!,
209     'BILL' => qq!Billing<BR>P.O. <INPUT TYPE="text" NAME="BILL_payinfo" VALUE=""><BR>${r}Exp !. expselect("BILL", "12-2037"). qq!<BR>${r}Attention<BR><INPUT TYPE="text" NAME="BILL_payname" VALUE="Accounts Payable">!,
210     'COMP' => qq!Complimentary<BR>${r}Approved by<INPUT TYPE="text" NAME="COMP_payinfo" VALUE=""><BR>${r}Exp !. expselect("COMP"),
211   );
212
213   my %paybychecked = (
214     'CARD' => qq!Credit card<BR>${r}<INPUT TYPE="text" NAME="CARD_payinfo" VALUE="$payinfo" MAXLENGTH=19><BR>${r}Exp !. expselect("CARD", $paydate). qq!<BR>${r}Name on card<BR><INPUT TYPE="text" NAME="CARD_payname" VALUE="$payname">!,
215     'BILL' => qq!Billing<BR>P.O. <INPUT TYPE="text" NAME="BILL_payinfo" VALUE="$payinfo"><BR>${r}Exp !. expselect("BILL", $paydate). qq!<BR>${r}Attention<BR><INPUT TYPE="text" NAME="BILL_payname" VALUE="$payname">!,
216     'COMP' => qq!Complimentary<BR>${r}Approved by<INPUT TYPE="text" NAME="COMP_payinfo" VALUE="$payinfo"><BR>${r}Exp !. expselect("COMP", $paydate),
217   );
218
219   for (@payby) {
220     print qq!<TD VALIGN=TOP><INPUT TYPE="radio" NAME="payby" VALUE="$_"!;
221     if ($payby eq $_) {
222       print qq! CHECKED> $paybychecked{$_}</TD>!;
223     } else {
224       print qq!> $payby{$_}</TD>!;
225     }
226   }
227
228   print <<END;
229 </TR></TABLE>$r required fields for each billing type
230 <BR><BR>First package
231 <TABLE BGCOLOR="#c0c0c0" BORDER=0 CELLSPACING=0 WIDTH="100%">
232 <TR>
233   <TD COLSPAN=2><SELECT NAME="pkgpart"><OPTION VALUE="">(none)
234 END
235
236   foreach my $package ( @{$packages} ) {
237     print qq!<OPTION VALUE="!, $package->{'pkgpart'}, '"';
238     print " SELECTED" if $pkgpart && ( $package->{'pkgpart'} == $pkgpart );
239     print ">", $package->{'pkg'};
240   }
241
242   print <<END;
243   </SELECT></TD>
244 </TR>
245 <TR>
246   <TD ALIGN="right">Username</TD>
247   <TD><INPUT TYPE="text" NAME="username" VALUE="$username"></TD>
248 </TR>
249 <TR>
250   <TD ALIGN="right">Password</TD>
251   <TD><INPUT TYPE="text" NAME="_password" VALUE="$password">
252   (blank to generate)</TD>
253 </TR>
254 <TR>
255   <TD ALIGN="right">POP</TD>
256   <TD><SELECT NAME="popnum" SIZE=1><OPTION> 
257 END
258
259   foreach my $pop ( @{$pops} ) {
260     print qq!<OPTION VALUE="!, $pop->{'popnum'}, '"',
261           ( $popnum && $pop->{'popnum'} == $popnum ) ? ' SELECTED' : '', ">", 
262           $pop->{'popnum'}, ": ", 
263           $pop->{'city'}, ", ",
264           $pop->{'state'},
265           " (", $pop->{'ac'}, ")/",
266           $pop->{'exch'}, "\n"
267         ;
268   }
269   print <<END;
270   </SELECT></TD>
271 </TR>
272 </TABLE>
273 <BR><BR><INPUT TYPE="submit" VALUE="Signup">
274 </FORM></BODY></HTML>
275 END
276
277 }
278
279 sub print_okay {
280   $user_agent = new HTTP::Headers::UserAgnet $ENV{HTTP_USER_AGENT};
281   if (    defined($ieak_docroot)
282        && defined($ieak_baseurl)
283        && defined($ieak_secret)
284        && $user_agent->platform eq 'ia32'
285        && $user_agent->os =~ /^win/
286        && ($user-agent->browser)[0] eq 'IE'
287      )
288   { #send an IEAK config
289     my $username = $cgi->param('username');
290     my $password = $cgi->param('_password');
291     my $email_name = $cgi->param('first'). ' '. $cgi->param('last');
292     my $ins_file = rand(4294967296). ".ins";
293     open(INS_FILE, ">$ieak_docroot/$ins_file");
294     print INS_FILE <<END;
295 [Entry]\r
296 Entry_Name = Netloud\r
297 [Phone]\r
298 Dial_As_Is=no\r
299 Phone_Number = 5551212\r
300 Area_Code = 415\r
301 Country_Code = 1\r
302 Country_Id = 1\r
303 [Server]\r
304 Type = PPP\r
305 SW_Compress = Yes\r
306 PW_Encrypt = Yes\r
307 Negotiate_TCP/IP = Yes\r
308 Disable_LCP = No\r
309 [TCP/IP]\r
310 Specify_IP_Address = No\r
311 Specity_Server_Address = No\r
312 IP_Header_Compress = Yes\r
313 Gateway_On_Remote = Yes\r
314 [User]\r
315 Name = $username\r
316 Password = $password\r
317 Display_Password = Yes\r
318 [Internet_Mail]\r
319 Email_Name = $email_name\r
320 Email_Address = $username\@netloud.com\r
321 POP_Server = mail.netloud.com\r
322 POP_Server_Port_Number = 110\r
323 POP_Login_Name = $username\r
324 POP_Login_Password = $password\r
325 SMTP_Server = mail.netloud.com\r
326 SMTP_Server_Port_Number = 25\r
327 Install_Mail = 1\r
328 [Internet_News]\r
329 NNTP_Server = news.netloud.com\r
330 NNTP_Server_Port_Number = 119\r
331 Logon_Required = No\r
332 Install_News = 1\r
333 [Branding]\r
334 Window_Title = Internet Explorer From Netloud.com\r
335 END
336     close INS_FILE;
337
338     print $cgi->redirect("$ieak_docroot/$ins_file");
339
340   } else { #send a simple confirmation
341     print $cgi->header( '-expires' => 'now' ), <<END;
342 <HTML><HEAD><TITLE>Signup successful</TITLE></HEAD>
343 <BODY BGCOLOR="#e8e8e8"><FONT SIZE=7>Signup successful</FONT><BR><BR>
344 blah blah blah
345 </BODY>
346 </HTML>
347 END
348   }
349 }
350
351 sub expselect {
352   my $prefix = shift;
353   my $date = shift || '';
354   my( $m, $y ) = ( 0, 0 );
355   if ( $date  =~ /^(\d{4})-(\d{2})-\d{2}$/ ) { #PostgreSQL date format
356     ( $m, $y ) = ( $2, $1 );
357   } elsif ( $date =~ /^(\d{1,2})-(\d{1,2}-)?(\d{4}$)/ ) {
358     ( $m, $y ) = ( $1, $3 );
359   }
360   my $return = qq!<SELECT NAME="$prefix!. qq!_month" SIZE="1">!;
361   for ( 1 .. 12 ) {
362     $return .= "<OPTION";
363     $return .= " SELECTED" if $_ == $m;
364     $return .= ">$_";
365   }
366   $return .= qq!</SELECT>/<SELECT NAME="$prefix!. qq!_year" SIZE="1">!;
367   for ( 1999 .. 2037 ) {
368     $return .= "<OPTION";
369     $return .= " SELECTED" if $_ == $y;
370     $return .= ">$_";
371   }
372   $return .= "</SELECT>";
373
374   $return;
375 }
376