freeside/FS/FS/part_export artera_turbo.pm,1.5,1.6

ivan ivan at pouncequick.420.am
Tue Jan 4 18:47:30 PST 2005


Update of /home/cvs/cvsroot/freeside/FS/FS/part_export
In directory pouncequick:/tmp/cvs-serv6098

Modified Files:
	artera_turbo.pm 
Log Message:
queue status changes rather than run them immediately, always format keycode as %010d, closes: Bug#936, Bug#1060

Index: artera_turbo.pm
===================================================================
RCS file: /home/cvs/cvsroot/freeside/FS/FS/part_export/artera_turbo.pm,v
retrieving revision 1.5
retrieving revision 1.6
diff -u -d -r1.5 -r1.6
--- artera_turbo.pm	23 Oct 2004 10:36:54 -0000	1.5
+++ artera_turbo.pm	5 Jan 2005 02:47:27 -0000	1.6
@@ -100,8 +100,8 @@
 
   if ( $result->{'id'} == 1 ) {
     my $new = new FS::svc_external { $svc_external->hash };
-    $new->id($result->{'ASN'});
-    $new->title($result->{'AKC'});
+    $new->id(sprintf('%010d', $result->{'ASN'}));
+    $new->title(sprintf('%010d', $result->{'AKC'}));
     $new->replace($svc_external);
   } else {
     $result->{'message'} || 'No response from Artera';
@@ -119,36 +119,58 @@
 
 sub _export_delete {
   my( $self, $svc_external ) = (shift, shift);
-  $self->statusChange(17, $svc_external);
+  $self->queue_statusChange(17, $svc_external);
 }
 
 sub _export_suspend {
   my( $self, $svc_external ) = (shift, shift);
-  $self->statusChange(16, $svc_external);
+  $self->queue_statusChange(16, $svc_external);
 }
 
 sub _export_unsuspend {
   my( $self, $svc_external ) = (shift, shift);
-  $self->statusChange(15, $svc_external);
+  $self->queue_statusChange(15, $svc_external);
 }
 
-sub statusChange {
+sub queueStatusChange {
   my( $self, $status, $svc_external ) = @_;
 
+  my $queue = new FS::queue {
+    'svcnum' => $svc_external->svcnum,
+    'job'    => 'FS::part_export::artera_turbo::statusChange',
+  };
+  $queue->insert(
+    ( map { $self->option($_) }
+          qw( rid username password production ) ),
+    $status,
+    $svc_external->id,
+    $svc_external->title,
+    $self->option('debug'),
+  );
+}
+
+sub statusChange {
+  my( $rid, $username, $password, $prod, $status, $id, $title, $debug ) = @_;
+
   eval "use Net::Artera;";
   return $@ if $@;
-  $Net::Artera::DEBUG = 1 if $self->option('debug');
-  my $artera = $self->_new_Artera;
+  $Net::Artera::DEBUG = 1 if $debug;
+
+  my $artera = new Net::Artera (
+    'rid'        => $rid,
+    'username'   => $username,
+    'password'   => $password,
+    'production' => $prod,
+  );
 
   my $result = $artera->statusChange(
-    'asn'      => sprintf('%010d', $svc_external->id),
-    'akc'      => $svc_external->title,
+    'asn'      => sprintf('%010d', $id),
+    'akc'      => sprintf('%010d', $title),
     'statusid' => $status,
   );
 
-  $result->{'id'} == 1
-    ? ''
-    : $result->{'message'};
+  die $result->{'message'} unless $result->{'id'} == 1;
+
 }
 
 1;




More information about the freeside-commits mailing list