mirror of
				https://github.com/Alfresco/alfresco-community-repo.git
				synced 2025-10-22 15:12:38 +00:00 
			
		
		
		
	12943: Port of support for ADB-47 from V2.1-A to 3.1
   12948: Port of tests from CHK-2235 for ADB-20 from V2.1-A to 3.1
   12965: Activated index tracker Quartz job by default
   12974: Port for lazy creation of home folders with configuration from V2.1-A to V3.1: original CHK-2619, CHK-2716
   12976: Merged V2.1A to V3.1
      8562: (record-only) Fix to lazily create home folders - DO NOT MERGE
      8694: (record-only) Added configuration for lazy or eager creation of home folders
   12978: Merged V3.0 to V3.1
      12920: Merged V2.2 to V3.0
         12456: Wire up AVM locking service by interface to allow for potential over-ride
         12457: Make AVM ChildKey case insensitive
         12470: Merged V2.2.1-NBC-FIXES to V2.2
            12156: Optimizations to WCMWorkflowEvaluator and WCMWorkflowDeletedEvaluator    
            12605: Hide annoying "Virtualisation Server not started" warnings (by making them debug)
         12707: AVM console - "snap" also allows tag and description to be specified
   12979: Build/test fix
   ___________________________________________________________________
   Modified: svn:mergeinfo
      Merged /alfresco/BRANCHES/DEV/V2.2.1-NBC-FIXES:r12156
      Merged /alfresco/BRANCHES/V2.1-A:r8562,8694
      Merged /alfresco/BRANCHES/V3.0:r12920
      Merged /alfresco/BRANCHES/V2.2:r12456-12457,12470,12605,12707
      Merged /alfresco/BRANCHES/V3.1:r12943,12948,12965,12974,12976,12978-12979
git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@13544 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
		
	
		
			
				
	
	
		
			74 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
			
		
		
	
	
			74 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
| package org.alfresco.repo.security.person;
 | |
| 
 | |
| import org.alfresco.util.Pair;
 | |
| 
 | |
| public class UserNameMatcherImpl implements UserNameMatcher
 | |
| {
 | |
|     private boolean userNamesAreCaseSensitive = false;
 | |
| 
 | |
|     private boolean domainNamesAreCaseSensitive = false;
 | |
| 
 | |
|     private String domainSeparator = "";
 | |
|     
 | |
|     public boolean getUserNamesAreCaseSensitive()
 | |
|     {
 | |
|         return userNamesAreCaseSensitive;
 | |
|     }
 | |
| 
 | |
|     public void setUserNamesAreCaseSensitive(boolean userNamesAreCaseSensitive)
 | |
|     {
 | |
|         this.userNamesAreCaseSensitive = userNamesAreCaseSensitive;
 | |
|     }
 | |
| 
 | |
|     public boolean getDomainNamesAreCaseSensitive()
 | |
|     {
 | |
|         return domainNamesAreCaseSensitive;
 | |
|     }
 | |
| 
 | |
|     public void setDomainNamesAreCaseSensitive(boolean domainNamesAreCaseSensitive)
 | |
|     {
 | |
|         this.domainNamesAreCaseSensitive = domainNamesAreCaseSensitive;
 | |
|     }
 | |
| 
 | |
|     public String getDomainSeparator()
 | |
|     {
 | |
|         return domainSeparator;
 | |
|     }
 | |
| 
 | |
|     public void setDomainSeparator(String domainSeparator)
 | |
|     {
 | |
|         this.domainSeparator = domainSeparator;
 | |
|     }
 | |
| 
 | |
|     public boolean matches(String realUserName, String searchUserName)
 | |
|     {
 | |
|         // note: domain string may be empty
 | |
|         Pair<String, String> real = splitByDomain(realUserName, domainSeparator);
 | |
|         Pair<String, String> search = splitByDomain(searchUserName, domainSeparator);
 | |
| 
 | |
|         return (((userNamesAreCaseSensitive && (real.getFirst().equals(search.getFirst()))) || (!userNamesAreCaseSensitive && (real.getFirst().equalsIgnoreCase(search
 | |
|                 .getFirst())))) &&
 | |
| 
 | |
|         ((domainNamesAreCaseSensitive && (real.getSecond().equals(search.getSecond()))) || (!domainNamesAreCaseSensitive && (real.getSecond().equalsIgnoreCase(search
 | |
|                 .getSecond())))));
 | |
|     }
 | |
| 
 | |
|     // Trailing domain only
 | |
|     private Pair<String, String> splitByDomain(String name, String domainSeparator)
 | |
|     {
 | |
|         int idx = name.lastIndexOf(domainSeparator);
 | |
|         if (idx != -1)
 | |
|         {
 | |
|             if ((idx + 1) > name.length())
 | |
|             {
 | |
|                 return new Pair<String, String>(name.substring(0, idx), "");
 | |
|             }
 | |
|             else
 | |
|             {
 | |
|                 return new Pair<String, String>(name.substring(0, idx), name.substring(idx + 1));
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         return new Pair<String, String>(name, "");
 | |
|     }
 | |
| } |