Page Menu
Home
WickedGov Phorge
Search
Configure Global Search
Log In
Files
F1427851
HttpError.php
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Flag For Later
Award Token
Size
3 KB
Referenced Files
None
Subscribers
None
HttpError.php
View Options
<?php
/**
* @license GPL-2.0-or-later
* @file
*/
namespace
MediaWiki\Exception
;
use
MediaWiki\Logger\LoggerFactory
;
use
MediaWiki\Message\Message
;
use
MediaWiki\Request\ContentSecurityPolicy
;
use
Wikimedia\Http\HttpStatus
;
/**
* Show an error that looks like an HTTP server error.
* Replacement for wfHttpError().
*
* @newable
* @stable to extend
* @since 1.19
* @ingroup Exception
*/
class
HttpError
extends
MWException
{
/** @var int */
private
$httpCode
;
/** @var string|Message|null */
private
$header
;
/** @var string|Message */
private
$content
;
/**
* @stable to call
* @param int $httpCode HTTP status code to send to the client
* @param string|Message $content Content of the message
* @param string|Message|null $header Content of the header (\<title\> and \<h1\>)
* @param-taint $content tainted
* @param-taint $header tainted
*/
public
function
__construct
(
$httpCode
,
$content
,
$header
=
null
)
{
parent
::
__construct
(
(
string
)
$content
);
$this
->
httpCode
=
(
int
)
$httpCode
;
$this
->
header
=
$header
;
$this
->
content
=
$content
;
}
/**
* We don't want the default exception logging as we got our own logging set
* up in self::report.
*
* @see MWException::isLoggable
*
* @since 1.24
* @return bool
*/
public
function
isLoggable
()
{
return
false
;
}
/**
* Returns the HTTP status code supplied to the constructor.
*
* @return int
*/
public
function
getStatusCode
()
{
return
$this
->
httpCode
;
}
/**
* Report and log the HTTP error.
* Sends the appropriate HTTP status code and outputs an
* HTML page with an error message.
*/
public
function
report
()
{
$this
->
doLog
();
HttpStatus
::
header
(
$this
->
httpCode
);
header
(
'Content-type: text/html; charset=utf-8'
);
ContentSecurityPolicy
::
sendRestrictiveHeader
();
print
$this
->
getHTML
();
}
private
function
doLog
()
{
$logger
=
LoggerFactory
::
getInstance
(
'HttpError'
);
$content
=
$this
->
content
;
if
(
$content
instanceof
Message
)
{
$content
=
$content
->
text
();
}
$context
=
[
'file'
=>
$this
->
getFile
(),
'line'
=>
$this
->
getLine
(),
'http_code'
=>
$this
->
httpCode
,
];
$logMsg
=
"$content ({http_code}) from {file}:{line}"
;
if
(
$this
->
getStatusCode
()
<
500
)
{
$logger
->
info
(
$logMsg
,
$context
);
}
else
{
$logger
->
error
(
$logMsg
,
$context
);
}
}
/**
* Returns HTML for reporting the HTTP error.
* This will be a minimal but complete HTML document.
*
* @return string HTML
*/
public
function
getHTML
()
{
if
(
$this
->
header
===
null
)
{
$titleHtml
=
htmlspecialchars
(
HttpStatus
::
getMessage
(
$this
->
httpCode
)
);
}
elseif
(
$this
->
header
instanceof
Message
)
{
$titleHtml
=
$this
->
header
->
escaped
();
}
else
{
$titleHtml
=
htmlspecialchars
(
$this
->
header
);
}
if
(
$this
->
content
instanceof
Message
)
{
$contentHtml
=
$this
->
content
->
escaped
();
}
else
{
$contentHtml
=
nl2br
(
htmlspecialchars
(
$this
->
content
)
);
}
return
"<!DOCTYPE html>
\n
"
.
"<html><head><title>$titleHtml</title><meta name=
\"
color-scheme
\"
content=
\"
light dark
\"
/></head>
\n
"
.
"<body><h1>$titleHtml</h1><p>$contentHtml</p></body></html>
\n
"
;
}
}
/** @deprecated class alias since 1.44 */
class_alias
(
HttpError
::
class
,
'HttpError'
);
File Metadata
Details
Attached
Mime Type
text/x-php
Expires
Sat, May 16, 15:11 (15 h, 17 m)
Storage Engine
local-disk
Storage Format
Raw Data
Storage Handle
31/f0/c6e600f5fb3bffb094aa8100dd88
Default Alt Text
HttpError.php (3 KB)
Attached To
Mode
rMWPROD MediaWiki Production
Attached
Detach File
Event Timeline
Log In to Comment