blob: 721bde98f71627528f48bf712b0f6f44c1ced3dc [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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
*
* https://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 org.apache.directory.api.ldap.model.schema.registries;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import org.apache.directory.api.i18n.I18n;
import org.apache.directory.api.ldap.model.exception.LdapException;
import org.apache.directory.api.ldap.model.schema.DitStructureRule;
import org.apache.directory.api.ldap.model.schema.SchemaObject;
import org.apache.directory.api.ldap.model.schema.SchemaObjectType;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* A DitStructureRule registry's service default implementation.
*
* @author <a href="mailto:dev@directory.apache.org">Apache Directory Project</a>
*/
public class DefaultDitStructureRuleRegistry extends DefaultSchemaObjectRegistry<DitStructureRule>
implements DitStructureRuleRegistry
{
/** static class logger */
private static final Logger LOG = LoggerFactory.getLogger( DefaultDitStructureRuleRegistry.class );
/** a map of DitStructureRule looked up by RuleId */
protected Map<Integer, DitStructureRule> byRuleId;
/**
* Creates a new default NormalizerRegistry instance.
*/
public DefaultDitStructureRuleRegistry()
{
super( SchemaObjectType.DIT_STRUCTURE_RULE, new OidRegistry<DitStructureRule>() );
byRuleId = new HashMap<>();
}
/**
* {@inheritDoc}
*/
@Override
public boolean contains( int ruleId )
{
return byRuleId.containsKey( ruleId );
}
/**
* {@inheritDoc}
*/
@Override
public Iterator<DitStructureRule> iterator()
{
return byRuleId.values().iterator();
}
/**
* {@inheritDoc}
*/
@Override
public Iterator<Integer> ruleIdIterator()
{
return byRuleId.keySet().iterator();
}
/**
* {@inheritDoc}
*/
@Override
public String getSchemaName( int ruleId ) throws LdapException
{
DitStructureRule ditStructureRule = byRuleId.get( ruleId );
if ( ditStructureRule != null )
{
return ditStructureRule.getSchemaName();
}
String msg = I18n.err( I18n.ERR_13729_RULE_ID_NOT_FOUND, ruleId );
if ( LOG.isWarnEnabled() )
{
LOG.warn( msg );
}
throw new LdapException( msg );
}
/**
* {@inheritDoc}
*/
@Override
public void register( DitStructureRule ditStructureRule ) throws LdapException
{
int ruleId = ditStructureRule.getRuleId();
if ( byRuleId.containsKey( ruleId ) )
{
String msg = I18n.err( I18n.ERR_13730_DIT_STRUCTURE_RULE_ALREADY_REGISTRED, ruleId );
if ( LOG.isWarnEnabled() )
{
LOG.warn( msg );
}
throw new LdapException( msg );
}
byRuleId.put( ruleId, ditStructureRule );
if ( LOG.isDebugEnabled() )
{
LOG.debug( I18n.msg( I18n.MSG_13731_REGISTRED_FOR_OID, ditStructureRule, ruleId ) );
}
}
/**
* {@inheritDoc}
*/
@Override
public DitStructureRule lookup( int ruleId ) throws LdapException
{
DitStructureRule ditStructureRule = byRuleId.get( ruleId );
if ( ditStructureRule == null )
{
String msg = I18n.err( I18n.ERR_13731_DIT_STRUCTURE_RULE_DOES_NOT_EXIST, ruleId );
if ( LOG.isDebugEnabled() )
{
LOG.debug( msg );
}
throw new LdapException( msg );
}
if ( LOG.isDebugEnabled() )
{
LOG.debug( I18n.msg( I18n.MSG_13724_FOUND_WITH_RULE_ID, ditStructureRule, ruleId ) );
}
return ditStructureRule;
}
/**
* {@inheritDoc}
*/
@Override
public void unregister( int ruleId ) throws LdapException
{
DitStructureRule ditStructureRule = byRuleId.remove( ruleId );
if ( LOG.isDebugEnabled() )
{
LOG.debug( I18n.msg( I18n.MSG_13721_REMOVED_WITH_RULE_ID, ditStructureRule, ruleId ) );
}
}
/**
* {@inheritDoc}
*/
@Override
public void unregisterSchemaElements( String schemaName )
{
if ( schemaName == null )
{
return;
}
// Loop on all the SchemaObjects stored and remove those associated
// with the give schemaName
for ( DitStructureRule ditStructureRule : this )
{
if ( schemaName.equalsIgnoreCase( ditStructureRule.getSchemaName() ) )
{
int ruleId = ditStructureRule.getRuleId();
SchemaObject removed = byRuleId.remove( ruleId );
if ( LOG.isDebugEnabled() )
{
LOG.debug( I18n.msg( I18n.MSG_13721_REMOVED_WITH_RULE_ID, removed, ruleId ) );
}
}
}
}
/**
* {@inheritDoc}
*/
@Override
public void renameSchema( String originalSchemaName, String newSchemaName )
{
// Loop on all the SchemaObjects stored and remove those associated
// with the give schemaName
for ( DitStructureRule ditStructureRule : this )
{
if ( originalSchemaName.equalsIgnoreCase( ditStructureRule.getSchemaName() ) )
{
ditStructureRule.setSchemaName( newSchemaName );
if ( LOG.isDebugEnabled() )
{
LOG.debug( I18n.msg( I18n.MSG_13722_RENAMED_SCHEMA_NAME_TO, ditStructureRule, newSchemaName ) );
}
}
}
}
/**
* {@inheritDoc}
*/
@Override
public DefaultDitStructureRuleRegistry copy()
{
DefaultDitStructureRuleRegistry copy = new DefaultDitStructureRuleRegistry();
// Copy the base data
copy.copy( this );
return copy;
}
}