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.searchResultEntry;
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.decorators.SearchResultEntryDecorator;
29 import org.apache.directory.api.ldap.model.exception.LdapException;
30 import org.apache.directory.api.util.Strings;
31 import org.slf4j.Logger;
32 import org.slf4j.LoggerFactory;
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48 public class AddAttributeType extends GrammarAction<LdapMessageContainer<SearchResultEntryDecorator>>
49 {
50
51 private static final Logger LOG = LoggerFactory.getLogger( AddAttributeType.class );
52
53
54 private static final boolean IS_DEBUG = LOG.isDebugEnabled();
55
56
57
58
59
60 public AddAttributeType()
61 {
62 super( "Store the AttributeType" );
63 }
64
65
66
67
68
69 public void action( LdapMessageContainer<SearchResultEntryDecorator> container ) throws DecoderException
70 {
71 SearchResultEntryDecorator searchResultEntry = container.getMessage();
72
73 TLV tlv = container.getCurrentTLV();
74
75
76 if ( tlv.getLength() == 0 )
77 {
78
79 String msg = I18n.err( I18n.ERR_04081 );
80 LOG.error( msg );
81 throw new DecoderException( msg );
82 }
83 else
84 {
85 try
86 {
87 searchResultEntry.addAttribute( tlv.getValue().getData() );
88 }
89 catch ( LdapException ine )
90 {
91 String type = Strings.utf8ToString( tlv.getValue().getData() );
92
93 String msg = "The Attribute type " + type + "is invalid : " + ine.getMessage();
94 LOG.error( "{} : {}", msg, ine.getMessage() );
95 throw new DecoderException( msg, ine );
96 }
97 }
98
99 if ( IS_DEBUG )
100 {
101 String type = Strings.utf8ToString( tlv.getValue().getData() );
102 LOG.debug( "Attribute type : {}", type );
103 }
104 }
105 }