summaryrefslogtreecommitdiff
path: root/FS/FS/access_user.pm
diff options
context:
space:
mode:
authorivan <ivan>2009-02-20 02:55:41 +0000
committerivan <ivan>2009-02-20 02:55:41 +0000
commitd119d4bc4b5f3f717c90d905a95f4de788c0e892 (patch)
treec318f2b276c21e019eb0960bd22ce1ae2b001a4d /FS/FS/access_user.pm
parenta30e8806a4d208aa8736061a3654b6ad97335322 (diff)
oops, adding multiple-rightname support broke ACL caching, bringing it back should be a good perf win for large customer views, whew. RT#4830
Diffstat (limited to 'FS/FS/access_user.pm')
-rw-r--r--FS/FS/access_user.pm32
1 files changed, 27 insertions, 5 deletions
diff --git a/FS/FS/access_user.pm b/FS/FS/access_user.pm
index 63ae30d..cf56fd8 100644
--- a/FS/FS/access_user.pm
+++ b/FS/FS/access_user.pm
@@ -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 @@ use FS::agent;
@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 @@ sub access_right {
$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 @@ sub access_right {
$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;
}