/usr/share/perl5/Dancer2/Core/HTTP.pm is in libdancer2-perl 0.166001+dfsg-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 | # ABSTRACT: helper for rendering HTTP status codes for Dancer2
package Dancer2::Core::HTTP;
$Dancer2::Core::HTTP::VERSION = '0.166001';
use strict;
use warnings;
my $HTTP_CODES = {
# informational
100 => 'Continue', # only on HTTP 1.1
101 => 'Switching Protocols', # only on HTTP 1.1
102 => 'Processing', # WebDAV; RFC 2518
# processed
200 => 'OK',
201 => 'Created',
202 => 'Accepted',
203 => 'Non-Authoritative Information', # only on HTTP 1.1
204 => 'No Content',
205 => 'Reset Content',
206 => 'Partial Content',
207 => 'Multi-Status', # WebDAV; RFC 4918
208 => 'Already Reported', # WebDAV; RFC 5842
# 226 => 'IM Used' # RFC 3229
# redirections
301 => 'Moved Permanently',
302 => 'Found',
303 => '303 See Other', # only on HTTP 1.1
304 => 'Not Modified',
305 => '305 Use Proxy', # only on HTTP 1.1
306 => 'Switch Proxy',
307 => 'Temporary Redirect', # only on HTTP 1.1
# 308 => 'Permanent Redirect' # approved as experimental RFC
# problems with request
400 => 'Bad Request',
401 => 'Unauthorized',
402 => 'Payment Required',
403 => 'Forbidden',
404 => 'Not Found',
405 => 'Method Not Allowed',
406 => 'Not Acceptable',
407 => 'Proxy Authentication Required',
408 => 'Request Timeout',
409 => 'Conflict',
410 => 'Gone',
411 => 'Length Required',
412 => 'Precondition Failed',
413 => 'Request Entity Too Large',
414 => 'Request-URI Too Long',
415 => 'Unsupported Media Type',
416 => 'Requested Range Not Satisfiable',
417 => 'Expectation Failed',
418 => "I'm a teapot", # RFC 2324
# 419 => 'Authentication Timeout', # not in RFC 2616
420 => 'Enhance Your Calm',
422 => 'Unprocessable Entity',
423 => 'Locked',
424 => 'Failed Dependency', # Also used for 'Method Failure'
425 => 'Unordered Collection',
426 => 'Upgrade Required',
428 => 'Precondition Required',
429 => 'Too Many Requests',
431 => 'Request Header Fields Too Large',
444 => 'No Response',
449 => 'Retry With',
450 => 'Blocked by Windows Parental Controls',
451 => 'Unavailable For Legal Reasons',
451 => 'Redirect',
494 => 'Request Header Too Large',
495 => 'Cert Error',
496 => 'No Cert',
497 => 'HTTP to HTTPS',
499 => 'Client Closed Request',
# problems with server
500 => 'Internal Server Error',
501 => 'Not Implemented',
502 => 'Bad Gateway',
503 => 'Service Unavailable',
504 => 'Gateway Timeout',
505 => 'HTTP Version Not Supported',
506 => 'Variant Also Negotiates',
507 => 'Insufficient Storage',
508 => 'Loop Detected',
509 => 'Bandwidth Limit Exceeded',
510 => 'Not Extended',
511 => 'Network Authentication Required',
598 => 'Network read timeout error',
599 => 'Network connect timeout error',
};
for my $code ( keys %$HTTP_CODES ) {
my $str_http_code = $HTTP_CODES->{$code};
$HTTP_CODES->{$str_http_code} = $code;
my $alias = lc join '_', split /\W/, $HTTP_CODES->{$code};
$HTTP_CODES->{$alias} = $code;
}
$HTTP_CODES->{error} = $HTTP_CODES->{internal_server_error};
sub status {
my ( $class, $status ) = @_;
return if ! defined $status;
return $status if $status =~ /^\d+$/;
if ( exists $HTTP_CODES->{$status} ) {
return $HTTP_CODES->{$status};
}
return;
}
sub status_message {
my ( $class, $status ) = @_;
return if ! defined $status;
my $code = $class->status($status);
return if ! defined $code || ! exists $HTTP_CODES->{$code};
return $HTTP_CODES->{ $code };
}
1;
__END__
=pod
=encoding UTF-8
=head1 NAME
Dancer2::Core::HTTP - helper for rendering HTTP status codes for Dancer2
=head1 VERSION
version 0.166001
=head1 FUNCTIONS
=head2 status(status_code)
Dancer2::Core::HTTP->status(200); # returns 200
Dancer2::Core::HTTP->status('Not Found'); # returns 404
Dancer2::Core::HTTP->status('bad_request'); # 400
Returns a HTTP status code. If given an integer, it will return the value it
received, else it will try to find the appropriate alias and return the correct
status.
=head2 status_message(status_code)
Dancer2::Core::HTTP->status_message(200); # returns 'OK'
Dancer2::Core::HTTP->status_message('error'); # returns 'Internal Server Error'
Returns the HTTP status message for the given status code.
=head1 AUTHOR
Dancer Core Developers
=head1 COPYRIGHT AND LICENSE
This software is copyright (c) 2015 by Alexis Sukrieh.
This is free software; you can redistribute it and/or modify it under
the same terms as the Perl 5 programming language system itself.
=cut
|