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.actions;
21
22
23 import org.apache.directory.api.asn1.DecoderException;
24 import org.apache.directory.api.asn1.ber.Asn1Container;
25 import org.apache.directory.api.asn1.ber.Asn1Decoder;
26 import org.apache.directory.api.asn1.ber.grammar.GrammarAction;
27 import org.apache.directory.api.asn1.ber.tlv.TLV;
28 import org.apache.directory.api.i18n.I18n;
29 import org.apache.directory.shared.kerberos.codec.hostAddresses.HostAddressesContainer;
30 import org.apache.directory.shared.kerberos.components.HostAddresses;
31 import org.slf4j.Logger;
32 import org.slf4j.LoggerFactory;
33
34
35
36
37
38
39
40 public abstract class AbstractReadHostAddresses<E extends Asn1Container> extends GrammarAction<E>
41 {
42
43 private static final Logger LOG = LoggerFactory.getLogger( AbstractReadHostAddresses.class );
44
45
46 private static final boolean IS_DEBUG = LOG.isDebugEnabled();
47
48
49
50
51
52 public AbstractReadHostAddresses( String name )
53 {
54 super( name );
55 }
56
57
58
59
60
61
62
63
64 protected abstract void setHostAddresses( HostAddresses hostAddresses, E container );
65
66
67
68
69
70 public final void action( E container ) throws DecoderException
71 {
72 TLV tlv = container.getCurrentTLV();
73
74
75 if ( tlv.getLength() == 0 )
76 {
77 LOG.error( I18n.err( I18n.ERR_01308_ZERO_LENGTH_TLV ) );
78
79
80 throw new DecoderException( I18n.err( I18n.ERR_01309_EMPTY_TLV ) );
81 }
82
83
84 HostAddressesContaineresses/HostAddressesContainer.html#HostAddressesContainer">HostAddressesContainer hostAddressesContainer = new HostAddressesContainer();
85
86
87 hostAddressesContainer.setStream( container.getStream() );
88
89
90 Asn1Decoder.decode( container.getStream(), hostAddressesContainer );
91
92
93 HostAddresses hostAddresses = hostAddressesContainer.getHostAddresses();
94 setHostAddresses( hostAddresses, container );
95
96
97 tlv.setExpectedLength( tlv.getExpectedLength() - tlv.getLength() );
98
99
100 container.updateParent();
101
102 if ( IS_DEBUG )
103 {
104 LOG.debug( "HostAddresses : {}", hostAddresses );
105 }
106 }
107 }