001/*
002 * Licensed under the Apache License, Version 2.0 (the "License");
003 * you may not use this file except in compliance with the License.
004 * You may obtain a copy of the License at
005 *
006 *     http://www.apache.org/licenses/LICENSE-2.0
007 *
008 * Unless required by applicable law or agreed to in writing, software
009 * distributed under the License is distributed on an "AS IS" BASIS,
010 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
011 * See the License for the specific language governing permissions and
012 * limitations under the License.
013 */
014package org.gbif.ws;
015
016import java.net.URI;
017
018import org.springframework.http.HttpStatus;
019
020/**
021 * A HTTP 404 (Not Found) exception.
022 */
023public class NotFoundException extends WebApplicationException {
024
025  /**
026   * The URI that cannot be found. Required.
027   */
028  private final URI notFoundUri;
029
030  /**
031   * Create a HTTP 404 (Not Found) exception.
032   *
033   * @param message     the String that is the entity of the 404 response.
034   * @param notFoundUri the URI that cannot be found.
035   */
036  public NotFoundException(String message, URI notFoundUri) {
037    super(message + " for uri: " + notFoundUri, HttpStatus.NOT_FOUND);
038    this.notFoundUri = notFoundUri;
039  }
040
041  /**
042   * Get the URI that is not found.
043   */
044  public URI getNotFoundUri() {
045    return notFoundUri;
046  }
047}