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.bindRequest;
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.BindRequestDecorator;
28 import org.apache.directory.api.ldap.model.message.BindRequest;
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
46
47
48
49 public class StoreSimpleAuth extends GrammarAction<LdapMessageContainer<BindRequestDecorator>>
50 {
51
52 private static final Logger LOG = LoggerFactory.getLogger( StoreSimpleAuth.class );
53
54
55 private static final boolean IS_DEBUG = LOG.isDebugEnabled();
56
57
58
59
60
61 public StoreSimpleAuth()
62 {
63 super( "Store BindRequest Simple Authentication" );
64 }
65
66
67
68
69
70 public void action( LdapMessageContainer<BindRequestDecorator> container ) throws DecoderException
71 {
72 BindRequest bindRequestMessage = container.getMessage();
73 TLV tlv = container.getCurrentTLV();
74
75
76 bindRequestMessage.setSimple( true );
77
78
79 if ( tlv.getLength() == 0 )
80 {
81 bindRequestMessage.setCredentials( Strings.EMPTY_BYTES );
82 }
83 else
84 {
85 bindRequestMessage.setCredentials( tlv.getValue().getData() );
86 }
87
88
89 container.setGrammarEndAllowed( true );
90
91 if ( IS_DEBUG )
92 {
93 LOG.debug( "The simple authentication is : {}", Strings.dumpBytes( bindRequestMessage
94 .getCredentials() ) );
95 }
96 }
97 }