/*
* Jitsi, the OpenSource Java VoIP and Instant Messaging client.
*
* Copyright @ 2015 Atlassian Pty Ltd
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package net.java.sip.communicator.impl.ldap;
import net.java.sip.communicator.service.ldap.*;
/**
* Implementation of The LdapFactory, used to
* create LdapDirectory-s, LdapDirectorySettings, LdapQuery, ...
*
* @author Sebastien Mazy
*/
public class LdapFactoryImpl
implements LdapFactory
{
/**
* Required by LdapFactory interface.
* Creates an LdapDirectory based on the provided settings.
* This method will not modify the <tt>settings</tt>
* or save a reference to it, but may save a clone.
*
* @param settings settings for this new server
*
* @return a reference to the created LdapDirectory
*
* @see LdapDirectorySettings
* @see LdapFactory#createServer
*/
public LdapDirectory createServer(LdapDirectorySettings settings)
throws IllegalArgumentException
{
return new LdapDirectoryImpl(settings);
}
/**
* Required by LdapFactory interface.
* Return a new instance of LdapDirectorySettings,
* a wrapper around a directory settings
*
* @return a new instance of LdapDirectorySettings
*
* @see LdapDirectorySettings
* @see LdapFactory#createServerSettings
*/
public LdapDirectorySettings createServerSettings()
{
return new LdapDirectorySettingsImpl();
}
/**
* Required by LdapFactory interface.
* Returns an LDAP query, ready to be sent to an LdapDirectory
*
* @param query the query string, e.g. "John Doe"
*
* @return an LDAP query, ready to be sent to an LdapDirectory
*
* @see LdapQuery
* @see LdapFactory#createQuery
*/
public LdapQuery createQuery(String query)
{
return new LdapQueryImpl(query);
}
/**
* Returns an LdapSearchSettings, to use when performing a search
*
* @return an LdapSearchSettings, to use when performing a search
*/
public LdapSearchSettings createSearchSettings()
{
return new LdapSearchSettingsImpl();
}
}