/*
* Copyright (c) 2011-2019 Contributors to the Eclipse Foundation
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License 2.0 which is available at
* http://www.eclipse.org/legal/epl-2.0, or the Apache License, Version 2.0
* which is available at https://www.apache.org/licenses/LICENSE-2.0.
*
* SPDX-License-Identifier: EPL-2.0 OR Apache-2.0
*/
package io.vertx.core.dns;
import io.vertx.codegen.annotations.VertxGen;
Represents the possible response codes a server may send after receiving a
query. A response code of 0 indicates no error.
/**
* Represents the possible response codes a server may send after receiving a
* query. A response code of 0 indicates no error.
*
*/
@VertxGen
public enum DnsResponseCode {
ID 0, no error
/**
* ID 0, no error
*/
NOERROR(0, "no error"),
ID 1, format error
/**
* ID 1, format error
*/
FORMERROR(1, "format error"),
ID 2, server failure
/**
* ID 2, server failure
*/
SERVFAIL(2, "server failure"),
ID 3, name error
/**
* ID 3, name error
*/
NXDOMAIN(3, "name error"),
ID 4, not implemented
/**
* ID 4, not implemented
*/
NOTIMPL(4, "not implemented"),
ID 5, operation refused
/**
* ID 5, operation refused
*/
REFUSED(5, "operation refused"),
ID 6, domain name should not exist
/**
* ID 6, domain name should not exist
*/
YXDOMAIN(6, "domain name should not exist"),
ID 7, resource record set should not exist
/**
* ID 7, resource record set should not exist
*/
YXRRSET(7, "resource record set should not exist"),
ID 8, rrset does not exist
/**
* ID 8, rrset does not exist
*/
NXRRSET(8, "rrset does not exist"),
ID 9, not authoritative for zone
/**
* ID 9, not authoritative for zone
*/
NOTAUTH(9, "not authoritative for zone"),
ID 10, name not in zone
/**
* ID 10, name not in zone
*/
NOTZONE(10, "name not in zone"),
ID 11, bad extension mechanism for version
/**
* ID 11, bad extension mechanism for version
*/
BADVERS(11, "bad extension mechanism for version"),
ID 12, bad signature
/**
* ID 12, bad signature
*/
BADSIG(12, "bad signature"),
ID 13, bad key
/**
* ID 13, bad key
*/
BADKEY(13, "bad key"),
ID 14, bad timestamp
/**
* ID 14, bad timestamp
*/
BADTIME(14, "bad timestamp");
private final int errorCode;
private final String message;
Returns the DnsResponseCode
that corresponds with the given responseCode
. Params: - responseCode –
the error code's id
Returns: corresponding DnsResponseCode
/**
* Returns the {@link io.vertx.core.dns.DnsResponseCode} that corresponds with the given
* {@code responseCode}.
*
* @param responseCode
* the error code's id
* @return corresponding {@link io.vertx.core.dns.DnsResponseCode}
*/
public static DnsResponseCode valueOf(int responseCode) {
DnsResponseCode[] errors = DnsResponseCode.values();
for (DnsResponseCode e : errors) {
if (e.errorCode == responseCode) {
return e;
}
}
return null;
}
private DnsResponseCode(int errorCode, String message) {
this.errorCode = errorCode;
this.message = message;
}
Returns the error code for this DnsResponseCode
. /**
* Returns the error code for this {@link io.vertx.core.dns.DnsResponseCode}.
*/
public int code() {
return errorCode;
}
Returns a formatted error message for this DnsResponseCode
. /**
* Returns a formatted error message for this {@link io.vertx.core.dns.DnsResponseCode}.
*/
@Override
public String toString() {
return name() + ": type " + errorCode + ", " + message;
}
}