[freeside-commits] freeside/FS/FS/ClientAPI Signup.pm, 1.64.2.2, 1.64.2.3

Erik Levinson levinse at wavetail.420.am
Thu Dec 30 17:23:36 PST 2010


Update of /home/cvs/cvsroot/freeside/FS/FS/ClientAPI
In directory wavetail.420.am:/tmp/cvs-serv31147/FS/FS/ClientAPI

Modified Files:
      Tag: FREESIDE_2_1_BRANCH
	Signup.pm 
Log Message:
self-signup with prepaid card without customer info, RT9713

Index: Signup.pm
===================================================================
RCS file: /home/cvs/cvsroot/freeside/FS/FS/ClientAPI/Signup.pm,v
retrieving revision 1.64.2.2
retrieving revision 1.64.2.3
diff -u -w -d -r1.64.2.2 -r1.64.2.3
--- Signup.pm	24 Dec 2010 05:49:01 -0000	1.64.2.2
+++ Signup.pm	31 Dec 2010 01:23:33 -0000	1.64.2.3
@@ -187,7 +187,7 @@
       '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,7 +506,39 @@
 
   #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 ( {
+  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}
@@ -531,6 +563,7 @@
     )
 
   } );
+  }
 
   my $agent = qsearchs('agent', { 'agentnum' => $agentnum } );
   if ( $conf->exists('agent_ship_address') && $agent->agent_custnum ) {



More information about the freeside-commits mailing list