[Rt-commit] r2024 - in rt/branches/3.4-RELEASE: .
html/Ticket/Elements lib/RT
jesse at bestpractical.com
jesse at bestpractical.com
Tue Dec 21 17:11:42 EST 2004
Author: jesse
Date: Tue Dec 21 17:11:39 2004
New Revision: 2024
Modified:
rt/branches/3.4-RELEASE/ (props changed)
rt/branches/3.4-RELEASE/html/Ticket/Elements/ShowHistory
rt/branches/3.4-RELEASE/lib/RT/Ticket_Overlay.pm
rt/branches/3.4-RELEASE/lib/RT/Transactions_Overlay.pm
Log:
r2500 at hualien: jesse | 2004-12-21T22:06:43.378557Z
Refactored RT's logic that limits sets of transactions to tickets to make it easier to reuse.
Fixed bugs in searches for transactions related to multiple tickets.
Modified: rt/branches/3.4-RELEASE/html/Ticket/Elements/ShowHistory
==============================================================================
--- rt/branches/3.4-RELEASE/html/Ticket/Elements/ShowHistory (original)
+++ rt/branches/3.4-RELEASE/html/Ticket/Elements/ShowHistory Tue Dec 21 17:11:39 2004
@@ -131,9 +131,7 @@
my $Transactions = new RT::Transactions($session{'CurrentUser'});
if ($Tickets) {
while (my $t = $Tickets->Next) {
- $Transactions->Limit(FIELD => 'Ticket',
- OPERATOR => '=',
- VALUE => $t->Id);
+ $Transactions->LimitToTicket($t->id);
}
} else {
$Transactions = $Ticket->Transactions;
Modified: rt/branches/3.4-RELEASE/lib/RT/Ticket_Overlay.pm
==============================================================================
--- rt/branches/3.4-RELEASE/lib/RT/Ticket_Overlay.pm (original)
+++ rt/branches/3.4-RELEASE/lib/RT/Ticket_Overlay.pm Tue Dec 21 17:11:39 2004
@@ -150,6 +150,7 @@
use RT::Date;
use RT::CustomFields;
use RT::Tickets;
+use RT::Transactions;
use RT::URI::fsck_com_rt;
use RT::URI;
use MIME::Entity;
@@ -3563,27 +3564,11 @@
sub Transactions {
my $self = shift;
- use RT::Transactions;
my $transactions = RT::Transactions->new( $self->CurrentUser );
#If the user has no rights, return an empty object
if ( $self->CurrentUserHasRight('ShowTicket') ) {
- my $tickets = $transactions->NewAlias('Tickets');
- $transactions->Join(
- ALIAS1 => 'main',
- FIELD1 => 'ObjectId',
- ALIAS2 => $tickets,
- FIELD2 => 'id'
- );
- $transactions->Limit(
- ALIAS => $tickets,
- FIELD => 'EffectiveId',
- VALUE => $self->id()
- );
- $transactions->Limit(
- FIELD => 'ObjectType',
- VALUE => ref($self),
- );
+ $transactions->LimitToTicket($self->id);
# if the user may not see comments do not return them
unless ( $self->CurrentUserHasRight('ShowTicketComments') ) {
Modified: rt/branches/3.4-RELEASE/lib/RT/Transactions_Overlay.pm
==============================================================================
--- rt/branches/3.4-RELEASE/lib/RT/Transactions_Overlay.pm (original)
+++ rt/branches/3.4-RELEASE/lib/RT/Transactions_Overlay.pm Tue Dec 21 17:11:39 2004
@@ -112,6 +112,48 @@
}
+
+
+=head2 LimitToTicket TICKETID
+
+Find only transactions for the ticket whose id is TICKETID.
+
+This includes tickets merged into TICKETID.
+
+Repeated calls to this method will intelligently limit down to that set of tickets, joined with an OR
+
+
+=cut
+
+
+sub LimitToTicket {
+ my $self = shift;
+ my $tid = shift;
+
+ unless ( $self->{'tickets_table'} ) {
+ $self->{'tickets_table'} ||= $self->NewAlias('Tickets');
+ $self->Join(
+ ALIAS1 => 'main',
+ FIELD1 => 'ObjectId',
+ ALIAS2 => $self->{'tickets_table'},
+ FIELD2 => 'id'
+ );
+ $self->Limit(
+ FIELD => 'ObjectType',
+ VALUE => 'RT::Ticket',
+ );
+ }
+ $self->Limit(
+ ALIAS => $self->{tickets_table},
+ FIELD => 'EffectiveId',
+ OPERATOR => '=',
+ ENTRYAGGREGATOR => 'OR',
+ VALUE => $tid,
+ );
+
+}
+
+
# {{{ sub Next
sub Next {
my $self = shift;
More information about the Rt-commit
mailing list