1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20 package org.apache.directory.api.ldap.codec.actions.request.search.filter;
21
22
23 import org.apache.directory.api.asn1.DecoderException;
24 import org.apache.directory.api.asn1.ber.grammar.GrammarAction;
25 import org.apache.directory.api.i18n.I18n;
26 import org.apache.directory.api.ldap.codec.api.LdapCodecConstants;
27 import org.apache.directory.api.ldap.codec.api.LdapMessageContainer;
28 import org.apache.directory.api.ldap.codec.search.AttributeValueAssertionFilter;
29 import org.apache.directory.api.ldap.codec.search.Filter;
30 import org.apache.directory.api.ldap.model.message.SearchRequest;
31 import org.slf4j.Logger;
32 import org.slf4j.LoggerFactory;
33
34
35
36
37
38
39
40 public class InitApproxMatchFilter extends GrammarAction<LdapMessageContainer<SearchRequest>>
41 {
42
43 private static final Logger LOG = LoggerFactory.getLogger( InitApproxMatchFilter.class );
44
45
46
47
48 public InitApproxMatchFilter()
49 {
50 super( "Init Approx Match filter Value" );
51 }
52
53
54
55
56
57 public void action( LdapMessageContainer<SearchRequest> container ) throws DecoderException
58 {
59
60 Filter filter = new AttributeValueAssertionFilter( container.getCurrentTLV().getId(),
61 LdapCodecConstants.APPROX_MATCH_FILTER );
62
63 container.addCurrentFilter( filter );
64
65
66
67 container.setTerminalFilter( filter );
68
69 if ( LOG.isDebugEnabled() )
70 {
71 LOG.debug( I18n.msg( I18n.MSG_05142_INITIALIZE_APPROX_FILTER ) );
72 }
73 }
74 }