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