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;
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.LdapMessageContainer;
31 import org.apache.directory.api.ldap.codec.decorators.SearchRequestDecorator;
32 import org.apache.directory.api.ldap.model.message.SearchRequest;
33 import org.slf4j.Logger;
34 import org.slf4j.LoggerFactory;
35
36
37
38
39
40
41
42
43
44
45
46
47 public class StoreSearchRequestTimeLimit extends GrammarAction<LdapMessageContainer<SearchRequestDecorator>>
48 {
49
50 private static final Logger LOG = LoggerFactory.getLogger( StoreSearchRequestTimeLimit.class );
51
52
53 private static final boolean IS_DEBUG = LOG.isDebugEnabled();
54
55
56
57
58
59 public StoreSearchRequestTimeLimit()
60 {
61 super( "Store SearchRequest timeLimit" );
62 }
63
64
65
66
67
68 public void action( LdapMessageContainer<SearchRequestDecorator> container ) throws DecoderException
69 {
70 SearchRequest searchRequest = container.getMessage().getDecorated();
71
72 TLV tlv = container.getCurrentTLV();
73
74
75
76 BerValue value = tlv.getValue();
77
78 int timeLimit = 0;
79
80 try
81 {
82 timeLimit = IntegerDecoder.parse( value, 0, Integer.MAX_VALUE );
83 }
84 catch ( IntegerDecoderException ide )
85 {
86 String msg = I18n.err( I18n.ERR_04104, value.toString() );
87 LOG.error( msg );
88 throw new DecoderException( msg );
89 }
90
91 searchRequest.setTimeLimit( timeLimit );
92
93 if ( IS_DEBUG )
94 {
95 LOG.debug( "The timeLimit value is set to {} seconds", Integer.valueOf( timeLimit ) );
96 }
97 }
98 }