[Rt-commit] r10070 - in rt/branches/3.7-EXPERIMENTAL: .

ruz at bestpractical.com ruz at bestpractical.com
Mon Dec 24 18:47:03 EST 2007


Author: ruz
Date: Mon Dec 24 18:47:02 2007
New Revision: 10070

Modified:
   rt/branches/3.7-EXPERIMENTAL/   (props changed)
   rt/branches/3.7-EXPERIMENTAL/lib/RT/User_Overlay.pm

Log:
 r9752 at cubic-pc (orig r9751):  ruz | 2007-11-28 01:20:47 +0300
 * don't cache PrincipalObj. it causes memory leak as now
   RT::CurrentUser ISA RT::User


Modified: rt/branches/3.7-EXPERIMENTAL/lib/RT/User_Overlay.pm
==============================================================================
--- rt/branches/3.7-EXPERIMENTAL/lib/RT/User_Overlay.pm	(original)
+++ rt/branches/3.7-EXPERIMENTAL/lib/RT/User_Overlay.pm	Mon Dec 24 18:47:02 2007
@@ -1105,20 +1105,20 @@
     my $self = shift;
 
     unless ( $self->id ) {
-        $RT::Logger->error('User not found');
-        return;
+        $RT::Logger->error("Couldn't get principal for not loaded object");
+        return undef;
     }
 
-    unless ( $self->{'PrincipalObj'} ) {
-        my $obj = RT::Principal->new( $self->CurrentUser );
-        $obj->LoadById( $self->id );
-        unless ( $obj->id && $obj->PrincipalType eq 'User' ) {
-            $RT::Logger->crit( 'Wrong principal for user #'. $self->id );
-        } else {
-            $self->{'PrincipalObj'} = $obj;
-        }
+    my $obj = RT::Principal->new( $self->CurrentUser );
+    $obj->LoadById( $self->id );
+    unless ( $obj->id ) {
+        $RT::Logger->crit( 'No principal for user #'. $self->id );
+        return undef;
+    } elsif ( $obj->PrincipalType ne 'User' ) {
+        $RT::Logger->crit( 'User #'. $self->id .' has principal of '. $obj->PrincipalType .' type' );
+        return undef;
     }
-    return $self->{'PrincipalObj'};
+    return $obj;
 }
 
 


More information about the Rt-commit mailing list