mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/TemplateData
synced 2024-11-23 23:43:54 +00:00
Add tracking for template data presence
This will give results whenever template data is requested e.g. by VisualEditor or the TemplateWizard. Bug: T259705 Change-Id: I2a9e864b94b6f8f49ca3adaa46502627ab6b3322
This commit is contained in:
parent
028aaba896
commit
b8b1df894f
|
@ -218,7 +218,8 @@
|
|||
"attributes": {
|
||||
"EventLogging": {
|
||||
"Schemas": {
|
||||
"TemplateDataEditor": 20759032
|
||||
"TemplateDataEditor": 20759032,
|
||||
"TemplateDataApi": 20817949
|
||||
}
|
||||
},
|
||||
"VisualEditor": {
|
||||
|
|
|
@ -147,6 +147,8 @@ class ApiTemplateData extends ApiBase {
|
|||
}
|
||||
}
|
||||
|
||||
$wikiPageFactory = $services->getWikiPageFactory();
|
||||
|
||||
// Now go through all the titles again, and attempt to extract parameter names from the
|
||||
// wikitext for templates with no templatedata.
|
||||
if ( $includeMissingTitles ) {
|
||||
|
@ -155,8 +157,8 @@ class ApiTemplateData extends ApiBase {
|
|||
// Ignore pages that already have templatedata or that don't exist.
|
||||
continue;
|
||||
}
|
||||
$content = $services->getWikiPageFactory()
|
||||
->newFromTitle( $pageInfo['title'] )
|
||||
|
||||
$content = $wikiPageFactory->newFromTitle( $pageInfo['title'] )
|
||||
->getContent( RevisionRecord::FOR_PUBLIC );
|
||||
$text = $content instanceof TextContent
|
||||
? $content->getText()
|
||||
|
@ -165,6 +167,22 @@ class ApiTemplateData extends ApiBase {
|
|||
}
|
||||
}
|
||||
|
||||
// TODO tracking will only be implemented temporarily to answer questions on
|
||||
// template usage for the Technical Wishes topic area see T258917
|
||||
if ( ExtensionRegistry::getInstance()->isLoaded( 'EventLogging' ) ) {
|
||||
foreach ( $resp as $pageId => $pageInfo ) {
|
||||
\EventLogging::logEvent(
|
||||
'TemplateDataApi',
|
||||
20817949,
|
||||
[
|
||||
'template_name' => $wikiPageFactory->newFromTitle( $pageInfo['title'] )
|
||||
->getTitle()->getDBkey(),
|
||||
'has_template_data' => !( isset( $pageInfo['notemplatedata'] ) ?: false ),
|
||||
]
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
ApiResult::setArrayType( $resp, 'kvp', 'id' );
|
||||
ApiResult::setIndexedTagName( $resp, 'page' );
|
||||
|
||||
|
|
Loading…
Reference in a new issue