Page Menu
Home
WickedGov Phorge
Search
Configure Global Search
Log In
Files
F1427522
RevisionHTMLHandler.php
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Flag For Later
Award Token
Size
4 KB
Referenced Files
None
Subscribers
None
RevisionHTMLHandler.php
View Options
<?php
namespace
MediaWiki\Rest\Handler
;
use
LogicException
;
use
MediaWiki\Rest\Handler\Helper\HtmlOutputRendererHelper
;
use
MediaWiki\Rest\Handler\Helper\PageRestHelperFactory
;
use
MediaWiki\Rest\Handler\Helper\RevisionContentHelper
;
use
MediaWiki\Rest\LocalizedHttpException
;
use
MediaWiki\Rest\Response
;
use
MediaWiki\Rest\SimpleHandler
;
use
MediaWiki\Rest\StringStream
;
use
Wikimedia\Assert\Assert
;
/**
* A handler that returns Parsoid HTML for the following routes:
* - /revision/{revision}/html,
* - /revision/{revision}/with_html
*/
class
RevisionHTMLHandler
extends
SimpleHandler
{
private
?
HtmlOutputRendererHelper
$htmlHelper
=
null
;
private
PageRestHelperFactory
$helperFactory
;
private
RevisionContentHelper
$contentHelper
;
public
function
__construct
(
PageRestHelperFactory
$helperFactory
)
{
$this
->
helperFactory
=
$helperFactory
;
$this
->
contentHelper
=
$helperFactory
->
newRevisionContentHelper
();
}
protected
function
postValidationSetup
()
{
$authority
=
$this
->
getAuthority
();
$this
->
contentHelper
->
init
(
$authority
,
$this
->
getValidatedParams
()
);
$page
=
$this
->
contentHelper
->
getPage
();
$revision
=
$this
->
contentHelper
->
getTargetRevision
();
if
(
$page
&&
$revision
)
{
$this
->
htmlHelper
=
$this
->
helperFactory
->
newHtmlOutputRendererHelper
(
$page
,
$this
->
getValidatedParams
(),
$authority
,
$revision
);
$request
=
$this
->
getRequest
();
$acceptLanguage
=
$request
->
getHeaderLine
(
'Accept-Language'
)
?:
null
;
if
(
$acceptLanguage
)
{
$this
->
htmlHelper
->
setVariantConversionLanguage
(
$acceptLanguage
);
}
}
}
/**
* @return Response
* @throws LocalizedHttpException
*/
public
function
run
():
Response
{
$this
->
contentHelper
->
checkAccess
();
$page
=
$this
->
contentHelper
->
getPage
();
$revisionRecord
=
$this
->
contentHelper
->
getTargetRevision
();
// The call to $this->contentHelper->getPage() should not return null if
// $this->contentHelper->checkAccess() did not throw.
Assert
::
invariant
(
$page
!==
null
,
'Page should be known'
);
// The call to $this->contentHelper->getTargetRevision() should not return null if
// $this->contentHelper->checkAccess() did not throw.
Assert
::
invariant
(
$revisionRecord
!==
null
,
'Revision should be known'
);
$outputMode
=
$this
->
getOutputMode
();
$setContentLanguageHeader
=
true
;
switch
(
$outputMode
)
{
case
'html'
:
$parserOutput
=
$this
->
htmlHelper
->
getHtml
();
$response
=
$this
->
getResponseFactory
()->
create
();
// TODO: need to respect content-type returned by Parsoid.
$response
->
setHeader
(
'Content-Type'
,
'text/html'
);
$this
->
htmlHelper
->
putHeaders
(
$response
,
$setContentLanguageHeader
);
$this
->
contentHelper
->
setCacheControl
(
$response
,
$parserOutput
->
getCacheExpiry
()
);
$response
->
setBody
(
new
StringStream
(
$parserOutput
->
getRawText
()
)
);
break
;
case
'with_html'
:
$parserOutput
=
$this
->
htmlHelper
->
getHtml
();
$body
=
$this
->
contentHelper
->
constructMetadata
();
$body
[
'html'
]
=
$parserOutput
->
getRawText
();
$response
=
$this
->
getResponseFactory
()->
createJson
(
$body
);
// For JSON content, it doesn't make sense to set content language header
$this
->
htmlHelper
->
putHeaders
(
$response
,
!
$setContentLanguageHeader
);
$this
->
contentHelper
->
setCacheControl
(
$response
,
$parserOutput
->
getCacheExpiry
()
);
break
;
default
:
throw
new
LogicException
(
"Unknown HTML type $outputMode"
);
}
return
$response
;
}
/**
* Returns an ETag representing a page's source. The ETag assumes a page's source has changed
* if the latest revision of a page has been made private, un-readable for another reason,
* or a newer revision exists.
* @return string|null
*/
protected
function
getETag
():
?
string
{
if
(
!
$this
->
contentHelper
->
isAccessible
()
)
{
return
null
;
}
// Vary eTag based on output mode
return
$this
->
htmlHelper
->
getETag
(
$this
->
getOutputMode
()
);
}
/**
* @return string|null
*/
protected
function
getLastModified
():
?
string
{
if
(
!
$this
->
contentHelper
->
isAccessible
()
)
{
return
null
;
}
return
$this
->
htmlHelper
->
getLastModified
();
}
private
function
getOutputMode
():
string
{
return
$this
->
getConfig
()[
'format'
];
}
public
function
needsWriteAccess
():
bool
{
return
false
;
}
public
function
getParamSettings
():
array
{
return
array_merge
(
$this
->
contentHelper
->
getParamSettings
(),
HtmlOutputRendererHelper
::
getParamSettings
()
);
}
/**
* @return bool
*/
protected
function
hasRepresentation
()
{
return
$this
->
contentHelper
->
hasContent
();
}
}
File Metadata
Details
Attached
Mime Type
text/x-php
Expires
Sat, May 16, 14:43 (1 d, 1 h)
Storage Engine
local-disk
Storage Format
Raw Data
Storage Handle
ef/b2/e6a992973955cf68a862d9977d07
Default Alt Text
RevisionHTMLHandler.php (4 KB)
Attached To
Mode
rMWPROD MediaWiki Production
Attached
Detach File
Event Timeline
Log In to Comment