From: ivan Date: Thu, 20 Jun 2002 22:35:17 +0000 (+0000) Subject: fix infostreet contact field foo X-Git-Tag: freeside_1_4_0_beta1~80 X-Git-Url: http://git.freeside.biz/gitweb/?p=freeside.git;a=commitdiff_plain;h=29bb6991a3b7187784cd14a3806b0c9db38dd51b fix infostreet contact field foo --- diff --git a/FS/FS/part_export/infostreet.pm b/FS/FS/part_export/infostreet.pm index e6d68c1e2..8a68a2077 100644 --- a/FS/FS/part_export/infostreet.pm +++ b/FS/FS/part_export/infostreet.pm @@ -1,6 +1,7 @@ package FS::part_export::infostreet; use vars qw(@ISA %infostreet2cust_main); +use FS::UID qw(dbh); use FS::part_export; @ISA = qw(FS::part_export); @@ -15,7 +16,7 @@ use FS::part_export; 'zipCode' => 'zip', 'country' => 'country', 'phoneNumber' => 'daytime', - 'faxNumber' => 'night', + 'faxNumber' => 'night', #noment-request... ); sub rebless { shift; } @@ -23,25 +24,41 @@ sub rebless { shift; } sub _export_insert { my( $self, $svc_acct ) = (shift, shift); my $cust_main = $svc_acct->cust_svc->cust_pkg->cust_main; - my $accountID = $self->infostreet_queue( $svc_acct->svcnum, + + local $SIG{HUP} = 'IGNORE'; + local $SIG{INT} = 'IGNORE'; + local $SIG{QUIT} = 'IGNORE'; + local $SIG{TERM} = 'IGNORE'; + local $SIG{TSTP} = 'IGNORE'; + local $SIG{PIPE} = 'IGNORE'; + my $oldAutoCommit = $FS::UID::AutoCommit; + local $FS::UID::AutoCommit = 0; + my $dbh = dbh; + + my $err_or_queue = $self->infostreet_err_or_queue( $svc_acct->svcnum, 'createUser', $svc_acct->username, $svc_acct->_password ); - foreach my $infostreet_field ( keys %infostreet2cust_main ) { - my $error = $self->infostreet_queue( $svc_acct->svcnum, - 'setContactField', $accountID, $infostreet_field, - $cust_main->getfield( $infostreet2cust_main{$infostreet_field} ) ); - return $error if $error; - } + return $err_or_queue unless ref($err_or_queue); + my $jobnum = $err_or_queue->jobnum; + + my %contact_info = ( map { + $_ => $cust_main->getfield( $infostreet2cust_main{$_} ); + } keys %infostreet2cust_main ); my @emails = grep { $_ ne 'POST' } $cust_main->invoicing_list; - if ( @emails ) { - my $error = $self->infostreet_queue( $svc_acct->svcnum, - 'setContactField', $accountID, 'email', $emails[0] ); - return $error if $error; - } + $contact_info{'email'} = $emails[0] if @emails; #this one is kinda noment-specific - $self->infostreet_queue( $svc_acct->svcnum, - 'setContactField', $accountID, 'title', $cust_main->agent->agent ); + $contact_info{'title'} = $cust_main->agent->agent; + + $err_or_queue = $self->infostreet_queueContact( $svc_acct->svcnum, + $svc_acct->username, %contact_info ); + return $err_or_queue unless ref($err_or_queue); + my $error = $err_or_queue->depend_insert( $jobnum ); + return $error if $error; + + $dbh->commit or die $dbh->errstr if $oldAutoCommit; + + ''; } @@ -88,6 +105,49 @@ sub infostreet_queue { ); } +#ick false laziness +sub infostreet_err_or_queue { + my( $self, $svcnum, $method ) = (shift, shift, shift); + my $queue = new FS::queue { + 'svcnum' => $svcnum, + 'job' => 'FS::part_export::infostreet::infostreet_command', + }; + $queue->insert( + $self->option('url'), + $self->option('login'), + $self->option('password'), + $self->option('groupID'), + $method, + @_, + ) or $queue; +} + +sub infostreet_queueContact { + my( $self, $svcnum ) = (shift, shift); + my $queue = new FS::queue { + 'svcnum' => $svcnum, + 'job' => 'FS::part_export::infostreet::infostreet_setContact', + }; + $queue->insert( + $self->option('url'), + $self->option('login'), + $self->option('password'), + $self->option('groupID'), + @_, + ) or $queue; +} + +sub infostreet_setContact { + my($url, $is_username, $is_password, $groupID, $username, %contact_info) = @_; + my $accountID = infostreet_command($url, $is_username, $is_password, $groupID, + 'getAccountID', $username); + foreach my $field ( %contact_info ) { + infostreet_command($url, $is_username, $is_password, $groupID, + 'setContactField', $field, $contact_info{$field} ); + } + +} + sub infostreet_command { #subroutine, not method my($url, $username, $password, $groupID, $method, @args) = @_;