Package io.netty.handler.codec.dns
Class DefaultDnsRecordDecoder
- java.lang.Object
-
- io.netty.handler.codec.dns.DefaultDnsRecordDecoder
-
- All Implemented Interfaces:
DnsRecordDecoder
public class DefaultDnsRecordDecoder extends java.lang.Object implements DnsRecordDecoder
The defaultDnsRecordDecoderimplementation.- See Also:
DefaultDnsRecordEncoder
-
-
Field Summary
-
Fields inherited from interface io.netty.handler.codec.dns.DnsRecordDecoder
DEFAULT
-
-
Constructor Summary
Constructors Modifier Constructor Description protectedDefaultDnsRecordDecoder()Creates a new instance.
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description static java.lang.StringdecodeName(ByteBuf in)Retrieves a domain name given a buffer containing a DNS packet.protected java.lang.StringdecodeName0(ByteBuf in)Retrieves a domain name given a buffer containing a DNS packet.DnsQuestiondecodeQuestion(ByteBuf in)Decodes a DNS question into its object representation.<T extends DnsRecord>
TdecodeRecord(ByteBuf in)Decodes a DNS record into its object representation.protected DnsRecorddecodeRecord(java.lang.String name, DnsRecordType type, int dnsClass, long timeToLive, ByteBuf in, int offset, int length)Decodes a record from the information decoded so far bydecodeRecord(ByteBuf).
-
-
-
Method Detail
-
decodeQuestion
public final DnsQuestion decodeQuestion(ByteBuf in) throws java.lang.Exception
Description copied from interface:DnsRecordDecoderDecodes a DNS question into its object representation.- Specified by:
decodeQuestionin interfaceDnsRecordDecoder- Parameters:
in- the input buffer which contains a DNS question at its reader index- Throws:
java.lang.Exception
-
decodeRecord
public final <T extends DnsRecord> T decodeRecord(ByteBuf in) throws java.lang.Exception
Description copied from interface:DnsRecordDecoderDecodes a DNS record into its object representation.- Specified by:
decodeRecordin interfaceDnsRecordDecoder- Parameters:
in- the input buffer which contains a DNS record at its reader index- Returns:
- the decoded record, or
nullif there are not enough data in the input buffer - Throws:
java.lang.Exception
-
decodeRecord
protected DnsRecord decodeRecord(java.lang.String name, DnsRecordType type, int dnsClass, long timeToLive, ByteBuf in, int offset, int length) throws java.lang.Exception
Decodes a record from the information decoded so far bydecodeRecord(ByteBuf).- Parameters:
name- the domain name of the recordtype- the type of the recorddnsClass- the class of the recordtimeToLive- the TTL of the recordin- theByteBufthat contains the RDATAoffset- the start offset of the RDATA ininlength- the length of the RDATA- Returns:
- a
DnsRawRecord. Override this method to decode RDATA and return other record implementation. - Throws:
java.lang.Exception
-
decodeName0
protected java.lang.String decodeName0(ByteBuf in)
Retrieves a domain name given a buffer containing a DNS packet. If the name contains a pointer, the position of the buffer will be set to directly after the pointer's index after the name has been read.- Parameters:
in- the byte buffer containing the DNS packet- Returns:
- the domain name for an entry
-
decodeName
public static java.lang.String decodeName(ByteBuf in)
Retrieves a domain name given a buffer containing a DNS packet. If the name contains a pointer, the position of the buffer will be set to directly after the pointer's index after the name has been read.- Parameters:
in- the byte buffer containing the DNS packet- Returns:
- the domain name for an entry
-
-