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;
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.IntegerDecoder;
27 import org.apache.directory.api.asn1.ber.tlv.IntegerDecoderException;
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.LdapCodecConstants;
31 import org.apache.directory.api.ldap.codec.api.LdapMessageContainer;
32 import org.apache.directory.api.ldap.model.message.AliasDerefMode;
33 import org.apache.directory.api.ldap.model.message.SearchRequest;
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
52 public class StoreSearchRequestDerefAlias extends GrammarAction<LdapMessageContainer<SearchRequest>>
53 {
54
55 private static final Logger LOG = LoggerFactory.getLogger( StoreSearchRequestDerefAlias.class );
56
57
58
59
60 public StoreSearchRequestDerefAlias()
61 {
62 super( "Store SearchRequest derefAlias flag" );
63 }
64
65
66
67
68
69 public void action( LdapMessageContainer<SearchRequest> container ) throws DecoderException
70 {
71 SearchRequest searchRequest = container.getMessage();
72
73 TLV tlv = container.getCurrentTLV();
74
75
76 BerValue value = tlv.getValue();
77
78 try
79 {
80 int derefAliases = IntegerDecoder.parse( value, LdapCodecConstants.NEVER_DEREF_ALIASES,
81 LdapCodecConstants.DEREF_ALWAYS );
82 searchRequest.setDerefAliases( AliasDerefMode.getDerefMode( derefAliases ) );
83 }
84 catch ( IntegerDecoderException ide )
85 {
86 String msg = I18n.err( I18n.ERR_05150_BAD_DEREF_ALIAS, value.toString() );
87 LOG.error( msg );
88 throw new DecoderException( msg, ide );
89 }
90
91
92 if ( LOG.isDebugEnabled() )
93 {
94 switch ( searchRequest.getDerefAliases() )
95 {
96 case NEVER_DEREF_ALIASES:
97 LOG.debug( I18n.msg( I18n.MSG_05161_HANDLING_OBJECT_STRATEGY, "NEVER_DEREF_ALIASES" ) );
98 break;
99
100 case DEREF_IN_SEARCHING:
101 LOG.debug( I18n.msg( I18n.MSG_05161_HANDLING_OBJECT_STRATEGY, "DEREF_IN_SEARCHING" ) );
102 break;
103
104 case DEREF_FINDING_BASE_OBJ:
105 LOG.debug( I18n.msg( I18n.MSG_05161_HANDLING_OBJECT_STRATEGY, "DEREF_FINDING_BASE_OBJ" ) );
106 break;
107
108 case DEREF_ALWAYS:
109 LOG.debug( I18n.msg( I18n.MSG_05161_HANDLING_OBJECT_STRATEGY, "DEREF_ALWAYS" ) );
110 break;
111
112 default:
113 LOG.debug( I18n.msg( I18n.MSG_05161_HANDLING_OBJECT_STRATEGY, "UNKNOWN" ) );
114 }
115 }
116 }
117 }