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.ldapResult;
21
22
23 import org.apache.directory.api.asn1.ber.grammar.GrammarAction;
24 import org.apache.directory.api.asn1.ber.tlv.TLV;
25 import org.apache.directory.api.i18n.I18n;
26 import org.apache.directory.api.ldap.codec.api.LdapMessageContainer;
27 import org.apache.directory.api.ldap.model.message.LdapResult;
28 import org.apache.directory.api.ldap.model.message.Message;
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
45 public class StoreErrorMessage extends GrammarAction<LdapMessageContainer<Message>>
46 {
47
48 private static final Logger LOG = LoggerFactory.getLogger( StoreErrorMessage.class );
49
50
51
52
53 public StoreErrorMessage()
54 {
55 super( "Store error message" );
56 }
57
58
59
60
61
62 @Override
63 public void action( LdapMessageContainer<Message> container )
64 {
65
66 TLV tlv = container.getCurrentTLV();
67 String errorMessage;
68
69
70
71 if ( tlv.getLength() == 0 )
72 {
73 errorMessage = "";
74 }
75 else
76 {
77 errorMessage = Strings.utf8ToString( tlv.getValue().getData() );
78 }
79
80 LdapResult ldapResult = container.getLdapResult();
81 ldapResult.setDiagnosticMessage( errorMessage );
82
83
84 container.setGrammarEndAllowed( true );
85
86 if ( LOG.isDebugEnabled() )
87 {
88 LOG.debug( I18n.msg( I18n.MSG_05106_ERROR_MESSAGE_IS, errorMessage ) );
89 }
90 }
91 }