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