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

org.apache.olingo.server.api.ODataLibraryException Maven / Gradle / Ivy

/*
 * 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.olingo.server.api;

import java.util.Arrays;
import java.util.Formatter;
import java.util.Locale;
import java.util.MissingFormatArgumentException;
import java.util.MissingResourceException;
import java.util.ResourceBundle;

import org.apache.olingo.commons.api.ex.ODataException;

/**
 * Abstract superclass of all translatable server exceptions.
 */
public abstract class ODataLibraryException extends ODataException {

  private static final long serialVersionUID = -1210541002198287561L;
  private static final Locale DEFAULT_LOCALE = Locale.ENGLISH;

  protected static final String DEFAULT_SERVER_BUNDLE_NAME = "server-core-exceptions-i18n";

  /** Key for the exception text in the resource bundle. */
  public interface MessageKey {
    /** Gets this key. */
    String getKey();
  }

  private MessageKey messageKey;
  private Object[] parameters;

  protected ODataLibraryException(final String developmentMessage, final MessageKey messageKey,
      final String... parameters) {
    super(developmentMessage);
    this.messageKey = messageKey;
    this.parameters = parameters;
  }

  protected ODataLibraryException(final String developmentMessage, final Throwable cause,
      final MessageKey messageKey,
      final String... parameters) {
    super(developmentMessage, cause);
    this.messageKey = messageKey;
    this.parameters = parameters;
  }

  @Override
  public String getLocalizedMessage() {
    return getTranslatedMessage(DEFAULT_LOCALE).getMessage();
  }

  @Override
  public String toString() {
    return getMessage();
  }

  /** Gets the message key. */
  public MessageKey getMessageKey() {
    return messageKey;
  }

  /**
   * Gets the translated message text for a given locale (or the default locale if not available),
   * returning the developer message text if none is found.
   * @param locale the preferred {@link Locale}
   * @return the error message
   */
  public ODataErrorMessage getTranslatedMessage(final Locale locale) {
    if (messageKey == null) {
      return new ODataErrorMessage(getMessage(), DEFAULT_LOCALE);
    }
    ResourceBundle bundle = createResourceBundle(locale);
    if (bundle == null) {
      return new ODataErrorMessage(getMessage(), DEFAULT_LOCALE);
    }

    return buildMessage(bundle, locale);
  }

  /**
   * 

Gets the name of the {@link ResourceBundle} containing the exception texts.

*

The key for an exception text is the concatenation of the exception-class name and * the {@link MessageKey}, separated by a dot.

* @return the name of the resource bundle */ protected abstract String getBundleName(); private ResourceBundle createResourceBundle(final Locale locale) { try { return ResourceBundle.getBundle(getBundleName(), locale == null ? DEFAULT_LOCALE : locale); } catch (final MissingResourceException e) { return null; } } private ODataErrorMessage buildMessage(final ResourceBundle bundle, final Locale locale) { String message = null; StringBuilder builder = new StringBuilder(); Formatter f = new Formatter(builder, locale); try { message = bundle.getString(getClass().getSimpleName() + '.' + messageKey.getKey()); f.format(message, parameters); Locale usedLocale = bundle.getLocale(); if (Locale.ROOT.equals(usedLocale)) { usedLocale = DEFAULT_LOCALE; } return new ODataErrorMessage(builder.toString(), usedLocale); } catch (MissingResourceException e) { return new ODataErrorMessage("Missing message for key '" + messageKey.getKey() + "'!", DEFAULT_LOCALE); } catch (MissingFormatArgumentException e) { return new ODataErrorMessage("Missing replacement for place holder in message '" + message + "' for following arguments '" + Arrays.toString(parameters) + "'!", DEFAULT_LOCALE); }finally{ f.close(); } } /** Error message text and {@link Locale} used for it. */ public static class ODataErrorMessage { private String message; private Locale locale; public ODataErrorMessage(final String message, final Locale usedLocale) { this.message = message; locale = usedLocale; } /** Gets the message text. */ public String getMessage() { return message; } /** Gets the {@link Locale} used for this message. */ public Locale getLocale() { return locale; } } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy