[rt-users] Action::EscalatePriority messing up my ticket history
Alex Young
alexyoung at scoutsolutions.co.uk
Thu Oct 9 09:15:19 EDT 2008
All I ever do is mkdir each directly that is needed by a script. I never
edit anything into the /opt/rt3/share/.... folder. I always copy the
files I want to edit from there to /opt/rt3/local/....
Check out Using the 'local' directory here:
http://wiki.bestpractical.com/view/CleanlyCustomizeRT
From: rt-users-bounces at lists.bestpractical.com
[mailto:rt-users-bounces at lists.bestpractical.com] On Behalf Of Bernd
Kuhlen -WetterOnline-
Sent: 09 October 2008 14:10
To: Bernd Kuhlen -WetterOnline-; rt-users at lists.bestpractical.com
Subject: Re: [rt-users] Action::EscalatePriority messing up my ticket
history
Hi Alex,
I think I know the core of my problem. The whole directory
./Callbacks/MyCallbacks.... hasn't existed before so I just made a
"mkdir" to have it in my directory-tree.
But the RT doesn't know about the existence of this directory (it's not
configured anywhere). That's why it's not working out, I guess.
I have a file called "ShowHistory" in my
>rt-root>/html/Ticket/Elements/ShowHistory. I'm pretty sure somewhere
within this file I have to do the changes
I dump it for you (in case you have the time, please feel free just to
skip this mail if you're busy ..)
<%perl>
if ($ShowDisplayModes or $ShowTitle) {
my $title = $ShowTitle
? loc('History')
: ' ';
my $titleright;
if ($ShowDisplayModes) {
$titleright = '';
if ($ShowHeaders) {
$titleright .= qq{<a href="$URIFile?id=} .
$Ticket->id.qq{">} .
loc("Brief headers") .
qq{</a> — };
$titleright .= q[<span class="selected">] . loc("Full
headers") . "</span>";
}
else {
$titleright .= q[<span class="selected">] . loc("Brief
headers") . "</span> — ";
$titleright .= qq{<a href="$URIFile?ShowHeaders=1;id=} .
$Ticket->id.qq{">} .
loc("Full headers") .
qq{</a>};
}
}
</%perl>
<div class="history">
<& /Widgets/TitleBoxStart, title => $title, titleright_raw =>
$titleright &>
% }
<div id="ticket-history">
<%perl>
my @attachments = @{$Attachments->ItemsArrayRef()};
my @attachment_content = @{$AttachmentContent->ItemsArrayRef()};
while ( my $Transaction = $Transactions->Next ) {
my $skip = 0;
$m->callback(
%ARGS,
Transaction => $Transaction,
skip => \$skip,
CallbackName => 'SkipTransaction',
);
next if $skip;
$i++;
my @trans_attachments = grep { $_->TransactionId == $Transaction->Id
} @attachments;
my $trans_content = {};
grep { ($_->TransactionId == $Transaction->Id ) &&
($trans_content->{$_->Id} = $_) } @attachment_content;
my $IsLastTransaction = 0;
if ( $OldestFirst ) {
$IsLastTransaction = $Transactions->IsLast;
} else {
$IsLastTransaction = 1 if ( $i == 1 );
}
#Args is first because we're clobbering the "Attachments" parameter
$m->comp( 'ShowTransaction',
%ARGS,
Ticket => $Ticket,
Transaction => $Transaction,
ShowHeaders => $ShowHeaders,
RowNum => $i,
Attachments => \@trans_attachments,
AttachmentContent => $trans_content,
LastTransaction => $IsLastTransaction
);
# manually flush the content buffer after each txn, so the user sees
# some update
$m->flush_buffer();
}
</%perl>
</div>
% if ($ShowDisplayModes or $ShowTitle) {
<& /Widgets/TitleBoxEnd &>
% }
</div>
<%INIT>
my $Transactions = new RT::Transactions($session{'CurrentUser'});
if ($Tickets) {
while (my $t = $Tickets->Next) {
$Transactions->LimitToTicket($t->id);
}
} else {
$Transactions = $Ticket->Transactions;
}
my $OldestFirst = RT->Config->Get( 'OldestTransactionsFirst',
$session{'CurrentUser'} );
my $SortOrder = $OldestFirst? 'ASC': 'DESC';
$Transactions->OrderByCols( { FIELD => 'Created',
ORDER => $SortOrder },
{ FIELD => 'id',
ORDER => $SortOrder },
);
my $i;
$Attachments ||= $m->comp('/Ticket/Elements/FindAttachments', Ticket =>
$Ticket, Tickets => $Tickets || undef);
$AttachmentContent ||= $m->comp('/Ticket/Elements/LoadTextAttachments',
Ticket => $Ticket);
</%INIT>
<%ARGS>
$URIFile => RT->Config->Get('WebPath')."/Ticket/Display.html"
$Ticket => undef
$Tickets => undef
$Attachments => undef
$AttachmentContent => undef
$ShowHeaders => undef
$ShowTitle => 1
$ShowDisplayModes => 1
$WarnUnsigned => undef
</%ARGS>
On 9 Oct 2008, at 14:43, Bernd Kuhlen -WetterOnline- wrote:
thanks a lot.
I'll check this out.
On 9 Oct 2008, at 14:39, Alex Young wrote:
Here is a copy of my file
/opt/rt3/local/html/Callbacks/MyCallbacks/Ticket/Elements/ShowHistory/Sk
ipTransaction
<%init>
$$skip = 1 if (($_SkipSystemMessages) && ($Transaction->Creator eq 1 |
$Transaction->Creator eq 12));
</%init>
<%args>
$Transaction => undef
$skip => undef
$_SkipSystemMessages => undef
</%args>
Creator ID 1 is RT_System, which pops up when you send emails out and
other systems.
Creator ID 12 is the linux/RT user which runs the escelate job.
All it is doing is seeing who created the transaction, and if its user
number 1 or 12, it skips it.
You will need ot find out the user ID number for the user running the
escelate job. You can od this by looking in the user list. The nuber to
the left is the number you would want to put into the "Creator eq XX"
bit of the code.
From: Bernd Kuhlen -WetterOnline- [mailto:bernd.kuhlen at wetteronline.de]
Sent: 09 October 2008 11:38
To: Alex Young; rt-users at lists.bestpractical.com
Cc: Bernd Kuhlen -WetterOnline-
Subject: Re: [rt-users] Action::EscalatePriority messing up my ticket
history
Dear Alex, Dear List,
thanks for your quick response. I should add that I'm using RT-3.8.1 on
FreeBSD6.3/amd64 (which I forgot in my first mail).
I did the following (which didn't quite help me):
mkdir -p Callbacks/MyCallbacks/Ticket/Elements/ShowHistory in my
<rt-root>/local/html/Ticket directory. The whole directory "Callbacks"
hadn't existed beforehand.
Into the file "SkipTransaction" I dumped the following:
<%init>
$$skip = 1 if (($_SkipSystemMessages) && ($Transaction->Creator eq
1));
</%init>
<%args>
$Transaction => undef
$skip => undef
$_SkipSystemMessages => undef
</%args>
Then in my "Display.html" I changed this block
<& /Ticket/Elements/ShowHistory ,
Ticket => $TicketObj,
Tickets => $Tickets,
Collapsed => $ARGS{'Collapsed'},
ShowHeaders => $ARGS{'ShowHeaders'},
Attachments => $attachments,
AttachmentContent => $attachment_content,
_SkipSystemMessages => !0 <----- that's what I added
&>
I must confess I don't have a clue what this code is doing I'm not a
programmer. The only thing I know: my ticket history is still being
messed up with priority-change entries.
I'm wondering if I could fix my problem by simply denying any existing
rights for the user doing the cron job. Of course the Right
"ModifyTicket" is needed but maybe there's some right for tracing
changes in the history ?
best regards,
Bernd
On 9 Oct 2008, at 11:29, Alex Young wrote:
I set RT to hide some of the history using this:
http://wiki.bestpractical.com/view/HideTransactions
All I have done is set it to hide the history of the RT_System user and
the user I have setup to escalate the tickets. You can still see their
entries on the history page, just not in anoy of the other pages.
-----Original Message-----
From: rt-users-bounces at lists.bestpractical.com
[mailto:rt-users-bounces at lists.bestpractical.com] On Behalf Of Bernd
Kuhlen -WetterOnline-
Sent: 09 October 2008 10:21
To: rt-users at lists.bestpractical.com
Subject: [rt-users] Action::EscalatePriority messing up my ticket
history
Hi everyone,
I've set up my rt-crontool like this:
0 1 * * * /usr/local/bin/rt-crontool --search RT::Search::FromSQL --
search-arg "(Status='new' OR Status='open' OR Status = 'stalled')" --
action RT::Action::EscalatePriority >/dev/null 2>/dev/null
and it's working fine. But I don't want it to mess up my ticket
history. I have tickets starting with a priority of 0 and ending with
100 in some weeks time and every night I get a new entry saying that
the ticket priority has changed. These entry are informative if the
priority has been manually changed but not if they just trace the
linear priority escalation done by a cronjob. So after a couple of
weeks I have numerous lines with a "ticket-priority changed" entry.
That's not nice.
I'm new to RT and couldn't find anything about this matter by google
or in any wiki.
best regards,
Bernd
_______________________________________________
http://lists.bestpractical.com/cgi-bin/mailman/listinfo/rt-users
Community help: http://wiki.bestpractical.com
Commercial support: sales at bestpractical.com
Discover RT's hidden secrets with RT Essentials from O'Reilly Media.
Buy a copy at http://rtbook.bestpractical.com
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.bestpractical.com/pipermail/rt-users/attachments/20081009/e5f1aa55/attachment.htm>
More information about the rt-users
mailing list