3 # $Id: signup.cgi,v 1.3 2000-01-28 22:49:49 ivan Exp $
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
12 #$ieak_docroot $ieak_baseurl
13 use subs qw( print_form print_okay expselect );
16 use CGI::Carp qw(fatalsToBrowser);
17 use HTTP::Headers::UserAgent 2.00;
18 use FS::SignupClient qw( signup_info new_customer );
21 #acceptable payment methods
23 #@payby = qw( CARD BILL COMP );
24 #@payby = qw( CARD BILL );
27 $ieak_file = '/usr/local/freeside/ieak.template';
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";
36 # #to enable ieak signups, you need to specify a directory in the web server's
37 # #document space and the equivalent base URL
39 # $ieak_docroot = "/var/www/sisd.420.am/freeside/ieak";
40 # $ieak_baseurl = "http://sisd.420.am/freeside/ieak";
42 #srand (time ^ $$ ^ unpack "%L*", `ps axww | gzip`);
44 ( $locales, $packages, $pops ) = signup_info();
48 if ( defined $cgi->param('magic') ) {
49 if ( $cgi->param('magic') eq 'process' ) {
51 $cgi->param('state') =~ /^(\w*)( \(([\w ]+)\))? ?\/ ?(\w+)$/
52 or die "Oops, illegal \"state\" param: ". $cgi->param('state');
57 $payby = $cgi->param('payby');
58 $payinfo = $cgi->param( $payby. '_payinfo' );
60 $cgi->param( $payby. '_month' ). '-'. $cgi->param( $payby. '_year' );
61 $payname = $cgi->param( $payby. '_payname' );
63 if ( $invoicing_list = $cgi->param('invoicing_list') ) {
64 $invoicing_list .= ', POST' if $cgi->param('invoicing_list_POST');
66 $invoicing_list = 'POST';
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'),
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'),
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'),
97 die "unrecognized magic: ". $cgi->param('magic');
115 $invoicing_list = '';
130 my $r = qq!<font color="#ff0000">*</font>!;
131 my $self_url = $cgi->self_url;
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>
138 print qq!<FONT SIZE="+1" COLOR="#ff0000">Error: $error</FONT>! if $error;
141 <FORM ACTION="$self_url" METHOD=POST>
142 <INPUT TYPE="hidden" NAME="magic" VALUE="process">
144 <TABLE BGCOLOR="#c0c0c0" BORDER=0 CELLSPACING=0 WIDTH="100%">
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>
153 <TD ALIGN="right">Company</TD>
154 <TD COLSPAN=5><INPUT TYPE="text" NAME="company" SIZE=70 VALUE="$company"></TD>
157 <TH ALIGN="right">${r}Address</TH>
158 <TD COLSPAN=5><INPUT TYPE="text" NAME="address1" SIZE=70 VALUE="$address1"></TD>
161 <TD ALIGN="right"> </TD>
162 <TD COLSPAN=5><INPUT TYPE="text" NAME="address2" SIZE=70 VALUE="$address2"></TD>
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">
171 foreach ( @{$locales} ) {
173 print " SELECTED" if ( $state eq $_->{'state'}
174 && $county eq $_->{'county'}
175 && $country eq $_->{'country'}
177 print ">", $_->{'state'};
178 print " (",$_->{'county'},")" if $_->{'county'};
179 print " / ", $_->{'country'};
185 <TD><INPUT TYPE="text" NAME="zip" SIZE=10 VALUE="$zip"></TD>
188 <TD ALIGN="right">Day Phone</TD>
189 <TD COLSPAN=5><INPUT TYPE="text" NAME="daytime" VALUE="$daytime" SIZE=18></TD>
192 <TD ALIGN="right">Night Phone</TD>
193 <TD COLSPAN=5><INPUT TYPE="text" NAME="night" VALUE="$night" SIZE=18></TD>
196 <TD ALIGN="right">Fax</TD>
197 <TD COLSPAN=5><INPUT TYPE="text" NAME="fax" VALUE="$fax" SIZE=12></TD>
199 </TABLE>$r required fields<BR>
200 <BR>Billing information<TABLE BGCOLOR="#c0c0c0" BORDER=0 CELLSPACING=0 WIDTH="100%">
204 print qq!<INPUT TYPE="checkbox" NAME="invoicing_list_POST" VALUE="POST"!;
205 my @invoicing_list = split(', ', $invoicing_list );
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 ),
214 <TR><TD>Billing type</TD></TR></TABLE>
215 <TABLE BGCOLOR="#c0c0c0" BORDER=1 WIDTH="100%">
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"),
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),
232 print qq!<TD VALIGN=TOP><INPUT TYPE="radio" NAME="payby" VALUE="$_"!;
234 print qq! CHECKED> $paybychecked{$_}</TD>!;
236 print qq!> $payby{$_}</TD>!;
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%">
245 <TD COLSPAN=2><SELECT NAME="pkgpart"><OPTION VALUE="">(none)
248 foreach my $package ( @{$packages} ) {
249 print qq!<OPTION VALUE="!, $package->{'pkgpart'}, '"';
250 print " SELECTED" if $pkgpart && ( $package->{'pkgpart'} == $pkgpart );
251 print ">", $package->{'pkg'};
258 <TD ALIGN="right">Username</TD>
259 <TD><INPUT TYPE="text" NAME="username" VALUE="$username"></TD>
262 <TD ALIGN="right">Password</TD>
263 <TD><INPUT TYPE="text" NAME="_password" VALUE="$password">
264 (blank to generate)</TD>
267 <TD ALIGN="right">POP</TD>
268 <TD><SELECT NAME="popnum" SIZE=1><OPTION>
271 foreach my $pop ( @{$pops} ) {
272 print qq!<OPTION VALUE="!, $pop->{'popnum'}, '"',
273 ( $popnum && $pop->{'popnum'} == $popnum ) ? ' SELECTED' : '', ">",
274 $pop->{'popnum'}, ": ",
275 $pop->{'city'}, ", ",
277 " (", $pop->{'ac'}, ")/",
285 <BR><BR><INPUT TYPE="submit" VALUE="Signup">
286 </FORM></BODY></HTML>
292 my $user_agent = new HTTP::Headers::UserAgnet $ENV{HTTP_USER_AGENT};
294 && $user_agent->platform eq 'ia32'
295 && $user_agent->os =~ /^win/
296 && ($user_agent->browser)[0] eq 'IE'
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');
303 print $cgi->header('application/x-Internet-signup'),
304 $ieak_template->fill_in();
306 # my $ins_file = rand(4294967296). ".ins";
307 # open(INS_FILE, ">$ieak_docroot/$ins_file");
308 # print INS_FILE <<END;
310 # print $cgi->redirect("$ieak_docroot/$ins_file");
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>
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 );
332 my $return = qq!<SELECT NAME="$prefix!. qq!_month" SIZE="1">!;
334 $return .= "<OPTION";
335 $return .= " SELECTED" if $_ == $m;
338 $return .= qq!</SELECT>/<SELECT NAME="$prefix!. qq!_year" SIZE="1">!;
339 for ( 1999 .. 2037 ) {
340 $return .= "<OPTION";
341 $return .= " SELECTED" if $_ == $y;
344 $return .= "</SELECT>";