From 4215cff6c334a834950ff5a93f4fd7713f9c5984 Mon Sep 17 00:00:00 2001 From: erickson Date: Wed, 9 Feb 2011 18:24:06 +0000 Subject: [PATCH] allow item status update if either status-specific perm is allowed or UPDATE_COPY is allowed. fire off related A/T events after the initial transaction has been committed git-svn-id: svn://svn.open-ils.org/ILS/branches/rel_2_1@19415 dcc99617-32d9-48b4-a31d-7c20da2025e4 --- Open-ILS/src/perlmods/lib/OpenILS/Application/Circ.pm | 14 ++++++++------ 1 file changed, 8 insertions(+), 6 deletions(-) diff --git a/Open-ILS/src/perlmods/lib/OpenILS/Application/Circ.pm b/Open-ILS/src/perlmods/lib/OpenILS/Application/Circ.pm index 52e76bc900..67b2dc1a3d 100644 --- a/Open-ILS/src/perlmods/lib/OpenILS/Application/Circ.pm +++ b/Open-ILS/src/perlmods/lib/OpenILS/Application/Circ.pm @@ -1138,9 +1138,6 @@ sub mark_item { ($copy->call_number->id == OILS_PRECAT_CALL_NUMBER) ? $copy->circ_lib : $copy->call_number->owning_lib; - return $e->die_event unless $e->allowed('UPDATE_COPY', $owning_lib); - - my $perm = 'MARK_ITEM_MISSING'; my $stat = OILS_COPY_STATUS_MISSING; @@ -1150,9 +1147,6 @@ sub mark_item { my $evt = handle_mark_damaged($e, $copy, $owning_lib, $args); return $evt if $evt; - my $ses = OpenSRF::AppSession->create('open-ils.trigger'); - $ses->request('open-ils.trigger.event.autocreate', 'damaged', $copy, $owning_lib); - } elsif ( $self->api_name =~ /bindery/ ) { $perm = 'MARK_ITEM_BINDERY'; $stat = OILS_COPY_STATUS_BINDERY; @@ -1173,6 +1167,8 @@ sub mark_item { $stat = OILS_COPY_STATUS_DISCARD; } + # caller may proceed if either perm is allowed + return $e->die_event unless $e->allowed([$perm, 'UPDATE_COPY'], $owning_lib); $copy->status($stat); $copy->edit_date('now'); @@ -1190,6 +1186,12 @@ sub mark_item { $e->commit; + if( $self->api_name =~ /damaged/ ) { + # now that we've committed the changes, create related A/T events + my $ses = OpenSRF::AppSession->create('open-ils.trigger'); + $ses->request('open-ils.trigger.event.autocreate', 'damaged', $copy, $owning_lib); + } + $logger->debug("resetting holds that target the marked copy"); OpenILS::Application::Circ::Holds->_reset_hold($e->requestor, $_) for @$holds; -- 2.11.0