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.intermediateResponse;
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.TLV;
26 import org.apache.directory.api.ldap.codec.api.LdapMessageContainer;
27 import org.apache.directory.api.ldap.codec.decorators.IntermediateResponseDecorator;
28 import org.apache.directory.api.ldap.model.message.IntermediateResponse;
29 import org.apache.directory.api.util.Strings;
30 import org.slf4j.Logger;
31 import org.slf4j.LoggerFactory;
32
33
34
35
36
37
38
39
40
41
42
43
44 public class StoreIntermediateResponseValue extends GrammarAction<LdapMessageContainer<IntermediateResponseDecorator>>
45 {
46
47 private static final Logger LOG = LoggerFactory.getLogger( StoreIntermediateResponseValue.class );
48
49
50 private static final boolean IS_DEBUG = LOG.isDebugEnabled();
51
52
53
54
55
56 public StoreIntermediateResponseValue()
57 {
58 super( "Store response value" );
59 }
60
61
62
63
64
65 public void action( LdapMessageContainer<IntermediateResponseDecorator> container ) throws DecoderException
66 {
67
68 IntermediateResponse intermediateResponse = container.getMessage();
69
70
71 TLV tlv = container.getCurrentTLV();
72
73
74
75 if ( tlv.getLength() == 0 )
76 {
77 intermediateResponse.setResponseValue( Strings.EMPTY_BYTES );
78 }
79 else
80 {
81 intermediateResponse.setResponseValue( tlv.getValue().getData() );
82 }
83
84
85 container.setGrammarEndAllowed( true );
86
87 if ( IS_DEBUG )
88 {
89 LOG.debug( "Value read : {}", Strings.dumpBytes( intermediateResponse.getResponseValue() ) );
90 }
91 }
92 }