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

org.apache.hadoop.hbase.quotas.SpaceLimitingException Maven / Gradle / Ivy

There is a newer version: 3.0.0-beta-1
Show newest version
/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to you 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 org.apache.hadoop.hbase.quotas;


import org.apache.yetus.audience.InterfaceAudience;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * An Exception that is thrown when a space quota is in violation.
 */
@InterfaceAudience.Public
public class SpaceLimitingException extends QuotaExceededException {
  private static final long serialVersionUID = 2319438922387583600L;
  private static final Logger LOG = LoggerFactory.getLogger(SpaceLimitingException.class);
  private static final String MESSAGE_PREFIX = SpaceLimitingException.class.getName() + ": ";

  private final String policyName;

  public SpaceLimitingException(String msg) {
    super(parseMessage(msg));

    // Hack around ResponseConverter expecting to invoke a single-arg String constructor
    // on this class
    if (msg != null) {
      for (SpaceViolationPolicy definedPolicy : SpaceViolationPolicy.values()) {
        if (msg.indexOf(definedPolicy.name()) != -1) {
          policyName = definedPolicy.name();
          return;
        }
      }
    }
    policyName = null;
  }

  public SpaceLimitingException(String policyName, String msg) {
    super(msg);
    this.policyName = policyName;
  }

  public SpaceLimitingException(String policyName, String msg, Throwable e) {
    super(msg, e);
    this.policyName = policyName;
  }

  /**
   * Returns the violation policy in effect.
   *
   * @return The violation policy in effect.
   */
  public String getViolationPolicy() {
    return this.policyName;
  }

  private static String parseMessage(String originalMessage) {
    // Serialization of the exception places a duplicate class name. Try to strip that off if it
    // exists. Best effort... Looks something like:
    // "org.apache.hadoop.hbase.quotas.SpaceLimitingException: NO_INSERTS A Put is disallowed due
    // to a space quota."
    if (originalMessage != null && originalMessage.startsWith(MESSAGE_PREFIX)) {
      // If it starts with the class name, rip off the policy too.
      try {
        int index = originalMessage.indexOf(' ', MESSAGE_PREFIX.length());
        return originalMessage.substring(index + 1);
      } catch (Exception e) {
        if (LOG.isTraceEnabled()) {
          LOG.trace("Failed to trim exception message", e);
        }
      }
    }
    return originalMessage;
  }

  @Override
  public String getMessage() {
    return (policyName == null ? "(unknown policy)" : policyName) + " " + super.getMessage();
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy