/**
* {@inheritDoc}
*/
public void action( LdapMessageContainer<SearchRequestDecorator> container ) throws DecoderException
{
SearchRequestDecorator searchRequest = container.getMessage();
TLV tlv = container.getCurrentTLV();
// Store the value.
SubstringFilter substringFilter = ( SubstringFilter ) searchRequest.getTerminalFilter();
if ( tlv.getLength() == 0 )
{
String msg = I18n.err( I18n.ERR_04020 );
LOG.error( msg );
throw new DecoderException( msg );
}
String finalValue = Strings.utf8ToString( tlv.getValue().getData() );
substringFilter.setFinalSubstrings( finalValue );
// We now have to get back to the nearest filter which is
// not terminal.
searchRequest.unstackFilters( container );
if ( IS_DEBUG )
{
LOG.debug( "Stored a any substring : {}", finalValue );
}