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