missing underscore!
[freeside.git] / FS / FS / part_export / artera_turbo.pm
index 13a4f39..c2de4d9 100644 (file)
@@ -22,6 +22,9 @@ tie my %options, 'Tie::IxHash',
   'production' => { 'label' => 'Production mode (leave unchecked for staging)',
                     'type'  => 'checkbox',
                   },
+  'debug'      => { 'label' => 'Enable debug logging',
+                    'type'  => 'checkbox',
+                  },
 ;
 
 %info = (
@@ -62,6 +65,7 @@ sub _export_insert {
 
   eval "use Net::Artera;";
   return $@ if $@;
+  $Net::Artera::DEBUG = 1 if $self->option('debug');
   my $artera = $self->_new_Artera;
 
   my $cust_pkg = $svc_external->cust_svc->cust_pkg;
@@ -96,8 +100,8 @@ sub _export_insert {
 
   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';
@@ -115,35 +119,58 @@ sub _export_replace {
 
 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 queue_StatusChange {
   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 $@;
-  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;