X-Git-Url: http://git.freeside.biz/gitweb/?p=freeside.git;a=blobdiff_plain;f=FS%2FFS%2Fpart_export%2Finfostreet.pm;h=89ab06d22ab9d7c67ed7000f2075857c581aa771;hp=40dee487af1e67559ad0c07c0a0cc24be0e8a87f;hb=5939c0f1ae7bea08adde82f6d3578e6c5ac31248;hpb=d7adf8a88198c98305dae4c5030bb82107595b43 diff --git a/FS/FS/part_export/infostreet.pm b/FS/FS/part_export/infostreet.pm index 40dee487a..89ab06d22 100644 --- a/FS/FS/part_export/infostreet.pm +++ b/FS/FS/part_export/infostreet.pm @@ -1,10 +1,13 @@ package FS::part_export::infostreet; -use vars qw(@ISA %infostreet2cust_main); +use vars qw(@ISA %infostreet2cust_main $DEBUG); +use FS::UID qw(dbh); use FS::part_export; @ISA = qw(FS::part_export); +$DEBUG = 0; + %infostreet2cust_main = ( 'firstName' => 'first', 'lastName' => 'last', @@ -15,7 +18,7 @@ use FS::part_export; 'zipCode' => 'zip', 'country' => 'country', 'phoneNumber' => 'daytime', - 'faxNumber' => 'night', + 'faxNumber' => 'night', #noment-request... ); sub rebless { shift; } @@ -23,20 +26,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; + $contact_info{'email'} = $emails[0] if @emails; - $self->infostreet_queue( $svc_acct->svcnum, - 'setContactField', $accountID, 'email', $cust_main->invoicing_list ) #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; + + ''; } @@ -83,9 +107,54 @@ 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 ( keys %contact_info ) { + infostreet_command($url, $is_username, $is_password, $groupID, + 'setContactField', $accountID, $field, $contact_info{$field} ); + } + +} + sub infostreet_command { #subroutine, not method my($url, $username, $password, $groupID, $method, @args) = @_; + warn "[FS::part_export::infostreet] $method ".join(' ', @args)."\n" if $DEBUG; + #quelle hack if ( $method =~ /,/ ) { foreach my $part ( split(/,\s*/, $method) ) {