mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-07-07 18:25:23 +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, "");
|
|
}
|
|
} |