Enum hyper::status::StatusCode  
                   
                       [−]
                   
               [src]
pub enum StatusCode {
    Continue,
    SwitchingProtocols,
    Processing,
    Ok,
    Created,
    Accepted,
    NonAuthoritativeInformation,
    NoContent,
    ResetContent,
    PartialContent,
    MultiStatus,
    AlreadyReported,
    ImUsed,
    MultipleChoices,
    MovedPermanently,
    Found,
    SeeOther,
    NotModified,
    UseProxy,
    TemporaryRedirect,
    PermanentRedirect,
    BadRequest,
    Unauthorized,
    PaymentRequired,
    Forbidden,
    NotFound,
    MethodNotAllowed,
    NotAcceptable,
    ProxyAuthenticationRequired,
    RequestTimeout,
    Conflict,
    Gone,
    LengthRequired,
    PreconditionFailed,
    PayloadTooLarge,
    UriTooLong,
    UnsupportedMediaType,
    RangeNotSatisfiable,
    ExpectationFailed,
    ImATeapot,
    MisdirectedRequest,
    UnprocessableEntity,
    Locked,
    FailedDependency,
    UpgradeRequired,
    PreconditionRequired,
    TooManyRequests,
    RequestHeaderFieldsTooLarge,
    UnavailableForLegalReasons,
    InternalServerError,
    NotImplemented,
    BadGateway,
    ServiceUnavailable,
    GatewayTimeout,
    HttpVersionNotSupported,
    VariantAlsoNegotiates,
    InsufficientStorage,
    LoopDetected,
    NotExtended,
    NetworkAuthenticationRequired,
    Unregistered(u16),
}An HTTP status code (status-code in RFC 7230 et al.).
This enum contains all common status codes and an Unregistered
extension variant. It allows status codes in the range [0, 65535], as any
u16 integer may be used as a status code for XHR requests. It is
recommended to only use values between [100, 599], since only these are
defined as valid status codes with a status class by HTTP.
If you encounter a status code that you do not know how to deal with, you
should treat it as the x00 status code—e.g. for code 123, treat it as
100 (Continue). This can be achieved with
self.class().default_code():
let status = StatusCode::Unregistered(123); assert_eq!(status.class().default_code(), StatusCode::Continue);
IANA maintain the Hypertext Transfer Protocol (HTTP) Status Code Registry which is the source for this enum (with one exception, 418 I'm a teapot, which is inexplicably not in the register).
Variants
Continue100 Continue [RFC7231, Section 6.2.1]
SwitchingProtocols101 Switching Protocols [RFC7231, Section 6.2.2]
Processing102 Processing [RFC2518]
Ok200 OK [RFC7231, Section 6.3.1]
Created201 Created [RFC7231, Section 6.3.2]
Accepted202 Accepted [RFC7231, Section 6.3.3]
NonAuthoritativeInformation203 Non-Authoritative Information [RFC7231, Section 6.3.4]
NoContent204 No Content [RFC7231, Section 6.3.5]
ResetContent205 Reset Content [RFC7231, Section 6.3.6]
PartialContent206 Partial Content [RFC7233, Section 4.1]
MultiStatus207 Multi-Status [RFC4918]
AlreadyReported208 Already Reported [RFC5842]
ImUsed226 IM Used [RFC3229]
MultipleChoices300 Multiple Choices [RFC7231, Section 6.4.1]
MovedPermanently301 Moved Permanently [RFC7231, Section 6.4.2]
Found302 Found [RFC7231, Section 6.4.3]
SeeOther303 See Other [RFC7231, Section 6.4.4]
NotModified304 Not Modified [RFC7232, Section 4.1]
UseProxy305 Use Proxy [RFC7231, Section 6.4.5]
TemporaryRedirect307 Temporary Redirect [RFC7231, Section 6.4.7]
PermanentRedirect308 Permanent Redirect [RFC7238]
BadRequest400 Bad Request [RFC7231, Section 6.5.1]
401 Unauthorized [RFC7235, Section 3.1]
PaymentRequired402 Payment Required [RFC7231, Section 6.5.2]
Forbidden403 Forbidden [RFC7231, Section 6.5.3]
NotFound404 Not Found [RFC7231, Section 6.5.4]
MethodNotAllowed405 Method Not Allowed [RFC7231, Section 6.5.5]
NotAcceptable406 Not Acceptable [RFC7231, Section 6.5.6]
ProxyAuthenticationRequired407 Proxy Authentication Required [RFC7235, Section 3.2]
RequestTimeout408 Request Timeout [RFC7231, Section 6.5.7]
Conflict409 Conflict [RFC7231, Section 6.5.8]
Gone410 Gone [RFC7231, Section 6.5.9]
LengthRequired411 Length Required [RFC7231, Section 6.5.10]
PreconditionFailed412 Precondition Failed [RFC7232, Section 4.2]
PayloadTooLarge413 Payload Too Large [RFC7231, Section 6.5.11]
UriTooLong414 URI Too Long [RFC7231, Section 6.5.12]
UnsupportedMediaType415 Unsupported Media Type [RFC7231, Section 6.5.13]
RangeNotSatisfiable416 Range Not Satisfiable [RFC7233, Section 4.4]
ExpectationFailed417 Expectation Failed [RFC7231, Section 6.5.14]
ImATeapot418 I'm a teapot [curiously, not registered by IANA, but RFC2324]
MisdirectedRequest421 Misdirected Request RFC7540, Section 9.1.2
UnprocessableEntity422 Unprocessable Entity [RFC4918]
Locked423 Locked [RFC4918]
FailedDependency424 Failed Dependency [RFC4918]
UpgradeRequired426 Upgrade Required [RFC7231, Section 6.5.15]
PreconditionRequired428 Precondition Required [RFC6585]
TooManyRequests429 Too Many Requests [RFC6585]
RequestHeaderFieldsTooLarge431 Request Header Fields Too Large [RFC6585]
451 Unavailable For Legal Reasons [RFC7725]
InternalServerError500 Internal Server Error [RFC7231, Section 6.6.1]
NotImplemented501 Not Implemented [RFC7231, Section 6.6.2]
BadGateway502 Bad Gateway [RFC7231, Section 6.6.3]
503 Service Unavailable [RFC7231, Section 6.6.4]
GatewayTimeout504 Gateway Timeout [RFC7231, Section 6.6.5]
HttpVersionNotSupported505 HTTP Version Not Supported [RFC7231, Section 6.6.6]
VariantAlsoNegotiates506 Variant Also Negotiates [RFC2295]
InsufficientStorage507 Insufficient Storage [RFC4918]
LoopDetected508 Loop Detected [RFC5842]
NotExtended510 Not Extended [RFC2774]
NetworkAuthenticationRequired511 Network Authentication Required [RFC6585]
Unregistered(u16)A status code not in the IANA HTTP status code registry or very well known
Methods
impl StatusCode[src]
fn canonical_reason(&self) -> Option<&'static str>
Get the standardised reason-phrase for this status code.
This is mostly here for servers writing responses, but could potentially have application at other times.
The reason phrase is defined as being exclusively for human readers. You should avoid deriving any meaning from it at all costs.
Bear in mind also that in HTTP/2.0 the reason phrase is abolished from transmission, and so this canonical reason phrase really is the only reason phrase you’ll find.
fn class(&self) -> StatusClass
Determine the class of a status code, based on its first digit.
fn is_informational(&self) -> bool
Check if class is Informational.
fn is_success(&self) -> bool
Check if class is Success.
fn is_redirection(&self) -> bool
Check if class is Redirection.
fn is_client_error(&self) -> bool
Check if class is ClientError.
fn is_server_error(&self) -> bool
Check if class is ServerError.
fn is_strange_status(&self) -> bool
Check if class is NoClass
Trait Implementations
impl Hash for StatusCode[src]
fn hash<__H: Hasher>(&self, __arg_0: &mut __H)
Feeds this value into the state given, updating the hasher as necessary.
fn hash_slice<H>(data: &[Self], state: &mut H) where H: Hasher1.3.0
Feeds a slice of this type into the state provided.
impl Debug for StatusCode[src]
impl Copy for StatusCode[src]
impl Display for StatusCode[src]
Formats the status code, including the canonical reason.
assert_eq!(format!("{}", ImATeapot), "418 I'm a teapot"); assert_eq!(format!("{}", Unregistered(123)), "123 <unknown status code>");
impl PartialEq for StatusCode[src]
fn eq(&self, other: &StatusCode) -> bool
This method tests for self and other values to be equal, and is used by ==. Read more
fn ne(&self, other: &Rhs) -> bool1.0.0
This method tests for !=.
impl Eq for StatusCode[src]
impl Clone for StatusCode[src]
fn clone(&self) -> StatusCode
Returns a copy of the value. Read more
fn clone_from(&mut self, source: &Self)1.0.0
Performs copy-assignment from source. Read more
impl PartialOrd for StatusCode[src]
fn partial_cmp(&self, other: &StatusCode) -> Option<Ordering>
This method returns an ordering between self and other values if one exists. Read more
fn lt(&self, other: &Rhs) -> bool1.0.0
This method tests less than (for self and other) and is used by the < operator. Read more
fn le(&self, other: &Rhs) -> bool1.0.0
This method tests less than or equal to (for self and other) and is used by the <= operator. Read more
fn gt(&self, other: &Rhs) -> bool1.0.0
This method tests greater than (for self and other) and is used by the > operator. Read more
fn ge(&self, other: &Rhs) -> bool1.0.0
This method tests greater than or equal to (for self and other) and is used by the >= operator. Read more
impl Ord for StatusCode[src]
fn cmp(&self, other: &StatusCode) -> Ordering
This method returns an Ordering between self and other. Read more