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

com.datastax.driver.core.exceptions.AlreadyExistsException Maven / Gradle / Ivy

/*
 * Copyright DataStax, Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package com.datastax.driver.core.exceptions;

import com.datastax.driver.core.EndPoint;
import java.net.InetAddress;
import java.net.InetSocketAddress;

/** Exception thrown when a query attempts to create a keyspace or table that already exists. */
public class AlreadyExistsException extends QueryValidationException
    implements CoordinatorException {

  private static final long serialVersionUID = 0;

  private final EndPoint endPoint;
  private final String keyspace;
  private final String table;

  public AlreadyExistsException(String keyspace, String table) {
    this(null, keyspace, table);
  }

  public AlreadyExistsException(EndPoint endPoint, String keyspace, String table) {
    super(makeMsg(keyspace, table));
    this.endPoint = endPoint;
    this.keyspace = keyspace;
    this.table = table;
  }

  private AlreadyExistsException(
      EndPoint endPoint, String msg, Throwable cause, String keyspace, String table) {
    super(msg, cause);
    this.endPoint = endPoint;
    this.keyspace = keyspace;
    this.table = table;
  }

  private static String makeMsg(String keyspace, String table) {
    if (table.isEmpty()) return String.format("Keyspace %s already exists", keyspace);
    else return String.format("Table %s.%s already exists", keyspace, table);
  }

  @Override
  public EndPoint getEndPoint() {
    return endPoint;
  }

  @Override
  @Deprecated
  public InetSocketAddress getAddress() {
    return (endPoint == null) ? null : endPoint.resolve();
  }

  @Override
  @Deprecated
  public InetAddress getHost() {
    return (endPoint == null) ? null : endPoint.resolve().getAddress();
  }

  /**
   * Returns whether the query yielding this exception was a table creation attempt.
   *
   * @return {@code true} if this exception is raised following a table creation attempt, {@code
   *     false} if it was a keyspace creation attempt.
   */
  public boolean wasTableCreation() {
    return !table.isEmpty();
  }

  /**
   * The name of keyspace that either already exists or is home to the table that already exists.
   *
   * @return a keyspace name that is either the keyspace whose creation attempt failed because a
   *     keyspace of the same name already exists (in that case, {@link #table} will return {@code
   *     null}), or the keyspace of the table creation attempt (in which case {@link #table} will
   *     return the name of said table).
   */
  public String getKeyspace() {
    return keyspace;
  }

  /**
   * If the failed creation was a table creation, the name of the table that already exists.
   *
   * @return the name of table whose creation attempt failed because a table of this name already
   *     exists, or {@code null} if the query was a keyspace creation query.
   */
  public String getTable() {
    return table.isEmpty() ? null : table;
  }

  @Override
  public DriverException copy() {
    return new AlreadyExistsException(getEndPoint(), getMessage(), this, keyspace, table);
  }

  /**
   * Create a copy of this exception with a nicer stack trace, and including the coordinator address
   * that caused this exception to be raised.
   *
   * 

This method is mainly intended for internal use by the driver and exists mainly because: * *

    *
  1. the original exception was decoded from a response frame and at that time, the * coordinator address was not available; and *
  2. the newly-created exception will refer to the current thread in its stack trace, which * generally yields a more user-friendly stack trace that the original one. *
* * @param endPoint The full address of the host that caused this exception to be thrown. * @return a copy/clone of this exception, but with the given host address instead of the original * one. */ public AlreadyExistsException copy(EndPoint endPoint) { return new AlreadyExistsException(endPoint, getMessage(), this, keyspace, table); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy