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.searchRequest.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.asn1.ber.tlv.BerValue;
26 import org.apache.directory.api.asn1.ber.tlv.BooleanDecoder;
27 import org.apache.directory.api.asn1.ber.tlv.BooleanDecoderException;
28 import org.apache.directory.api.asn1.ber.tlv.TLV;
29 import org.apache.directory.api.i18n.I18n;
30 import org.apache.directory.api.ldap.codec.api.LdapMessageContainer;
31 import org.apache.directory.api.ldap.codec.decorators.SearchRequestDecorator;
32 import org.apache.directory.api.ldap.codec.search.ExtensibleMatchFilter;
33 import org.apache.directory.api.util.Strings;
34 import org.slf4j.Logger;
35 import org.slf4j.LoggerFactory;
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51 public class StoreMatchingRuleDnAttributes extends GrammarAction<LdapMessageContainer<SearchRequestDecorator>>
52 {
53
54 private static final Logger LOG = LoggerFactory.getLogger( StoreMatchingRuleDnAttributes.class );
55
56
57 private static final boolean IS_DEBUG = LOG.isDebugEnabled();
58
59
60
61
62
63 public StoreMatchingRuleDnAttributes()
64 {
65 super( "Store matchingRuleAssertion dnAttributes" );
66 }
67
68
69
70
71
72 public void action( LdapMessageContainer<SearchRequestDecorator> container ) throws DecoderException
73 {
74 SearchRequestDecorator searchRequest = container.getMessage();
75
76 TLV tlv = container.getCurrentTLV();
77
78
79 ExtensibleMatchFilter extensibleMatchFilter = ( ExtensibleMatchFilter ) searchRequest.getTerminalFilter();
80
81
82
83
84
85
86
87 BerValue value = tlv.getValue();
88
89 try
90 {
91 extensibleMatchFilter.setDnAttributes( BooleanDecoder.parse( value ) );
92 }
93 catch ( BooleanDecoderException bde )
94 {
95 LOG.error( I18n
96 .err( I18n.ERR_04110, Strings.dumpBytes( value.getData() ), bde.getMessage() ) );
97
98 throw new DecoderException( bde.getMessage(), bde );
99 }
100
101 if ( IS_DEBUG )
102 {
103 LOG.debug( "Dn Attributes : {}", Boolean.valueOf( extensibleMatchFilter.isDnAttributes() ) );
104 }
105
106
107 searchRequest.unstackFilters( container );
108 }
109 }