org.dmfs.httpessentials.HttpStatus Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of http-client-essentials Show documentation
Show all versions of http-client-essentials Show documentation
A lightweight http client model.
/*
* Copyright 2017 dmfs GmbH
*
*
* 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 org.dmfs.httpessentials;
import org.dmfs.httpessentials.status.NoneHttpStatus;
import org.dmfs.httpessentials.status.SimpleHttpStatus;
/**
* Interface of an HTTP status. Instances must be immutable. By convention, all instances MUST return the status code when {@link #hashCode()} is called.
*
* @author Marten Gajda
*/
public interface HttpStatus
{
/*
* Dummy HttpStatus for internal use.
*/
/**
* A dummy HTTP status which can be used to return "no status". This is the null
object.
*/
HttpStatus NONE = new NoneHttpStatus();
/*
* 1xx Informational status codes, see http://tools.ietf.org/html/rfc7231#section-6.2
*/
/**
* HTTP status: 100 Continue
*/
HttpStatus CONTINUE = new SimpleHttpStatus(100, "Continue");
/**
* HTTP status: 101 Switching Protocols
*/
HttpStatus SWITCHING_PROTOCOLS = new SimpleHttpStatus(101, "Switching Protocols");
/**
* HTTP status: 102 Processing (WebDAV) Note that this has been removed from the WebDAV
* specification in RFC 4918, see RFC 4918, section 21.4
*/
HttpStatus PROCESSING = new SimpleHttpStatus(102, "Processing");
/*
* 2xx Successful status codes, see: http://tools.ietf.org/html/rfc7231#section-6.3
*/
/**
* HTTP status: 200 OK
*/
HttpStatus OK = new SimpleHttpStatus(200, "OK");
/**
* HTTP status: 201 Created
*/
HttpStatus CREATED = new SimpleHttpStatus(201, "CREATED");
/**
* HTTP status: 202 Accepted
*/
HttpStatus ACCEPTED = new SimpleHttpStatus(202, "Accepted");
/**
* HTTP status: 203 Non-Authoritative Information
*/
HttpStatus NON_AUTHORITATIVE_INFORMATION = new SimpleHttpStatus(203,
"Non-Authoritative Information");
/**
* HTTP status: 204 No Content
*/
HttpStatus NO_CONTENT = new SimpleHttpStatus(204, "No Content");
/**
* HTTP status: 205 Reset Content
*/
HttpStatus RESET_CONTENT = new SimpleHttpStatus(205, "Reset Content");
/**
* HTTP status: 206 Partial Content
*/
HttpStatus PARTIAL_CONTENT = new SimpleHttpStatus(206, "Partial Content");
/**
* HTTP status: 207 Multistatus (WebDAV)
*/
HttpStatus MULTISTATUS = new SimpleHttpStatus(207, "Multistatus");
/*
* 3xx Redirection status codes, see: http://tools.ietf.org/html/rfc2068#section-10.3
*/
/**
* HTTP status: 300 Multiple Choices
*/
HttpStatus MULTIPLE_CHOICES = new SimpleHttpStatus(300, "Multiple Choices");
/**
* HTTP status: 301 Moved Permanently
*/
HttpStatus MOVED_PERMANENTLY = new SimpleHttpStatus(301, "Moved Permanently");
/**
* HTTP status: 302 Found
*/
HttpStatus FOUND = new SimpleHttpStatus(302, "Found");
/**
* HTTP status: 303 See Other
*/
HttpStatus SEE_OTHER = new SimpleHttpStatus(303, "See Other");
/**
* HTTP status: 304 Not Modified
*/
HttpStatus NOT_MODIFIED = new SimpleHttpStatus(304, "Not Modified");
/**
* HTTP status: 305 Use Proxy
*/
HttpStatus USE_PROXY = new SimpleHttpStatus(305, "Use Proxy");
/**
* HTTP status: 307 Temporary Redirect
*/
HttpStatus TEMPORARY_REDIRECT = new SimpleHttpStatus(307, "Temporary Redirect");
/**
* HTTP status: 308 Permanent Redirect
*/
HttpStatus PERMANENT_REDIRECT = new SimpleHttpStatus(308, "Permanent Redirect");
/*
* 4xx Client Error status codes, see: http://tools.ietf.org/html/rfc2068#section-10.4
*/
/**
* HTTP status: 400 Bad Request
*/
HttpStatus BAD_REQUEST = new SimpleHttpStatus(400, "Bad Request");
/**
* HTTP status: 401 Unauthorized
*/
HttpStatus UNAUTHORIZED = new SimpleHttpStatus(401, "Unauthorized");
/**
* HTTP status: 402 Payment Required
*/
HttpStatus PAYMENT_REQUIRED = new SimpleHttpStatus(402, "Payment Required");
/**
* HTTP status: 403 Forbidden
*/
HttpStatus FORBIDDEN = new SimpleHttpStatus(403, "Forbidden");
/**
* HTTP status: 404 Not Found
*/
HttpStatus NOT_FOUND = new SimpleHttpStatus(404, "Not Found");
/**
* HTTP status: 405 Method Not Allowed
*/
HttpStatus METHOD_NOT_ALLOWED = new SimpleHttpStatus(405, "Method Not Allowed");
/**
* HTTP status: 406 Not Acceptable
*/
HttpStatus NOT_ACCEPTABLE = new SimpleHttpStatus(406, "Not Acceptable");
/**
* HTTP status: 407 Proxy Authentication Required
*/
HttpStatus PROXY_AUTHENTICATION_REQUIRED = new SimpleHttpStatus(407,
"Proxy Authentication Required");
/**
* HTTP status: 408 Request Timeout
*/
HttpStatus REQUEST_TIMEOUT = new SimpleHttpStatus(408, "Request Timeout");
/**
* HTTP status: 409 Conflict
*/
HttpStatus CONFLICT = new SimpleHttpStatus(409, "Conflict");
/**
* HTTP status: 410 Gone
*/
HttpStatus GONE = new SimpleHttpStatus(410, "Gone");
/**
* HTTP status: 411 Length Required
*/
HttpStatus LENGTH_REQUIRED = new SimpleHttpStatus(411, "Length Required");
/**
* HTTP status: 412 Precondition Failed
*/
HttpStatus PRECONDITION_FAILED = new SimpleHttpStatus(412, "Precondition Failed");
/**
* HTTP status: 413 Payload Too Large
*/
HttpStatus PAYLOAD_TOO_LARGE = new SimpleHttpStatus(413, "Payload Too Large");
/**
* Old name of {@link #PAYLOAD_TOO_LARGE}.
*/
@Deprecated
HttpStatus REQUEST_ENTITY_TOO_LARGE = PAYLOAD_TOO_LARGE;
/**
* HTTP status: 414 URI Too Long
*/
HttpStatus URI_TOO_LONG = new SimpleHttpStatus(414, "URI Too Long");
/**
* Old name of {@link #URI_TOO_LONG}.
*/
@Deprecated
HttpStatus REQUEST_URI_TOO_LONG = URI_TOO_LONG;
/**
* HTTP status: 415 Unsupported Media Type
*/
HttpStatus UNSUPPORTED_MEDIA_TYPE = new SimpleHttpStatus(415, "Unsupported Media Type");
/**
* HTTP status: 417 Expectation Failed
*/
HttpStatus EXPECTATION_FAILED = new SimpleHttpStatus(417, "Expectation Failed");
/**
* HTTP status: 422 Unprocessable Entity (WebDAV)
*/
HttpStatus UNPROCESSABLE_ENTITY = new SimpleHttpStatus(422, "Unprocessable Entity");
/**
* HTTP status: 423 Locked (WebDAV)
*/
HttpStatus LOCKED = new SimpleHttpStatus(423, "Locked");
/**
* HTTP status: 424 Failed Dependency (WebDAV)
*/
HttpStatus FAILED_DEPENDENCY = new SimpleHttpStatus(424, "Failed Dependency");
/**
* HTTP status: 426 Upgrade Required
*/
HttpStatus UPGRADE_REQUIRED = new SimpleHttpStatus(426, "Upgrade Required");
/*
* 5xx Server Error status codes, see: http://tools.ietf.org/html/rfc2068#section-10.5
*/
/**
* HTTP status: 500 Internal Server Error
*/
HttpStatus INTERNAL_SERVER_ERROR = new SimpleHttpStatus(500, "Internal Server Error");
/**
* HTTP status: 501 Not Implemented
*/
HttpStatus NOT_IMPLEMENTED = new SimpleHttpStatus(501, "Not Implemented");
/**
* HTTP status: 502 Bad Gateway
*/
HttpStatus BAD_GATEWAY = new SimpleHttpStatus(502, "Bad Gateway");
/**
* HTTP status: 503 Service Unavailable
*/
HttpStatus SERVICE_UNAVAILABLE = new SimpleHttpStatus(503, "Service Unavailable");
/**
* HTTP status: 504 Gateway Timeout
*/
HttpStatus GATEWAY_TIMEOUT = new SimpleHttpStatus(504, "Gateway Timeout");
/**
* HTTP status: 505 HTTP Version Not Supported
*/
HttpStatus HTTP_VERSION_NOT_SUPPORTED = new SimpleHttpStatus(505, "HTTP Version Not Supported");
/**
* HTTP status: 506 Variant Also Negotiates (experimental)
*/
HttpStatus VARIANT_ALSO_NEGOTIATES = new SimpleHttpStatus(506, "Variant Also Negotiates");
/**
* HTTP status: 507 Insufficient Storage (WebDAV)
*/
HttpStatus INSUFFICIENT_STORAGE = new SimpleHttpStatus(507, "Insufficient Storage");
/**
* Returns the status code.
*
* @return
*/
int statusCode();
/**
* Returns the reason phrase of this status code. Note: the reason phrase doesn't contain the status code itself.
*
* @return The reason phrase or null
if the status code is unknown.
*/
String reason();
/**
* Returns whether this represents an informational status code.
*
* @return true
if this represents an informational status code, false
otherwise.
*/
boolean isInformational();
/**
* Returns whether this status represents a success status code.
*
* @return true
if this represents a success status code, false
otherwise.
*/
boolean isSuccess();
/**
* Returns whether this status represents a redirection status code.
*
* @return true
if this represents a redirection status code, false
otherwise.
*/
boolean isRedirect();
/**
* Returns whether this status represents a client error status code.
*
* @return true
if this represents a client error status code, false
otherwise.
*/
boolean isClientError();
/**
* Returns whether this status represents a server error status code.
*
* @return true
if this represents a server error status code, false
otherwise.
*/
boolean isServerError();
@Override
int hashCode();
@Override
boolean equals(final Object obj);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy