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.request.bind;
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.BindRequest;
28 import org.apache.directory.api.util.Strings;
29 import org.slf4j.Logger;
30 import org.slf4j.LoggerFactory;
31
32
33
34
35
36
37
38
39
40
41
42 public class StoreSaslMechanism extends GrammarAction<LdapMessageContainer<BindRequest>>
43 {
44
45 private static final Logger LOG = LoggerFactory.getLogger( StoreSaslMechanism.class );
46
47
48
49
50 public StoreSaslMechanism()
51 {
52 super( "Store SASL mechanism" );
53 }
54
55
56
57
58
59 @Override
60 public void action( LdapMessageContainer<BindRequest> container )
61 {
62 BindRequest bindRequestMessage = container.getMessage();
63 TLV tlv = container.getCurrentTLV();
64
65
66
67 if ( tlv.getLength() == 0 )
68 {
69 bindRequestMessage.setSaslMechanism( "" );
70 }
71 else
72 {
73 bindRequestMessage.setSaslMechanism( Strings.utf8ToString( tlv.getValue().getData() ) );
74 }
75
76
77 container.setGrammarEndAllowed( true );
78
79 if ( LOG.isDebugEnabled() )
80 {
81 LOG.debug( I18n.msg( I18n.MSG_05118_THE_SASL_MECHANISM_IS, bindRequestMessage.getSaslMechanism() ) );
82 }
83 }
84 }