[Rt-commit] [rtir] 04/05: Turn off UseSQLForACLChecks when Constituencies are enabled.

Kevin Falcone falcone at bestpractical.com
Fri Sep 26 16:41:53 EDT 2014


This is an automated email from the git hooks/post-receive script.

falcone pushed a commit to branch 3.2-trunk
in repository rtir.

commit b91ced2c5ddb4d72911e9299d0b2c8e5df58ba91
Author: Kevin Falcone <falcone at bestpractical.com>
Date:   Thu Sep 25 15:35:46 2014 -0400

    Turn off UseSQLForACLChecks when Constituencies are enabled.
    
    UseSQLForACLChecks will generate sql like
    select * from main tickets where (Queue = 'Incident Reports - EDUNET' OR
    Queue = 'Incidents - EDUNET' ..) and (Queue = 'Incident Reports')
    if you're searching for IRs, which is an impossible WHERE and you lose.
    
    You can 'fix' this by giving AdminCc in each of the 4 primary RTIR
    queues ShowTicket rights, but this is a deviation from previous rights
    and I worry about performance when we have to join for 4 different role
    groups every time.
    
    This will be better in RTIR 3.4 since we're throwing away the hack and
    can just use Constituencies like real queues.
---
 docs/Constituencies.pod | 17 +++++++++++++++++
 lib/RT/IR/Config.pm     | 10 ++++++++++
 2 files changed, 27 insertions(+)

diff --git a/docs/Constituencies.pod b/docs/Constituencies.pod
index e1a8315..6f05134 100644
--- a/docs/Constituencies.pod
+++ b/docs/Constituencies.pod
@@ -368,3 +368,20 @@ Considering the above suggestion, a good way to manage users is to place
 each user in a constituency specific groups based on their access needs.
 Place users into DutyTeam only if they should work with all constituencies.
 
+=head2 Constituency issues
+
+Constituencies are very heavyweight, they add extra code to many
+permission checks in the system and also greatly complicate the number
+of groups and group members in the system.  If you are not going to use
+this functionality, you would be well served to disable the Constituency
+Custom Field, which will cause RTIR to remove a number of added
+complexities.
+
+Additionaly, while RT 4.2 has shipped with the config option
+C<$UseSQLForACLChecks> defaulted on, it is not compatible with Constituencies.
+If RTIR detects that it is being started with Constituencies enabled it
+will disabled C<$UseSQLForACLChecks>.  Overriding this means that any
+part of the UI trying to show a list of tickets (such as the RTIR
+homepage or any search results) will be empty for users in restricted
+Constituency DutyTeams.
+
diff --git a/lib/RT/IR/Config.pm b/lib/RT/IR/Config.pm
index 326e6be..c0de127 100644
--- a/lib/RT/IR/Config.pm
+++ b/lib/RT/IR/Config.pm
@@ -94,6 +94,16 @@ sub Init {
 
     RT->Config->Set(HomepageComponents => \@homepage_components);
 
+    $RT::Config::META{UseSQLForACLChecks}{PostLoadCheck} = sub {
+        my ($self,$value) = @_;
+        if ( RT::IR->HasConstituency ) {
+            if ( $value ) {
+                $self->Set('UseSQLForACLChecks',0);
+                RT->Logger->info('Disabling UseSQLForACLChecks because Constituencies are in use.  If you are not using Constituencies, you can disable that Custom Field.');
+            }
+        }
+    };
+
     return;
 }
 

-- 
To stop receiving notification emails like this one, please contact
the administrator of this repository.


More information about the rt-commit mailing list