mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-06-30 18:15:39 +00:00
- undeleted and reinstated use of org.alfresco.util.Pair - undeleted org.alfresco.util.PropertyCheck which is used in the deployment code. - undeleted other org.alfresco.util.* classes which probably should never have been moved to spring surf. git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@19312 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
92 lines
3.0 KiB
Java
92 lines
3.0 KiB
Java
/*
|
|
* Copyright (C) 2005-2010 Alfresco Software Limited.
|
|
*
|
|
* This file is part of Alfresco
|
|
*
|
|
* Alfresco is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Lesser General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* Alfresco is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
* along with Alfresco. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
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, "");
|
|
}
|
|
} |