summaryrefslogtreecommitdiff
path: root/FS/FS/did_order.pm
diff options
context:
space:
mode:
authorlevinse <levinse>2011-06-08 17:09:43 +0000
committerlevinse <levinse>2011-06-08 17:09:43 +0000
commitce8f8c834fb0b707b6cbd27846e812efc211e4f3 (patch)
tree72559b6be0d7488dc626ca9e1410409966926f51 /FS/FS/did_order.pm
parent89d81f2d5e133aca8274d6bf034d040f31f0a47c (diff)
DID inventory/import / bulk DID orders - phase 2, RT12754
Diffstat (limited to 'FS/FS/did_order.pm')
-rw-r--r--FS/FS/did_order.pm52
1 files changed, 43 insertions, 9 deletions
diff --git a/FS/FS/did_order.pm b/FS/FS/did_order.pm
index 2404ad8..d004f23 100644
--- a/FS/FS/did_order.pm
+++ b/FS/FS/did_order.pm
@@ -124,6 +124,8 @@ sub delete {
}
$dbh->commit or die $dbh->errstr if $oldAutoCommit;
+
+ '';
}
=item merge SOURCE_ORDER
@@ -133,11 +135,11 @@ Merges the DID order given by SOURCE_ORDER into THIS order.
The following fields from the source order are transferred, only if they aren't
set in this order:
-vendor order #
--submitted
-confirmed
-customer
-DID order items are transferred into this order.
+DID order items are transferred into this order. Per-order customer is cleared
+if any order items are assigned to a customer.
The source order is deleted.
@@ -157,25 +159,57 @@ sub merge {
return "DID vendors do not match"
if $src->vendornum != $self->vendornum;
-
- my @move_if_unset = qw( vendor_order_id submitted confirmed custnum );
+
+ 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 @move_if_unset = qw( vendor_order_id confirmed custnum );
foreach my $f ( @move_if_unset ) {
$self->$f($src->$f) if !$self->$f;
}
my $error = '';
- my @did_order_items = qsearch('did_order_item', { 'ordernum' => $src->ordernum });
- foreach my $did_order_item ( @did_order_items ) {
+ my $item_has_cust = 0;
+ my @did_order_item = $src->did_order_item;
+ foreach my $did_order_item ( @did_order_item ) {
$did_order_item->ordernum($self->ordernum);
+ $item_has_cust = 1 if $did_order_item->custnum;
$error = $did_order_item->replace;
- return $error if $error;
+ if ( $error ) {
+ $dbh->rollback if $oldAutoCommit;
+ return "can't replace did order item "
+ . $did_order_item->orderitemnum . ": $error";
+ }
+ }
+
+ @did_order_item = $self->did_order_item;
+ foreach my $did_order_item ( @did_order_item ) {
+ $item_has_cust = 1 if $did_order_item->custnum;
}
+ $self->custnum('') if $item_has_cust;
+
$error = $src->delete;
- return $error if !$error;
+ if ( $error ) {
+ $dbh->rollback if $oldAutoCommit;
+ return "can't delete source order: $error";
+ }
$error = $self->replace;
- return $error if !$error;
+ if ( $error ) {
+ $dbh->rollback if $oldAutoCommit;
+ return "can't replace target order: $error";
+ }
+
+ $dbh->commit or die $dbh->errstr if $oldAutoCommit;
'';
}