1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20 package org.apache.directory.shared.kerberos.codec.etypeInfo2.actions;
21
22
23 import org.apache.directory.api.asn1.DecoderException;
24 import org.apache.directory.api.asn1.ber.Asn1Decoder;
25 import org.apache.directory.api.asn1.ber.grammar.GrammarAction;
26 import org.apache.directory.api.asn1.ber.tlv.TLV;
27 import org.apache.directory.api.i18n.I18n;
28 import org.apache.directory.shared.kerberos.codec.etypeInfo2.ETypeInfo2Container;
29 import org.apache.directory.shared.kerberos.codec.etypeInfo2Entry.ETypeInfo2EntryContainer;
30 import org.apache.directory.shared.kerberos.components.ETypeInfo2Entry;
31 import org.slf4j.Logger;
32 import org.slf4j.LoggerFactory;
33
34
35
36
37
38
39
40 public class AddETypeInfo2Entry extends GrammarAction<ETypeInfo2Container>
41 {
42
43 private static final Logger LOG = LoggerFactory.getLogger( AddETypeInfo2Entry.class );
44
45
46 private static final boolean IS_DEBUG = LOG.isDebugEnabled();
47
48
49
50
51
52 public AddETypeInfo2Entry()
53 {
54 super( "Add an ETypeInfo2Entry instance" );
55 }
56
57
58
59
60
61 public void action( ETypeInfo2Container eTypeInfo2Container ) throws DecoderException
62 {
63 TLV tlv = eTypeInfo2Container.getCurrentTLV();
64
65
66 if ( tlv.getLength() == 0 )
67 {
68 LOG.error( I18n.err( I18n.ERR_01308_ZERO_LENGTH_TLV ) );
69
70
71 throw new DecoderException( I18n.err( I18n.ERR_01309_EMPTY_TLV ) );
72 }
73
74
75 ETypeInfo2EntryContainer2Entry/ETypeInfo2EntryContainer.html#ETypeInfo2EntryContainer">ETypeInfo2EntryContainer etypeInfo2EntryContainer = new ETypeInfo2EntryContainer();
76 etypeInfo2EntryContainer.setStream( eTypeInfo2Container.getStream() );
77
78
79
80 eTypeInfo2Container.rewind();
81
82
83 Asn1Decoder.decode( eTypeInfo2Container.getStream(), etypeInfo2EntryContainer );
84
85
86 tlv.setExpectedLength( tlv.getExpectedLength() - tlv.getLength() );
87
88
89 eTypeInfo2Container.updateParent();
90
91
92 ETypeInfo2Entry etypeInfo2Entry = etypeInfo2EntryContainer.getETypeInfo2Entry();
93 eTypeInfo2Container.addEtypeInfo2Entry( etypeInfo2Entry );
94
95 if ( IS_DEBUG )
96 {
97 LOG.debug( "ETYPE-INFO2-ENTRY added : {}", etypeInfo2Entry );
98 }
99
100 eTypeInfo2Container.setGrammarEndAllowed( true );
101 }
102 }