Page Menu
Home
c4science
Search
Configure Global Search
Log In
Files
F101898523
ConduitAPI_diffusion_readmequery_Method.php
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Subscribers
None
File Metadata
Details
File Info
Storage
Attached
Created
Fri, Feb 14, 21:49
Size
3 KB
Mime Type
text/x-php
Expires
Sun, Feb 16, 21:49 (2 d)
Engine
blob
Format
Raw Data
Handle
24240780
Attached To
rPH Phabricator
ConduitAPI_diffusion_readmequery_Method.php
View Options
<?php
final
class
ConduitAPI_diffusion_readmequery_Method
extends
ConduitAPI_diffusion_abstractquery_Method
{
public
function
getMethodDescription
()
{
return
pht
(
'Retrieve any "readme" that can be found for a set of paths in '
.
'repository.'
);
}
public
function
defineReturnType
()
{
return
'string'
;
}
protected
function
defineCustomParamTypes
()
{
return
array
(
'paths'
=>
'required array <string>'
,
'commit'
=>
'optional string'
,
);
}
protected
function
getResult
(
ConduitAPIRequest
$request
)
{
$drequest
=
$this
->
getDiffusionRequest
();
$path_dicts
=
$request
->
getValue
(
'paths'
,
array
());
$paths
=
array
();
foreach
(
$path_dicts
as
$dict
)
{
$paths
[]
=
DiffusionRepositoryPath
::
newFromDictionary
(
$dict
);
}
$readme
=
''
;
foreach
(
$paths
as
$result_path
)
{
$file_type
=
$result_path
->
getFileType
();
if
((
$file_type
!=
ArcanistDiffChangeType
::
FILE_NORMAL
)
&&
(
$file_type
!=
ArcanistDiffChangeType
::
FILE_TEXT
))
{
// Skip directories, etc.
continue
;
}
$path
=
$result_path
->
getPath
();
if
(
preg_match
(
'/^readme(|
\.
txt|
\.
remarkup|
\.
rainbow|
\.
md)$/i'
,
$path
))
{
$readme
=
$result_path
;
break
;
}
}
if
(!
$readme
)
{
return
''
;
}
$readme_request
=
DiffusionRequest
::
newFromDictionary
(
array
(
'user'
=>
$request
->
getUser
(),
'repository'
=>
$drequest
->
getRepository
(),
'commit'
=>
$drequest
->
getStableCommit
(),
'path'
=>
$readme
->
getFullPath
(),
));
$file_content
=
DiffusionFileContent
::
newFromConduit
(
DiffusionQuery
::
callConduitWithDiffusionRequest
(
$request
->
getUser
(),
$readme_request
,
'diffusion.filecontentquery'
,
array
(
'commit'
=>
$drequest
->
getStableCommit
(),
'path'
=>
$readme
->
getFullPath
(),
'needsBlame'
=>
false
,
)));
$readme_content
=
$file_content
->
getCorpus
();
if
(
preg_match
(
'/
\\
.txt$/'
,
$readme
->
getPath
()))
{
$readme_content
=
phutil_escape_html_newlines
(
$readme_content
);
$class
=
null
;
}
else
if
(
preg_match
(
'/
\\
.rainbow$/'
,
$readme
->
getPath
()))
{
$highlighter
=
new
PhutilRainbowSyntaxHighlighter
();
$readme_content
=
$highlighter
->
getHighlightFuture
(
$readme_content
)
->
resolve
();
$readme_content
=
phutil_escape_html_newlines
(
$readme_content
);
require_celerity_resource
(
'syntax-highlighting-css'
);
$class
=
'remarkup-code'
;
}
else
{
// TODO: This is sketchy, but make sure we hit the markup cache.
$markup_object
=
id
(
new
PhabricatorMarkupOneOff
())
->
setEngineRuleset
(
'diffusion-readme'
)
->
setContent
(
$readme_content
);
$markup_field
=
'default'
;
$readme_content
=
id
(
new
PhabricatorMarkupEngine
())
->
setViewer
(
$request
->
getUser
())
->
addObject
(
$markup_object
,
$markup_field
)
->
process
()
->
getOutput
(
$markup_object
,
$markup_field
);
$engine
=
$markup_object
->
newMarkupEngine
(
$markup_field
);
$toc
=
PhutilRemarkupEngineRemarkupHeaderBlockRule
::
renderTableOfContents
(
$engine
);
if
(
$toc
)
{
$toc
=
phutil_tag_div
(
'phabricator-remarkup-toc'
,
array
(
phutil_tag_div
(
'phabricator-remarkup-toc-header'
,
pht
(
'Table of Contents'
)),
$toc
,
));
$readme_content
=
array
(
$toc
,
$readme_content
);
}
$class
=
'phabricator-remarkup'
;
}
$readme_content
=
phutil_tag
(
'div'
,
array
(
'class'
=>
$class
,
),
$readme_content
);
return
$readme_content
;
}
}
Event Timeline
Log In to Comment