All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.couchbase.client.core.deps.org.xbill.DNS.IPSECKEYRecord Maven / Gradle / Ivy

There is a newer version: 3.7.2
Show newest version
// SPDX-License-Identifier: BSD-3-Clause
// Copyright (c) 2004 Brian Wellington ([email protected])

package com.couchbase.client.core.deps.org.xbill.DNS;

import java.io.IOException;
import java.net.Inet6Address;
import java.net.InetAddress;
import com.couchbase.client.core.deps.org.xbill.DNS.utils.base64;

/**
 * IPsec Keying Material (RFC 4025)
 *
 * @author Brian Wellington
 * @see RFC 4025: A Method for Storing IPsec Keying
 *     Material in DNS
 */
public class IPSECKEYRecord extends Record {
  /**
   * Algorithm types for IPSECKEY RRs as defined in IPSECKEY
   * Resource Record Parameters.
   */
  public static class Algorithm {
    private Algorithm() {}

    /** A DSA key is present, in the format defined in [RFC2536] */
    public static final int DSA = 1;

    /** A RSA key is present, in the format defined in [RFC3110] */
    public static final int RSA = 2;

    /** An ECDSA key is present, in the format defined in [RFC6605] */
    public static final int ECDSA = 3;
  }

  /**
   * Gateway types for IPSECKEY RRs as defined in IPSECKEY
   * Resource Record Parameters.
   */
  public static class Gateway {
    private Gateway() {}

    /** No gateway is present */
    public static final int None = 0;

    /** A 4-byte IPv4 address is present */
    public static final int IPv4 = 1;

    /** A 16-byte IPv6 address is present */
    public static final int IPv6 = 2;

    /** A wire-encoded domain name is present */
    public static final int Name = 3;
  }

  private int precedence;
  private int gatewayType;
  private int algorithmType;
  private Object gateway;
  private byte[] key;

  IPSECKEYRecord() {}

  /**
   * Creates an IPSECKEY Record from the given data.
   *
   * @param precedence The record's precedence.
   * @param gatewayType The record's gateway type.
   * @param algorithmType The record's algorithm type.
   * @param gateway The record's gateway.
   * @param key The record's public key.
   */
  public IPSECKEYRecord(
      Name name,
      int dclass,
      long ttl,
      int precedence,
      int gatewayType,
      int algorithmType,
      Object gateway,
      byte[] key) {
    super(name, Type.IPSECKEY, dclass, ttl);
    this.precedence = checkU8("precedence", precedence);
    this.gatewayType = checkU8("gatewayType", gatewayType);
    this.algorithmType = checkU8("algorithmType", algorithmType);
    switch (gatewayType) {
      case Gateway.None:
        this.gateway = null;
        break;
      case Gateway.IPv4:
        if (!(gateway instanceof InetAddress)) {
          throw new IllegalArgumentException("\"gateway\" must be an IPv4 address");
        }
        this.gateway = gateway;
        break;
      case Gateway.IPv6:
        if (!(gateway instanceof Inet6Address)) {
          throw new IllegalArgumentException("\"gateway\" must be an IPv6 address");
        }
        this.gateway = gateway;
        break;
      case Gateway.Name:
        if (!(gateway instanceof Name)) {
          throw new IllegalArgumentException("\"gateway\" must be a DNS name");
        }
        this.gateway = checkName("gateway", (Name) gateway);
        break;
      default:
        throw new IllegalArgumentException("\"gatewayType\" must be between 0 and 3");
    }

    this.key = key;
  }

  @Override
  protected void rrFromWire(DNSInput in) throws IOException {
    precedence = in.readU8();
    gatewayType = in.readU8();
    algorithmType = in.readU8();
    switch (gatewayType) {
      case Gateway.None:
        gateway = null;
        break;
      case Gateway.IPv4:
        gateway = InetAddress.getByAddress(in.readByteArray(4));
        break;
      case Gateway.IPv6:
        gateway = InetAddress.getByAddress(in.readByteArray(16));
        break;
      case Gateway.Name:
        gateway = new Name(in);
        break;
      default:
        throw new WireParseException("invalid gateway type");
    }
    if (in.remaining() > 0) {
      key = in.readByteArray();
    }
  }

  @Override
  protected void rdataFromString(Tokenizer st, Name origin) throws IOException {
    precedence = st.getUInt8();
    gatewayType = st.getUInt8();
    algorithmType = st.getUInt8();
    switch (gatewayType) {
      case Gateway.None:
        String s = st.getString();
        if (!s.equals(".")) {
          throw new TextParseException("invalid gateway format");
        }
        gateway = null;
        break;
      case Gateway.IPv4:
        gateway = st.getAddress(Address.IPv4);
        break;
      case Gateway.IPv6:
        gateway = st.getAddress(Address.IPv6);
        break;
      case Gateway.Name:
        gateway = st.getName(origin);
        break;
      default:
        throw new WireParseException("invalid gateway type");
    }
    key = st.getBase64(false);
  }

  @Override
  protected String rrToString() {
    StringBuilder sb = new StringBuilder();
    sb.append(precedence);
    sb.append(" ");
    sb.append(gatewayType);
    sb.append(" ");
    sb.append(algorithmType);
    sb.append(" ");
    switch (gatewayType) {
      case Gateway.None:
        sb.append(".");
        break;
      case Gateway.IPv4:
      case Gateway.IPv6:
        InetAddress gatewayAddr = (InetAddress) gateway;
        sb.append(gatewayAddr.getHostAddress());
        break;
      case Gateway.Name:
        sb.append(gateway);
        break;
    }
    if (key != null) {
      sb.append(" ");
      sb.append(base64.toString(key));
    }
    return sb.toString();
  }

  /** Returns the record's precedence. */
  public int getPrecedence() {
    return precedence;
  }

  /** Returns the record's gateway type. */
  public int getGatewayType() {
    return gatewayType;
  }

  /** Returns the record's algorithm type. */
  public int getAlgorithmType() {
    return algorithmType;
  }

  /** Returns the record's gateway. */
  public Object getGateway() {
    return gateway;
  }

  /** Returns the record's public key */
  public byte[] getKey() {
    return key;
  }

  @Override
  protected void rrToWire(DNSOutput out, Compression c, boolean canonical) {
    out.writeU8(precedence);
    out.writeU8(gatewayType);
    out.writeU8(algorithmType);
    switch (gatewayType) {
      case Gateway.None:
        break;
      case Gateway.IPv4:
      case Gateway.IPv6:
        InetAddress gatewayAddr = (InetAddress) gateway;
        out.writeByteArray(gatewayAddr.getAddress());
        break;
      case Gateway.Name:
        Name gatewayName = (Name) gateway;
        gatewayName.toWire(out, null, canonical);
        break;
    }
    if (key != null) {
      out.writeByteArray(key);
    }
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy