/*
* Copyright (c) 2000, 2011, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation. Oracle designates this
* particular file as subject to the "Classpath" exception as provided
* by Oracle in the LICENSE file that accompanied this code.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
package com.sun.jndi.dns;
import java.util.Vector;
import javax.naming.*;
The ResourceRecords class represents the resource records in the
four sections of a DNS message.
The additional records section is currently ignored.
Author: Scott Seligman
/**
* The ResourceRecords class represents the resource records in the
* four sections of a DNS message.
*
* The additional records section is currently ignored.
*
* @author Scott Seligman
*/
class ResourceRecords {
// Four sections: question, answer, authority, additional.
// The question section is treated as being made up of (shortened)
// resource records, although this isn't technically how it's defined.
Vector<ResourceRecord> question = new Vector<>();
Vector<ResourceRecord> answer = new Vector<>();
Vector<ResourceRecord> authority = new Vector<>();
Vector<ResourceRecord> additional = new Vector<>();
/*
* True if these resource records are from a zone transfer. In
* that case only answer records are read (as per
* draft-ietf-dnsext-axfr-clarify-02.txt). Also, the rdata of
* those answer records is not decoded (for efficiency) except
* for SOA records.
*/
boolean zoneXfer;
/*
* Returns a representation of the resource records in a DNS message.
* Does not modify or store a reference to the msg array.
*/
ResourceRecords(byte[] msg, int msgLen, Header hdr, boolean zoneXfer)
throws NamingException {
if (zoneXfer) {
answer.ensureCapacity(8192); // an arbitrary "large" number
}
this.zoneXfer = zoneXfer;
add(msg, msgLen, hdr);
}
/*
* Returns the type field of the first answer record, or -1 if
* there are no answer records.
*/
int getFirstAnsType() {
if (answer.size() == 0) {
return -1;
}
return answer.firstElement().getType();
}
/*
* Returns the type field of the last answer record, or -1 if
* there are no answer records.
*/
int getLastAnsType() {
if (answer.size() == 0) {
return -1;
}
return answer.lastElement().getType();
}
/*
* Decodes the resource records in a DNS message and adds
* them to this object.
* Does not modify or store a reference to the msg array.
*/
void add(byte[] msg, int msgLen, Header hdr) throws NamingException {
ResourceRecord rr;
int pos = Header.HEADER_SIZE; // current offset into msg
try {
for (int i = 0; i < hdr.numQuestions; i++) {
rr = new ResourceRecord(msg, msgLen, pos, true, false);
if (!zoneXfer) {
question.addElement(rr);
}
pos += rr.size();
}
for (int i = 0; i < hdr.numAnswers; i++) {
rr = new ResourceRecord(
msg, msgLen, pos, false, !zoneXfer);
answer.addElement(rr);
pos += rr.size();
}
if (zoneXfer) {
return;
}
for (int i = 0; i < hdr.numAuthorities; i++) {
rr = new ResourceRecord(msg, msgLen, pos, false, true);
authority.addElement(rr);
pos += rr.size();
}
// The additional records section is currently ignored.
} catch (IndexOutOfBoundsException e) {
throw new CommunicationException(
"DNS error: corrupted message");
}
}
}