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.addRequest;
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.LdapMessageContainer;
28 import org.apache.directory.api.ldap.codec.api.ResponseCarryingException;
29 import org.apache.directory.api.ldap.codec.decorators.AddRequestDecorator;
30 import org.apache.directory.api.ldap.model.exception.LdapException;
31 import org.apache.directory.api.ldap.model.message.AddResponseImpl;
32 import org.apache.directory.api.ldap.model.message.ResultCodeEnum;
33 import org.apache.directory.api.util.Strings;
34 import org.slf4j.Logger;
35 import org.slf4j.LoggerFactory;
36
37
38
39
40
41
42
43
44
45
46
47 public class AddAddRequestAttributeType extends GrammarAction<LdapMessageContainer<AddRequestDecorator>>
48 {
49
50 private static final Logger LOG = LoggerFactory.getLogger( AddAddRequestAttributeType.class );
51
52
53 private static final boolean IS_DEBUG = LOG.isDebugEnabled();
54
55
56
57
58
59 public AddAddRequestAttributeType()
60 {
61 super( "Store attribute type" );
62 }
63
64
65
66
67
68 public void action( LdapMessageContainer<AddRequestDecorator> container ) throws DecoderException
69 {
70 AddRequestDecorator addRequest = container.getMessage();
71
72 TLV tlv = container.getCurrentTLV();
73
74
75 if ( tlv.getLength() == 0 )
76 {
77 String msg = I18n.err( I18n.ERR_04086 );
78 LOG.error( msg );
79
80 AddResponseImpl response = new AddResponseImpl( addRequest.getMessageId() );
81
82 throw new ResponseCarryingException( msg, response, ResultCodeEnum.INVALID_ATTRIBUTE_SYNTAX,
83 addRequest.getEntry().getDn(), null );
84 }
85
86 String type = Strings.utf8ToString( tlv.getValue().getData() );
87
88 try
89 {
90 addRequest.addAttributeType( type );
91 }
92 catch ( LdapException ne )
93 {
94 String msg = I18n.err( I18n.ERR_04087 );
95 LOG.error( msg );
96
97 AddResponseImpl response = new AddResponseImpl( addRequest.getMessageId() );
98 throw new ResponseCarryingException( msg, response, ResultCodeEnum.INVALID_ATTRIBUTE_SYNTAX,
99 addRequest.getEntry().getDn(), ne );
100 }
101
102 if ( IS_DEBUG )
103 {
104 LOG.debug( "Adding type {}", type );
105 }
106 }
107 }