summaryrefslogtreecommitdiff
path: root/FS/FS/ClientAPI/Signup.pm
diff options
context:
space:
mode:
authorlevinse <levinse>2010-12-31 01:23:28 +0000
committerlevinse <levinse>2010-12-31 01:23:28 +0000
commit0bebde603df97eb496150e80a58755b2f792f64a (patch)
tree6251a2adf9db8de3672ea7284c5e4e8b7484632f /FS/FS/ClientAPI/Signup.pm
parent807f0570749e9093cbc82f6b11b3fa743b86b1db (diff)
self-signup with prepaid card without customer info, RT9713
Diffstat (limited to 'FS/FS/ClientAPI/Signup.pm')
-rw-r--r--FS/FS/ClientAPI/Signup.pm73
1 files changed, 53 insertions, 20 deletions
diff --git a/FS/FS/ClientAPI/Signup.pm b/FS/FS/ClientAPI/Signup.pm
index 488692f..7087b12 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 ) {