summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorlevinse <levinse>2010-12-31 01:23:34 +0000
committerlevinse <levinse>2010-12-31 01:23:34 +0000
commit903bebf00a555e3b285df70d031f158b5f817a16 (patch)
tree5d71f3e41add0b688c6f8fd4be72ee68f6bd7476
parent180dce3fb97569331accc27fb6061392e11b3efe (diff)
self-signup with prepaid card without customer info, RT9713
-rw-r--r--FS/FS/ClientAPI/Signup.pm73
-rw-r--r--FS/FS/Conf.pm7
-rwxr-xr-xfs_selfservice/FS-SelfService/cgi/signup.cgi4
-rwxr-xr-xfs_selfservice/FS-SelfService/cgi/signup.html54
4 files changed, 96 insertions, 42 deletions
diff --git a/FS/FS/ClientAPI/Signup.pm b/FS/FS/ClientAPI/Signup.pm
index 488692f9f..7087b12a2 100644
--- a/FS/FS/ClientAPI/Signup.pm
+++ b/FS/FS/ClientAPI/Signup.pm
@@ -187,7 +187,7 @@ sub signup_info {
'agent_ship_address' => scalar($conf->exists('agent-ship_address')),
'require_phone' => scalar($conf->exists('cust_main-require_phone')),
'logo' => scalar($conf->config_binary('logo.png')),
-
+ 'prepaid_template_custnum' => $conf->exists('signup_server-prepaid-template-custnum'),
};
$cache->set('signup_info_cache', $signup_info_cache);
@@ -506,31 +506,64 @@ sub new_customer {
#shares some stuff with htdocs/edit/process/cust_main.cgi... take any
# common that are still here and library them.
- my $cust_main = new FS::cust_main ( {
- #'custnum' => '',
- 'agentnum' => $agentnum,
- 'refnum' => $packet->{refnum}
- || $conf->config('signup_server-default_refnum'),
+ my $template_custnum = $conf->config('signup_server-prepaid-template-custnum');
+ my $cust_main;
+ if ( $template_custnum && $packet->{prepaid_shortform} ) {
+ my $template_cust = qsearchs('cust_main', { 'custnum' => $template_custnum } );
+ return { 'error' => 'Configuration error' } unless $template_cust;
+ $cust_main = new FS::cust_main ( {
+ 'agentnum' => $agentnum,
+ 'refnum' => $packet->{refnum}
+ || $conf->config('signup_server-default_refnum'),
+ map { $_ => $template_cust->$_ } qw(
+ last first company address1 address2
+ city county state zip country
+ daytime night fax
+
+ ship_last ship_first ship_company ship_address1 ship_address2
+ ship_city ship_county ship_state ship_zip ship_country
+ ship_daytime ship_night ship_fax
+ ),
+ map { $_ => $packet->{$_} } qw(
+
+ ss stateid stateid_state
+
+ payby
+ payinfo paycvv paydate payname paystate paytype
+ paystart_month paystart_year payissue
+ payip
+
+ referral_custnum comments
+ )
+ } );
+ }
+ else {
+ $cust_main = new FS::cust_main ( {
+ #'custnum' => '',
+ 'agentnum' => $agentnum,
+ 'refnum' => $packet->{refnum}
+ || $conf->config('signup_server-default_refnum'),
- map { $_ => $packet->{$_} } qw(
+ map { $_ => $packet->{$_} } qw(
- last first ss company address1 address2
- city county state zip country
- daytime night fax stateid stateid_state
+ last first ss company address1 address2
+ city county state zip country
+ daytime night fax stateid stateid_state
- ship_last ship_first ship_ss ship_company ship_address1 ship_address2
- ship_city ship_county ship_state ship_zip ship_country
- ship_daytime ship_night ship_fax
+ ship_last ship_first ship_ss ship_company ship_address1 ship_address2
+ ship_city ship_county ship_state ship_zip ship_country
+ ship_daytime ship_night ship_fax
- payby
- payinfo paycvv paydate payname paystate paytype
- paystart_month paystart_year payissue
- payip
+ payby
+ payinfo paycvv paydate payname paystate paytype
+ paystart_month paystart_year payissue
+ payip
- referral_custnum comments
- )
+ referral_custnum comments
+ )
- } );
+ } );
+ }
my $agent = qsearchs('agent', { 'agentnum' => $agentnum } );
if ( $conf->exists('agent_ship_address') && $agent->agent_custnum ) {
diff --git a/FS/FS/Conf.pm b/FS/FS/Conf.pm
index b1a210cbd..635f66423 100644
--- a/FS/FS/Conf.pm
+++ b/FS/FS/Conf.pm
@@ -1838,6 +1838,13 @@ and customer address. Include units.',
'svc_pbx' => 'PBX (svc_pbx)',
],
},
+
+ {
+ 'key' => 'signup_server-prepaid-template-custnum',
+ 'section' => 'self-service',
+ 'description' => 'When the signup server is used with prepaid cards and customer info is not required for signup, the contact/address info will be copied from this customer, if specified',
+ 'type' => 'text',
+ },
{
'key' => 'selfservice_server-base_url',
diff --git a/fs_selfservice/FS-SelfService/cgi/signup.cgi b/fs_selfservice/FS-SelfService/cgi/signup.cgi
index 02acf14aa..200161404 100755
--- a/fs_selfservice/FS-SelfService/cgi/signup.cgi
+++ b/fs_selfservice/FS-SelfService/cgi/signup.cgi
@@ -232,7 +232,7 @@ if ( $magic eq 'process' || $action eq 'process_signup' ) {
pkgpart refnum agentnum
username sec_phrase _password popnum
mac_addr
- countrycode phonenum sip_password pin
+ countrycode phonenum sip_password pin prepaid_shortform
),
grep { /^snarf_/ } $cgi->param
),
@@ -292,6 +292,8 @@ sub print_form {
#$cgi->delete('init_popstate');
$r->{self_url} = $cgi->self_url;
+ $r->{prepaid_shortform} = $cgi->param('prepaid_shortform');
+
print $cgi->header( '-expires' => 'now' ),
$signup_template->fill_in( PACKAGE => 'FS::SelfService::_signupcgi',
HASH => $r
diff --git a/fs_selfservice/FS-SelfService/cgi/signup.html b/fs_selfservice/FS-SelfService/cgi/signup.html
index 7a56a31a1..405444cfa 100755
--- a/fs_selfservice/FS-SelfService/cgi/signup.html
+++ b/fs_selfservice/FS-SelfService/cgi/signup.html
@@ -28,6 +28,7 @@
<FONT SIZE="+1" COLOR="#ff0000"><%= $error %></FONT>
<FORM NAME="OneTrueForm" ACTION="<%= $self_url %>" METHOD=POST onSubmit="document.OneTrueForm.signup.disabled=true">
+<INPUT TYPE="hidden" NAME="prepaid_shortform" VALUE="<%= $prepaid_shortform %>">
<INPUT TYPE="hidden" NAME="session" VALUE="<%= $session_id %>">
<INPUT TYPE="hidden" NAME="action" VALUE="process_signup">
<INPUT TYPE="hidden" NAME="agentnum" VALUE="<%= $agentnum %>">
@@ -52,30 +53,35 @@ Where did you hear about our service? <SELECT NAME="refnum">
}
%>
</SELECT><BR><BR>
+
+<%= unless ( $prepaid_template_custnum && $prepaid_shortform ) {
+
+my $bgcolor = $box_bgcolor || '#c0c0c0';
+$OUT .= qq!
Contact Information
-<TABLE BGCOLOR="<%= $box_bgcolor || '#c0c0c0' %>" BORDER=0 CELLSPACING=0 WIDTH="100%">
+<TABLE BGCOLOR="$bgcolor" BORDER=0 CELLSPACING=0 WIDTH="100%">
<TR>
<TH ALIGN="right"><font color="#ff0000">*</font>Contact name<BR>(last, first)</TH>
- <TD COLSPAN=5><INPUT TYPE="text" NAME="last" VALUE="<%= $last %>">,
- <INPUT TYPE="text" NAME="first" VALUE="<%= $first %>"></TD>
+ <TD COLSPAN=5><INPUT TYPE="text" NAME="last" VALUE="$last">,
+ <INPUT TYPE="text" NAME="first" VALUE="$first"></TD>
</TR>
<TR>
<TD ALIGN="right">Company</TD>
- <TD COLSPAN=5><INPUT TYPE="text" NAME="company" SIZE=70 VALUE="<%= $company %>"></TD>
+ <TD COLSPAN=5><INPUT TYPE="text" NAME="company" SIZE=70 VALUE="$company"></TD>
</TR>
<TR>
<TH ALIGN="right"><font color="#ff0000">*</font>Address</TH>
- <TD COLSPAN=5><INPUT TYPE="text" NAME="address1" SIZE=70 VALUE="<%= $address1 %>"></TD>
+ <TD COLSPAN=5><INPUT TYPE="text" NAME="address1" SIZE=70 VALUE="$address1"></TD>
</TR>
<TR>
<TD ALIGN="right">&nbsp;</TD>
- <TD COLSPAN=5><INPUT TYPE="text" NAME="address2" SIZE=70 VALUE="<%= $address2 %>"></TD>
+ <TD COLSPAN=5><INPUT TYPE="text" NAME="address2" SIZE=70 VALUE="$address2"></TD>
</TR>
<TR>
<TH ALIGN="right"><font color="#ff0000">*</font>City</TH>
- <TD><INPUT TYPE="text" NAME="city" VALUE="<%= $city %>"></TD>
- <%=
- ($county_html, $state_html, $country_html) =
+ <TD><INPUT TYPE="text" NAME="city" VALUE="$city"></TD> !;
+
+ my ($county_html, $state_html, $country_html) =
regionselector( {
selected_county => $county,
selected_state => $state,
@@ -85,32 +91,30 @@ Contact Information
locales => \@cust_main_county,
} );
- %>
- <TH ALIGN="right"><font color="#ff0000">*</font>
- <%= ($county_html =~ /SELECT/) ? 'County/State' : 'State' %></TH>
+$county_out = ($county_html =~ /SELECT/) ? 'County/State' : 'State';
+$OUT .= qq!<TH ALIGN="right"><font color="#ff0000">*</font> $county_out </TH>
<TD>
- <%= "$county_html $state_html"; %>
+ $county_html $state_html
</TD>
<TH><font color="#ff0000">*</font>Zip</TH>
- <TD><INPUT TYPE="text" NAME="zip" SIZE=10 VALUE="<%= $zip %>"></TD>
+ <TD><INPUT TYPE="text" NAME="zip" SIZE=10 VALUE="$zip"></TD>
</TR>
<TR>
<TH ALIGN="right"><font color="#ff0000">*</font>Country</TH>
- <TD><%= $country_html %></TD>
+ <TD>$country_html</TD>
<TR>
<TD ALIGN="right">Day Phone</TD>
- <TD COLSPAN=5><INPUT TYPE="text" NAME="daytime" VALUE="<%= $daytime %>" SIZE=18></TD>
+ <TD COLSPAN=5><INPUT TYPE="text" NAME="daytime" VALUE="$daytime" SIZE=18></TD>
</TR>
<TR>
<TD ALIGN="right">Night Phone</TD>
- <TD COLSPAN=5><INPUT TYPE="text" NAME="night" VALUE="<%= $night %>" SIZE=18></TD>
+ <TD COLSPAN=5><INPUT TYPE="text" NAME="night" VALUE="$night" SIZE=18></TD>
</TR>
<TR>
<TD ALIGN="right">Fax</TD>
- <TD COLSPAN=5><INPUT TYPE="text" NAME="fax" VALUE="<%= $fax %>" SIZE=12></TD>
+ <TD COLSPAN=5><INPUT TYPE="text" NAME="fax" VALUE="$fax" SIZE=12></TD>
</TR>
-<%=
- $OUT = '';
+!;
if ( $stateid_enabled ) {
my ($county_html, $state_html, $country_html) =
regionselector( {
@@ -124,8 +128,16 @@ Contact Information
$OUT .= qq!<TD ALIGN="right">!. $label{stateid_state} .'</TD>';
$OUT .="<TD COLSPAN=3>$county_html $state_html</TD></TR>";
}
-%>
+$OUT .= qq!
</TABLE><font color="#ff0000">*</font> required fields<BR>
+!;
+
+}
+else {
+ @payby = ('PREPAY');
+}
+%>
+
<BR>Billing information<TABLE BGCOLOR="<%= $box_bgcolor || '#c0c0c0' %>" BORDER=0 CELLSPACING=0 WIDTH="100%">
<TR><TD>