[freeside-commits] freeside/FS/FS access_user.pm,1.22,1.23
Ivan,,,
ivan at wavetail.420.am
Thu Feb 19 18:55:43 PST 2009
Update of /home/cvs/cvsroot/freeside/FS/FS
In directory wavetail.420.am:/tmp/cvs-serv21925
Modified Files:
access_user.pm
Log Message:
oops, adding multiple-rightname support broke ACL caching, bringing it back should be a good perf win for large customer views, whew. RT#4830
Index: access_user.pm
===================================================================
RCS file: /home/cvs/cvsroot/freeside/FS/FS/access_user.pm,v
retrieving revision 1.22
retrieving revision 1.23
diff -u -d -r1.22 -r1.23
--- access_user.pm 9 Feb 2009 01:49:27 -0000 1.22
+++ access_user.pm 20 Feb 2009 02:55:41 -0000 1.23
@@ -1,7 +1,7 @@
package FS::access_user;
use strict;
-use vars qw( @ISA $htpasswd_file );
+use vars qw( @ISA $DEBUG $me $htpasswd_file );
use FS::UID;
use FS::Conf;
use FS::Record qw( qsearch qsearchs dbh );
@@ -14,6 +14,9 @@
@ISA = qw( FS::m2m_Common FS::option_Common FS::Record );
#@ISA = qw( FS::m2m_Common FS::option_Common );
+$DEBUG = 0;
+$me = '[FS::access_user]';
+
#kludge htpasswd for now (i hope this bootstraps okay)
FS::UID->install_callback( sub {
my $conf = new FS::Conf;
@@ -413,16 +416,29 @@
$rightname = [ $rightname ] unless ref($rightname);
+ warn "$me access_right called on ". join(', ', @$rightname). "\n"
+ if $DEBUG;
+
#some caching of ACL requests for low-hanging fruit perf improvement
#since we get a new $CurrentUser object each page view there shouldn't be any
#issues with stickiness
if ( $self->{_ACLcache} ) {
- return grep $self->{_ACLcache}{$_}, @$rightname
- unless grep !exists($self->{_ACLcache}{$_}), @$rightname;
+ unless ( grep !exists($self->{_ACLcache}{$_}), @$rightname ) {
+ warn "$me ACL cache hit for ". join(', ', @$rightname). "\n"
+ if $DEBUG;
+ return grep $self->{_ACLcache}{$_}, @$rightname
+ }
+
+ warn "$me ACL cache miss for ". join(', ', @$rightname). "\n"
+ if $DEBUG;
} else {
+
+ warn "initializing ACL cache\n"
+ if $DEBUG;
$self->{_ACLcache} = {};
+
}
my $has_right = ' rightname IN ('. join(',', map '?', @$rightname ). ') ';
@@ -440,8 +456,14 @@
$sth->execute($self->usernum, @$rightname) or die $sth->errstr;
my $row = $sth->fetchrow_arrayref;
- #$row ? $row->[0] : '';
- $self->{_ACLcache}{$rightname} = ( $row ? $row->[0] : '' );
+ my $return = $row ? $row->[0] : '';
+
+ #just caching the single-rightname hits should be enough of a win for now
+ if ( scalar(@$rightname) == 1 ) {
+ $self->{_ACLcache}{${$rightname}[0]} = $return;
+ }
+
+ $return;
}
More information about the freeside-commits
mailing list