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.bindResponse;
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.BindResponseDecorator;
28 import org.apache.directory.api.ldap.model.message.BindResponse;
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 public class StoreServerSASLCreds extends GrammarAction<LdapMessageContainer<BindResponseDecorator>>
44 {
45
46 private static final Logger LOG = LoggerFactory.getLogger( StoreServerSASLCreds.class );
47
48
49 private static final boolean IS_DEBUG = LOG.isDebugEnabled();
50
51
52
53
54
55 public StoreServerSASLCreds()
56 {
57 super( "Store server sasl credentials value" );
58 }
59
60
61
62
63
64 public void action( LdapMessageContainer<BindResponseDecorator> container ) throws DecoderException
65 {
66
67 TLV tlv = container.getCurrentTLV();
68
69
70
71 byte[] serverSaslCreds;
72
73 if ( tlv.getLength() == 0 )
74 {
75 serverSaslCreds = Strings.EMPTY_BYTES;
76 }
77 else
78 {
79 serverSaslCreds = tlv.getValue().getData();
80 }
81
82 BindResponse response = container.getMessage();
83 response.setServerSaslCreds( serverSaslCreds );
84
85
86 container.setGrammarEndAllowed( true );
87
88 if ( IS_DEBUG )
89 {
90 LOG.debug( "The SASL credentials value is : {}", Strings.dumpBytes( serverSaslCreds ) );
91 }
92 }
93 }