Compare commits

..

No commits in common. "master" and "REL1_34" have entirely different histories.

62 changed files with 2528 additions and 6423 deletions

View file

@ -1,8 +0,0 @@
{
"root": true,
"extends": [
"wikimedia/client-es5",
"wikimedia/jquery",
"wikimedia/mediawiki"
]
}

1
.gitignore vendored
View file

@ -5,4 +5,3 @@
node_modules/ node_modules/
/composer.lock /composer.lock
/vendor/ /vendor/
/.eslintcache

2
.jshintignore Normal file
View file

@ -0,0 +1,2 @@
node_modules
vendor

View file

@ -1,12 +1,13 @@
<?xml version="1.0"?> <?xml version="1.0"?>
<ruleset> <ruleset>
<rule ref="./vendor/mediawiki/mediawiki-codesniffer/MediaWiki"> <rule ref="./vendor/mediawiki/mediawiki-codesniffer/MediaWiki">
<exclude name="MediaWiki.Files.ClassMatchesFilename.NotMatch" />
<exclude name="MediaWiki.Commenting.FunctionComment.MissingDocumentationProtected" />
<exclude name="MediaWiki.Commenting.FunctionComment.MissingDocumentationPublic" /> <exclude name="MediaWiki.Commenting.FunctionComment.MissingDocumentationPublic" />
<exclude name="MediaWiki.Usage.ExtendClassUsage.FunctionConfigUsage" /> <exclude name="MediaWiki.Usage.DbrQueryUsage.DbrQueryFound" />
<exclude name="PSR12.Properties.ConstantVisibility.NotFound" />
<exclude name="Squiz.Scope.MethodScope.Missing" /> <exclude name="Squiz.Scope.MethodScope.Missing" />
</rule> </rule>
<file>.</file> <file>.</file>
<arg name="extensions" value="php" /> <arg name="extensions" value="php,php5,inc" />
<arg name="encoding" value="UTF-8" /> <arg name="encoding" value="UTF-8" />
</ruleset> </ruleset>

View file

@ -233,16 +233,6 @@ $specialPageAliases['sk'] = [
'ContributionScores' => [ 'SkórePríspevkov' ], 'ContributionScores' => [ 'SkórePríspevkov' ],
]; ];
/** Serbian Cyrillic (српски (ћирилица)) */
$specialPageAliases['sr-ec'] = [
'ContributionScores' => [ 'ОценеДоприноса' ],
];
/** Serbian Latin (srpski (latinica)) */
$specialPageAliases['sr-el'] = [
'ContributionScores' => [ 'OceneDoprinosa' ],
];
/** Swedish (svenska) */ /** Swedish (svenska) */
$specialPageAliases['sv'] = [ $specialPageAliases['sv'] = [
'ContributionScores' => [ 'Bidragspoäng' ], 'ContributionScores' => [ 'Bidragspoäng' ],

93
ContributionScores.php Normal file
View file

@ -0,0 +1,93 @@
<?php
/** \file
* \brief Contains setup code for the Contribution Scores Extension.
*/
# Not a valid entry point, skip unless MEDIAWIKI is defined
if ( !defined( 'MEDIAWIKI' ) ) {
echo 'Contribution Scores extension';
exit( 1 );
}
$wgExtensionCredits['specialpage'][] = [
'path' => __FILE__,
'name' => 'Contribution Scores',
'url' => 'https://www.mediawiki.org/wiki/Extension:Contribution_Scores',
'author' => 'Tim Laqua',
'descriptionmsg' => 'contributionscores-desc',
'version' => '1.25.0'
];
define( 'CONTRIBUTIONSCORES_MAXINCLUDELIMIT', 50 );
$wgContribScoreReports = null;
// These settings can be overridden in LocalSettings.php.
// Set to true to exclude bots from the reporting.
$wgContribScoreIgnoreBlockedUsers = false;
// Set to true to exclude blocked users from the reporting.
$wgContribScoreIgnoreBots = false;
// Set to true to use real user names when available. Only for MediaWiki 1.19 and later.
$wgContribScoresUseRealName = false;
// Set to true to disable cache for parser function and inclusion of table.
$wgContribScoreDisableCache = false;
$wgAutoloadClasses['ContributionScores'] = __DIR__ . '/ContributionScores_body.php';
$wgSpecialPages['ContributionScores'] = 'ContributionScores';
$wgMessagesDirs['ContributionScores'] = __DIR__ . '/i18n';
$wgExtensionMessagesFiles['ContributionScoresAlias'] = __DIR__ . '/ContributionScores.alias.php';
$wgExtensionMessagesFiles['ContributionScoresMagic'] =
__DIR__ . '/ContributionScores.i18n.magic.php';
$wgHooks['ParserFirstCallInit'][] = 'efContributionScores_Setup';
function efContributionScores_Setup( &$parser ) {
$parser->setFunctionHook( 'cscore', 'efContributionScores_Render' );
return true;
}
function efContributionScores_Render( &$parser, $usertext, $metric = 'score' ) {
global $wgContribScoreDisableCache;
if ( $wgContribScoreDisableCache ) {
$parser->disableCache();
}
$user = User::newFromName( $usertext );
$dbr = wfGetDB( DB_REPLICA );
if ( $user instanceof User && $user->isLoggedIn() ) {
global $wgLang;
if ( $metric == 'score' ) {
$res = $dbr->select( 'revision',
'COUNT(DISTINCT rev_page)+SQRT(COUNT(rev_id)-COUNT(DISTINCT rev_page))*2 AS wiki_rank',
[ 'rev_user' => $user->getID() ] );
$row = $dbr->fetchObject( $res );
$output = $wgLang->formatNum( round( $row->wiki_rank, 0 ) );
} elseif ( $metric == 'changes' ) {
$res = $dbr->select( 'revision',
'COUNT(rev_id) AS rev_count',
[ 'rev_user' => $user->getID() ] );
$row = $dbr->fetchObject( $res );
$output = $wgLang->formatNum( $row->rev_count );
} elseif ( $metric == 'pages' ) {
$res = $dbr->select( 'revision',
'COUNT(DISTINCT rev_page) AS page_count',
[ 'rev_user' => $user->getID() ] );
$row = $dbr->fetchObject( $res );
$output = $wgLang->formatNum( $row->page_count );
} else {
$output = wfMessage( 'contributionscores-invalidmetric' )->text();
}
} else {
$output = wfMessage( 'contributionscores-invalidusername' )->text();
}
return $parser->insertStripItem( $output, $parser->mStripState );
}

275
ContributionScores_body.php Normal file
View file

@ -0,0 +1,275 @@
<?php
/** \file
* \brief Contains code for the ContributionScores Class (extends SpecialPage).
*/
/// Special page class for the Contribution Scores extension
/**
* Special page that generates a list of wiki contributors based
* on edit diversity (unique pages edited) and edit volume (total
* number of edits.
*
* @ingroup Extensions
* @author Tim Laqua <t.laqua@gmail.com>
*/
class ContributionScores extends IncludableSpecialPage {
public function __construct() {
parent::__construct( 'ContributionScores' );
}
/// Generates a "Contribution Scores" table for a given LIMIT and date range
/**
* Function generates Contribution Scores tables in HTML format (not wikiText)
*
* @param int $days Days in the past to run report for
* @param int $limit Maximum number of users to return (default 50)
* @param string|null $title The title of the table
* @param array $options array of options (default none; nosort/notools)
* @return string Html Table representing the requested Contribution Scores.
*/
function genContributionScoreTable( $days, $limit, $title = null, $options = 'none' ) {
global $wgContribScoreIgnoreBots, $wgContribScoreIgnoreBlockedUsers, $wgContribScoresUseRealName;
$opts = explode( ',', strtolower( $options ) );
$dbr = wfGetDB( DB_REPLICA );
$userTable = $dbr->tableName( 'user' );
$userGroupTable = $dbr->tableName( 'user_groups' );
$revTable = $dbr->tableName( 'revision' );
$ipBlocksTable = $dbr->tableName( 'ipblocks' );
$sqlWhere = "";
$nextPrefix = "WHERE";
if ( $days > 0 ) {
$date = time() - ( 60 * 60 * 24 * $days );
$dateString = $dbr->timestamp( $date );
$sqlWhere .= " {$nextPrefix} rev_timestamp > '$dateString'";
$nextPrefix = "AND";
}
if ( $wgContribScoreIgnoreBlockedUsers ) {
$sqlWhere .= " {$nextPrefix} rev_user NOT IN " .
"(SELECT ipb_user FROM {$ipBlocksTable} WHERE ipb_user <> 0)";
$nextPrefix = "AND";
}
if ( $wgContribScoreIgnoreBots ) {
$sqlWhere .= " {$nextPrefix} rev_user NOT IN " .
"(SELECT ug_user FROM {$userGroupTable} WHERE ug_group='bot')";
}
$sqlMostPages = "SELECT rev_user,
COUNT(DISTINCT rev_page) AS page_count,
COUNT(rev_id) AS rev_count
FROM {$revTable}
{$sqlWhere}
GROUP BY rev_user
ORDER BY page_count DESC
LIMIT {$limit}";
$sqlMostRevs = "SELECT rev_user,
COUNT(DISTINCT rev_page) AS page_count,
COUNT(rev_id) AS rev_count
FROM {$revTable}
{$sqlWhere}
GROUP BY rev_user
ORDER BY rev_count DESC
LIMIT {$limit}";
$sql = "SELECT user_id, " .
"user_name, " .
"user_real_name, " .
"page_count, " .
"rev_count, " .
"page_count+SQRT(rev_count-page_count)*2 AS wiki_rank " .
"FROM $userTable u JOIN (($sqlMostPages) UNION ($sqlMostRevs)) s ON (user_id=rev_user) " .
"ORDER BY wiki_rank DESC " .
"LIMIT $limit";
$res = $dbr->query( $sql );
$sortable = in_array( 'nosort', $opts ) ? '' : ' sortable';
$output = "<table class=\"wikitable contributionscores plainlinks{$sortable}\" >\n" .
"<tr class='header'>\n" .
Html::element( 'th', [], $this->msg( 'contributionscores-rank' )->text() ) .
Html::element( 'th', [], $this->msg( 'contributionscores-score' )->text() ) .
Html::element( 'th', [], $this->msg( 'contributionscores-pages' )->text() ) .
Html::element( 'th', [], $this->msg( 'contributionscores-changes' )->text() ) .
Html::element( 'th', [], $this->msg( 'contributionscores-username' )->text() );
$altrow = '';
$user_rank = 1;
$lang = $this->getLanguage();
foreach ( $res as $row ) {
// Use real name if option used and real name present.
if ( $wgContribScoresUseRealName && $row->user_real_name !== '' ) {
$userLink = Linker::userLink(
$row->user_id,
$row->user_name,
$row->user_real_name
);
} else {
$userLink = Linker::userLink(
$row->user_id,
$row->user_name
);
}
$output .= Html::closeElement( 'tr' );
$output .= "<tr class='{$altrow}'>\n" .
"<td class='content' style='padding-right:10px;text-align:right;'>" .
$lang->formatNum( round( $user_rank, 0 ) ) .
"\n</td><td class='content' style='padding-right:10px;text-align:right;'>" .
$lang->formatNum( round( $row->wiki_rank, 0 ) ) .
"\n</td><td class='content' style='padding-right:10px;text-align:right;'>" .
$lang->formatNum( $row->page_count ) .
"\n</td><td class='content' style='padding-right:10px;text-align:right;'>" .
$lang->formatNum( $row->rev_count ) .
"\n</td><td class='content'>" .
$userLink;
# Option to not display user tools
if ( !in_array( 'notools', $opts ) ) {
$output .= Linker::userToolLinks( $row->user_id, $row->user_name );
}
$output .= Html::closeElement( 'td' ) . "\n";
if ( $altrow == '' && empty( $sortable ) ) {
$altrow = 'odd ';
} else {
$altrow = '';
}
$user_rank++;
}
$output .= Html::closeElement( 'tr' );
$output .= Html::closeElement( 'table' );
$dbr->freeResult( $res );
if ( !empty( $title ) ) {
$output = Html::rawElement( 'table',
[
'style' => 'border-spacing: 0; padding: 0',
'class' => 'contributionscores-wrapper',
'lang' => htmlspecialchars( $lang->getCode() ),
'dir' => $lang->getDir()
],
"\n" .
"<tr>\n" .
"<td style='padding: 0px;'>{$title}</td>\n" .
"</tr>\n" .
"<tr>\n" .
"<td style='padding: 0px;'>{$output}</td>\n" .
"</tr>\n"
);
}
return $output;
}
function execute( $par ) {
$this->setHeaders();
if ( $this->including() ) {
$this->showInclude( $par );
} else {
$this->showPage();
}
return true;
}
/**
* Called when being included on a normal wiki page.
* Cache is disabled so it can depend on the user language.
* @param string|null $par A subpage give to the special page
*/
function showInclude( $par ) {
$days = null;
$limit = null;
$options = 'none';
if ( !empty( $par ) ) {
$params = explode( '/', $par );
$limit = intval( $params[0] );
if ( isset( $params[1] ) ) {
$days = intval( $params[1] );
}
if ( isset( $params[2] ) ) {
$options = $params[2];
}
}
if ( empty( $limit ) || $limit < 1 || $limit > CONTRIBUTIONSCORES_MAXINCLUDELIMIT ) {
$limit = 10;
}
if ( is_null( $days ) || $days < 0 ) {
$days = 7;
}
if ( $days > 0 ) {
$reportTitle = $this->msg( 'contributionscores-days' )->numParams( $days )->text();
} else {
$reportTitle = $this->msg( 'contributionscores-allrevisions' )->text();
}
$reportTitle .= ' ' . $this->msg( 'contributionscores-top' )->numParams( $limit )->text();
$title = Xml::element( 'h4',
[ 'class' => 'contributionscores-title' ],
$reportTitle
) . "\n";
$this->getOutput()->addHTML( $this->genContributionScoreTable(
$days,
$limit,
$title,
$options
) );
}
/**
* Show the special page
*/
function showPage() {
global $wgContribScoreReports;
if ( !is_array( $wgContribScoreReports ) ) {
$wgContribScoreReports = [
[ 7, 50 ],
[ 30, 50 ],
[ 0, 50 ]
];
}
$out = $this->getOutput();
$out->addWikiMsg( 'contributionscores-info' );
foreach ( $wgContribScoreReports as $scoreReport ) {
list( $days, $revs ) = $scoreReport;
if ( $days > 0 ) {
$reportTitle = $this->msg( 'contributionscores-days' )->numParams( $days )->text();
} else {
$reportTitle = $this->msg( 'contributionscores-allrevisions' )->text();
}
$reportTitle .= ' ' . $this->msg( 'contributionscores-top' )->numParams( $revs )->text();
$title = Xml::element( 'h2',
[ 'class' => 'contributionscores-title' ],
$reportTitle
) . "\n";
$out->addHTML( $title );
$out->addHTML( $this->genContributionScoreTable( $days, $revs ) );
}
}
protected function getGroupName() {
return 'wiki';
}
}

View file

@ -1,26 +1,29 @@
/* eslint-env node, es6 */ /*jshint node:true */
module.exports = function ( grunt ) { module.exports = function ( grunt ) {
'use strict'; 'use strict';
grunt.loadNpmTasks( 'grunt-contrib-jshint' );
grunt.loadNpmTasks( 'grunt-banana-checker' ); grunt.loadNpmTasks( 'grunt-banana-checker' );
grunt.loadNpmTasks( 'grunt-eslint' ); grunt.loadNpmTasks( 'grunt-jsonlint' );
grunt.initConfig( { grunt.initConfig( {
jshint: {
all: [
'*.js'
]
},
banana: { banana: {
all: 'i18n' all: 'i18n'
}, },
eslint: { jsonlint: {
options: {
cache: true
},
all: [ all: [
'**/*.{js,json}', '**/*.json',
'!node_modules/**', '!node_modules/**',
'!vendor/**' '!vendor/**'
] ]
} }
} ); } );
grunt.registerTask( 'test', [ 'eslint', 'banana' ] ); grunt.registerTask( 'test', [ 'jshint', 'jsonlint', 'banana' ] );
grunt.registerTask( 'default', 'test' ); grunt.registerTask( 'default', 'test' );
}; };

View file

@ -1,25 +1,19 @@
{ {
"require-dev": { "require-dev": {
"mediawiki/mediawiki-codesniffer": "45.0.0", "jakub-onderka/php-parallel-lint": "1.0.0",
"mediawiki/minus-x": "1.1.3", "mediawiki/mediawiki-codesniffer": "26.0.0",
"php-parallel-lint/php-console-highlighter": "1.0.0", "jakub-onderka/php-console-highlighter": "0.3.2",
"php-parallel-lint/php-parallel-lint": "1.4.0" "mediawiki/minus-x": "0.3.1"
}, },
"scripts": { "scripts": {
"fix": [ "fix": [
"minus-x fix .", "phpcbf",
"phpcbf" "minus-x fix ."
], ],
"test": [ "test": [
"parallel-lint . --exclude vendor --exclude node_modules", "parallel-lint . --exclude vendor --exclude node_modules",
"@phpcs", "phpcs -p -s",
"minus-x check ." "minus-x check ."
], ]
"phpcs": "phpcs -sp --cache"
},
"config": {
"allow-plugins": {
"dealerdirect/phpcodesniffer-composer-installer": true
}
} }
} }

View file

@ -1,64 +0,0 @@
{
"name": "ContributionScores",
"author": "Tim Laqua",
"url": "https://www.mediawiki.org/wiki/Extension:Contribution_Scores",
"descriptionmsg": "contributionscores-desc",
"version": "1.26.1",
"type": "specialpage",
"requires": {
"MediaWiki": ">= 1.34.0"
},
"SpecialPages": {
"ContributionScores": "ContributionScores"
},
"AutoloadClasses": {
"ContributionScores": "src/ContributionScores.php"
},
"Hooks": {
"ParserFirstCallInit": "ContributionScores::onParserFirstCallInit"
},
"MessagesDirs": {
"ContributionScores": [
"i18n"
]
},
"ExtensionMessagesFiles": {
"ContribScoreAlias": "ContributionScores.alias.php",
"ContribScoreMagic": "ContributionScores.i18n.magic.php"
},
"config": {
"ContribScoreReports": {
"value": null,
"description": "Each array defines a report - 7,50 is \"past 7 days \" and \"LIMIT 50 \" - Can be omitted."
},
"ContribScoreIgnoreBlockedUsers": {
"value": false,
"description": "Set to true to exclude blocked users from the reporting."
},
"ContribScoreIgnoreBots": {
"value": false,
"description": "Set to true to exclude bots users from the reporting."
},
"ContribScoreIgnoreUsernames": {
"value": [],
"description": "Array of usernames to exclude from the reporting."
},
"ContribScoresUseRealName": {
"value": false,
"description": "Set to true to use real user names when available."
},
"ContribScoreDisableCache": {
"value": false,
"description": "Set to true to disable cache for parser function and inclusion of table."
},
"ContribScoreUseRoughEditCount": {
"value": false,
"description": "Set to true to use the rough number of edits in user table, for performance issue."
},
"ContribScoreCacheTTL": {
"value": 30,
"description": "Cache the contribution scores data, in minutes."
}
},
"manifest_version": 2
}

View file

@ -1,8 +1,8 @@
{ {
"@metadata": { "@metadata": {
"authors": [ "authors": [
"Alp Er Tunqa", "Mousa",
"Mousa" "Alp Er Tunqa"
] ]
}, },
"contributionscores": "چالیشماق امتیازلاری", "contributionscores": "چالیشماق امتیازلاری",

View file

@ -1,10 +1,10 @@
{ {
"@metadata": { "@metadata": {
"authors": [ "authors": [
"Aftab1995",
"Aftabuzzaman",
"Bellayet", "Bellayet",
"Wikitanvir", "Wikitanvir",
"Aftab1995",
"Aftabuzzaman",
"আফতাবুজ্জামান" "আফতাবুজ্জামান"
] ]
}, },

View file

@ -3,8 +3,7 @@
"authors": [ "authors": [
"CERminator", "CERminator",
"KWiki", "KWiki",
"Srdjan m", "Srdjan m"
"Srđan"
] ]
}, },
"contributionscores": "Rezultat doprinosa", "contributionscores": "Rezultat doprinosa",

View file

@ -4,8 +4,7 @@
"Byrial", "Byrial",
"Christian List", "Christian List",
"Kaare", "Kaare",
"Peter Alberti", "Peter Alberti"
"Saederup92"
] ]
}, },
"contributionscores": "Bidragspoint", "contributionscores": "Bidragspoint",
@ -15,7 +14,6 @@
"contributionscores-days": "Sidste {{PLURAL:$1|dag|$1 dage}}", "contributionscores-days": "Sidste {{PLURAL:$1|dag|$1 dage}}",
"contributionscores-allrevisions": "Gennem tiden", "contributionscores-allrevisions": "Gennem tiden",
"contributionscores-score": "Point", "contributionscores-score": "Point",
"contributionscores-rank": "Rang",
"contributionscores-pages": "Sider", "contributionscores-pages": "Sider",
"contributionscores-changes": "Ændringer", "contributionscores-changes": "Ændringer",
"contributionscores-username": "Brugernavn", "contributionscores-username": "Brugernavn",

View file

@ -8,7 +8,7 @@
] ]
}, },
"contributionscores": "Statistik zu Benutzern", "contributionscores": "Statistik zu Benutzern",
"contributionscores-desc": "Erweitert das Wiki um eine [[Special:ContributionScores|Spezialseite]] zum Ermitteln der Benutzer mit den meisten Beiträgen", "contributionscores-desc": "Ergänzt eine [[Special:ContributionScores|Spezialseite]] zum Abfragen der Datenbank des Wikis bezüglich der Benutzer mit den meisten Beiträgen",
"contributionscores-info": "In die Bewertung fließen hauptsächlich einmalig bearbeitete Seiten unter Berücksichtigung einer hohen Bearbeitungszahl ein.", "contributionscores-info": "In die Bewertung fließen hauptsächlich einmalig bearbeitete Seiten unter Berücksichtigung einer hohen Bearbeitungszahl ein.",
"contributionscores-top": "(Top $1)", "contributionscores-top": "(Top $1)",
"contributionscores-days": "{{PLURAL:$1|Letzter Tag|Letzte $1 Tage}}", "contributionscores-days": "{{PLURAL:$1|Letzter Tag|Letzte $1 Tage}}",

View file

@ -2,8 +2,8 @@
"@metadata": { "@metadata": {
"authors": [ "authors": [
"Erdemaslancan", "Erdemaslancan",
"Marmase", "Mirzali",
"Mirzali" "Marmase"
] ]
}, },
"contributionscores": "Skorê iştıraqan", "contributionscores": "Skorê iştıraqan",
@ -11,7 +11,7 @@
"contributionscores-info": "Ebe pawıtışê hecmê tedqiqê berzi ra, puwan raveri pelanê bêemsalanê vurniyayeyan senceno.", "contributionscores-info": "Ebe pawıtışê hecmê tedqiqê berzi ra, puwan raveri pelanê bêemsalanê vurniyayeyan senceno.",
"contributionscores-top": "(Tewr Gırde $1)", "contributionscores-top": "(Tewr Gırde $1)",
"contributionscores-days": "{{PLURAL:$1|Roca peyêne|$1 Rocê peyêni}}", "contributionscores-days": "{{PLURAL:$1|Roca peyêne|$1 Rocê peyêni}}",
"contributionscores-allrevisions": "Her dem", "contributionscores-allrevisions": "Çaxan de hemi",
"contributionscores-score": "Puwan", "contributionscores-score": "Puwan",
"contributionscores-rank": "Rêze", "contributionscores-rank": "Rêze",
"contributionscores-pages": "Peli", "contributionscores-pages": "Peli",

View file

@ -4,8 +4,8 @@
"Consta", "Consta",
"Crazymadlover", "Crazymadlover",
"Omnipaedista", "Omnipaedista",
"Protnet", "ZaDiak",
"ZaDiak" "Protnet"
] ]
}, },
"contributionscores": "Βαθμολογίες συνεισφοράς", "contributionscores": "Βαθμολογίες συνεισφοράς",

View file

@ -15,4 +15,4 @@
"contributionscores-username": "Username", "contributionscores-username": "Username",
"contributionscores-invalidusername": "Invalid username", "contributionscores-invalidusername": "Invalid username",
"contributionscores-invalidmetric": "Invalid metric" "contributionscores-invalidmetric": "Invalid metric"
} }

View file

@ -2,9 +2,9 @@
"@metadata": { "@metadata": {
"authors": [ "authors": [
"Michawiki", "Michawiki",
"Mirin", "Yekrats",
"Robin van der Vliet", "Robin van der Vliet",
"Yekrats" "Mirin"
] ]
}, },
"contributionscores": "Poentaro de Kontribuoj", "contributionscores": "Poentaro de Kontribuoj",
@ -18,6 +18,6 @@
"contributionscores-pages": "Paĝoj", "contributionscores-pages": "Paĝoj",
"contributionscores-changes": "Ŝanĝoj", "contributionscores-changes": "Ŝanĝoj",
"contributionscores-username": "Uzantnomo", "contributionscores-username": "Uzantnomo",
"contributionscores-invalidusername": "Nevalida uzantnomo", "contributionscores-invalidusername": "Nevalida salutnomo",
"contributionscores-invalidmetric": "Nevalida parametro" "contributionscores-invalidmetric": "Nevalida parametro"
} }

View file

@ -6,8 +6,8 @@
"Fitoschido", "Fitoschido",
"Ihojose", "Ihojose",
"Imre", "Imre",
"Macofe", "Sanbec",
"Sanbec" "Macofe"
] ]
}, },
"contributionscores": "Puntuaciones de contribuciones", "contributionscores": "Puntuaciones de contribuciones",

8
i18n/ext.json Normal file
View file

@ -0,0 +1,8 @@
{
"@metadata": {
"authors": [
"Better"
]
},
"contributionscores-days": "Úrtimus $1 dias"
}

View file

@ -1,13 +1,13 @@
{ {
"@metadata": { "@metadata": {
"authors": [ "authors": [
"Alirezaaa",
"Ebraminio", "Ebraminio",
"Huji", "Huji",
"Mjbmr", "Mjbmr",
"Reza1615", "Reza1615",
"Tofighi", "Tofighi",
"ZxxZxxZ" "ZxxZxxZ",
"Alirezaaa"
] ]
}, },
"contributionscores": "امتیاز مشارکت", "contributionscores": "امتیاز مشارکت",

View file

@ -1,13 +1,12 @@
{ {
"@metadata": { "@metadata": {
"authors": [ "authors": [
"01miki10",
"Crt", "Crt",
"Nike", "Nike",
"Pxos",
"Pyscowicz",
"Str4nd", "Str4nd",
"Stryn" "Stryn",
"Pxos",
"Pyscowicz"
] ]
}, },
"contributionscores": "Muokkauspisteet", "contributionscores": "Muokkauspisteet",
@ -19,7 +18,7 @@
"contributionscores-rank": "Sija", "contributionscores-rank": "Sija",
"contributionscores-pages": "Sivuja", "contributionscores-pages": "Sivuja",
"contributionscores-changes": "Muutoksia", "contributionscores-changes": "Muutoksia",
"contributionscores-username": "Käyttäjänimi", "contributionscores-username": "Käyttäjätunnus",
"contributionscores-invalidusername": "Virheellinen käyttäjänimi", "contributionscores-invalidusername": "Virheellinen käyttäjätunnus",
"contributionscores-invalidmetric": "Virheellinen muuttuja" "contributionscores-invalidmetric": "Virheellinen muuttuja"
} }

View file

@ -1,8 +0,0 @@
{
"@metadata": {
"authors": [
"Pyscowicz"
]
},
"contributionscores": "Mookkauspisteet"
}

View file

@ -21,6 +21,6 @@
"contributionscores-pages": "Pages", "contributionscores-pages": "Pages",
"contributionscores-changes": "Changements", "contributionscores-changes": "Changements",
"contributionscores-username": "Nom dutilisateur", "contributionscores-username": "Nom dutilisateur",
"contributionscores-invalidusername": "Nom dutilisateur incorrect", "contributionscores-invalidusername": "Nom dutilisateur invalide",
"contributionscores-invalidmetric": "Métrique incorrecte" "contributionscores-invalidmetric": "Métrique incorrecte"
} }

View file

@ -1,10 +1,10 @@
{ {
"@metadata": { "@metadata": {
"authors": [ "authors": [
"PiefPafPier", "Snakesteuben",
"Robin van der Vliet",
"Robin0van0der0vliet", "Robin0van0der0vliet",
"Snakesteuben" "Robin van der Vliet",
"PiefPafPier"
] ]
}, },
"contributionscores-username": "Meidochnamme" "contributionscores-username": "Meidochnamme"

View file

@ -3,8 +3,8 @@
"authors": [ "authors": [
"Ansumang", "Ansumang",
"Kaustubh", "Kaustubh",
"Sfic", "Siddhartha Ghai",
"Siddhartha Ghai" "Sfic"
] ]
}, },
"contributionscores": "योगदान संख्या", "contributionscores": "योगदान संख्या",

View file

@ -3,21 +3,19 @@
"authors": [ "authors": [
"Dalibor Bosits", "Dalibor Bosits",
"Ex13", "Ex13",
"MaGa",
"SpeedyGonsales" "SpeedyGonsales"
] ]
}, },
"contributionscores": "Najbolji suradnici", "contributionscores": "Najbolji suradnici",
"contributionscores-desc": "Šalje upit bazi podataka za najveći [[Special:ContributionScores|broj suradničkih doprinosa]]", "contributionscores-desc": "Šalje upit bazi podataka za najveći [[Special:ContributionScores|broj suradničkih doprinosa]]",
"contributionscores-info": "U prvom planu rezultat mjeri jedinstvene izmijenjene stranice, uzimajući u obzir veliku količinu uređivanja.", "contributionscores-info": "Rezultat se dobiva kao suma slijedećih stavki:\n*1 bod za svaku stranicu koju ste uređivali\n* (kvadratni) korijen iz (broja ukupnih uređivanja) - (broja stranica koje ste uređivali) * 2\n\nRezultat dobiven na ovaj način daje veću težinu broju uređivanja različitih stranica nego ukupnom broju uređivanja. U osnovi, ovakav rezultat mjeri prvenstveno broj različitih stranica koje ste uređivali, uzimajući u obzir broj uređivanja, jer veći broj uređivanja na nekom članku daje kvalitetniji članak.",
"contributionscores-top": "(najboljih $1)", "contributionscores-top": "(Najboljih $1)",
"contributionscores-days": "{{PLURAL:$1|Zadnji dan|Zadnjih $1 dana}}", "contributionscores-days": "{{PLURAL:$1|Zadnji dan|Zadnjih $1 dana}}",
"contributionscores-allrevisions": "Sve vrijeme", "contributionscores-allrevisions": "Sva uređivanja",
"contributionscores-score": "Rezultat", "contributionscores-score": "Rezultat",
"contributionscores-rank": "Mjesto",
"contributionscores-pages": "Stranica", "contributionscores-pages": "Stranica",
"contributionscores-changes": "Uređivanja", "contributionscores-changes": "Uređivanja",
"contributionscores-username": "Suradničko ime", "contributionscores-username": "Ime suradnika",
"contributionscores-invalidusername": "Nevaljano suradničko ime", "contributionscores-invalidusername": "Nevaljano suradničko ime",
"contributionscores-invalidmetric": "Nevaljana metrika" "contributionscores-invalidmetric": "Nevaljana metrika"
} }

View file

@ -6,12 +6,11 @@
}, },
"contributionscores": "Contes de contribution", "contributionscores": "Contes de contribution",
"contributionscores-desc": "Calcula li funde de data del wiki por max alt [[Special:ContributionScores|volúmine de contribution de usator]]", "contributionscores-desc": "Calcula li funde de data del wiki por max alt [[Special:ContributionScores|volúmine de contribution de usator]]",
"contributionscores-info": "Li calcul primarimen mesura págines unic redactet, considerant li alt volume de redactiones.", "contributionscores-info": "Contes es calculat quam seque:\n*Un (1) punctu por chascun págine unic redactet\n*Fonte de quadrat de (total de redactiones fat) - (total unique pages) * 2\nContes calculat in ti diversitá de redaction in pesa maniere súper de volúmine de redaction.\nBasicmen, ti conte mesura primarimen págines unic redactet, che consideration por alt volúmine de redaction - suposit esser un págine de alt qualitá.",
"contributionscores-top": "(Prim $1)", "contributionscores-top": "(Prim $1)",
"contributionscores-days": "Ultim {{PLURAL:$1|die|$1 dies}}", "contributionscores-days": "Ultim {{PLURAL:$1|die|$1 dies}}",
"contributionscores-allrevisions": "Omni témpor", "contributionscores-allrevisions": "Omni témpor",
"contributionscores-score": "Conte", "contributionscores-score": "Conte",
"contributionscores-rank": "Classification",
"contributionscores-pages": "Págines", "contributionscores-pages": "Págines",
"contributionscores-changes": "Changes", "contributionscores-changes": "Changes",
"contributionscores-username": "Nómine de usator", "contributionscores-username": "Nómine de usator",

View file

@ -5,8 +5,5 @@
] ]
}, },
"contributionscores-days": "Lasta {{PLURAL:$1|dio|$1 dii}}", "contributionscores-days": "Lasta {{PLURAL:$1|dio|$1 dii}}",
"contributionscores-score": "Nombro di punti", "contributionscores-pages": "Pagini"
"contributionscores-pages": "Pagini",
"contributionscores-changes": "Modifikuri",
"contributionscores-username": "Uzeronomo"
} }

View file

@ -1,15 +1,13 @@
{ {
"@metadata": { "@metadata": {
"authors": [ "authors": [
"Diki Ananta",
"Meursault2004", "Meursault2004",
"NoiX180",
"Pras", "Pras",
"Sumbukompor" "NoiX180"
] ]
}, },
"contributionscores": "Bijining pasumbang", "contributionscores": "Bijining pasumbang",
"contributionscores-desc": "Nglakokaké polling (angkèt) ing basis data kanggo [[Special:ContributionScores|volume kontribusi naraguna]]", "contributionscores-desc": "Nglakokaké polling (angkèt) ing basis data kanggo [[Special:ContributionScores|volume kontribusi panganggo]]",
"contributionscores-info": "Skoré diétung kaya mangkéné:\n* Biji siji (1) per kaca unik sing disunting\n* Oyot (bs. Indonesia ''akar'') saka (Gunggungé Suntingan) - (Gunggungé Kaca-KAca Unik) * 2\nSkor sing diétung miturut cara iki bisa nyerminaké divèrsitas suntingan sadhuwuring volume suntingan.\nSacara dhasar, skor iki utamané ngétung kaca-kaca unik sing disunting, karo mélu nimbangaké volume suntingan dhuwur - diasumsèkaké kwalitas kacané luwih dhuwur.", "contributionscores-info": "Skoré diétung kaya mangkéné:\n* Biji siji (1) per kaca unik sing disunting\n* Oyot (bs. Indonesia ''akar'') saka (Gunggungé Suntingan) - (Gunggungé Kaca-KAca Unik) * 2\nSkor sing diétung miturut cara iki bisa nyerminaké divèrsitas suntingan sadhuwuring volume suntingan.\nSacara dhasar, skor iki utamané ngétung kaca-kaca unik sing disunting, karo mélu nimbangaké volume suntingan dhuwur - diasumsèkaké kwalitas kacané luwih dhuwur.",
"contributionscores-top": "(Top $1)", "contributionscores-top": "(Top $1)",
"contributionscores-days": "{{PLURAL:$1|dina|$1 dina}} pungkasan", "contributionscores-days": "{{PLURAL:$1|dina|$1 dina}} pungkasan",
@ -18,7 +16,7 @@
"contributionscores-rank": "Rangking", "contributionscores-rank": "Rangking",
"contributionscores-pages": "Kaca", "contributionscores-pages": "Kaca",
"contributionscores-changes": "Owah-owahan", "contributionscores-changes": "Owah-owahan",
"contributionscores-username": "Jeneng naraguna", "contributionscores-username": "Jeneng panganggo",
"contributionscores-invalidusername": "Jeneng naraguna ora sah", "contributionscores-invalidusername": "Jeneng panganggo ora sah",
"contributionscores-invalidmetric": "Metrik ora sah" "contributionscores-invalidmetric": "Metrik ora sah"
} }

View file

@ -1,7 +1,5 @@
{ {
"@metadata": { "@metadata": [],
"authors": []
},
"contributionscores": "Üles berw esepteri", "contributionscores": "Üles berw esepteri",
"contributionscores-info": "Esepter kelesi deý sanaladı:\n*1 upaý ärbir tüzetilgen biregeý bet üşin\n*Mınanıñ şarşı tübiri (Barlıq İstelingen Tüzetwler) (Barlıq Biregeý Better) * 2\nOsı täsilmen sanalğan esepter tüzetw awqımındağı öñdew ärkelkiliginiñ salmağın ölşeýdi. Negizinde, bul esep aldımen tüzetilgen birkelki betterdi ölşeýdi, joğarğı öñdew awqımımen birge — joğarı sapalı bet jağdaýımen eseptep.", "contributionscores-info": "Esepter kelesi deý sanaladı:\n*1 upaý ärbir tüzetilgen biregeý bet üşin\n*Mınanıñ şarşı tübiri (Barlıq İstelingen Tüzetwler) (Barlıq Biregeý Better) * 2\nOsı täsilmen sanalğan esepter tüzetw awqımındağı öñdew ärkelkiliginiñ salmağın ölşeýdi. Negizinde, bul esep aldımen tüzetilgen birkelki betterdi ölşeýdi, joğarğı öñdew awqımımen birge — joğarı sapalı bet jağdaýımen eseptep.",
"contributionscores-top": "(Joğarğı $1)", "contributionscores-top": "(Joğarğı $1)",

View file

@ -3,9 +3,9 @@
"authors": [ "authors": [
"Hym411", "Hym411",
"Priviet", "Priviet",
"Revi",
"Shirayuki", "Shirayuki",
"아라" "아라",
"Revi"
] ]
}, },
"contributionscores": "기여 점수", "contributionscores": "기여 점수",

View file

@ -1,12 +1,10 @@
{ {
"@metadata": { "@metadata": {
"authors": [ "authors": [
"Balyozxane",
"George Animal" "George Animal"
] ]
}, },
"contributionscores-allrevisions": "Hemû dem", "contributionscores-allrevisions": "Hemû dem",
"contributionscores-pages": "Rûpel", "contributionscores-pages": "Rûpel",
"contributionscores-changes": "Guhartin",
"contributionscores-username": "Navê bikarhêner" "contributionscores-username": "Navê bikarhêner"
} }

View file

@ -6,7 +6,7 @@
] ]
}, },
"contributionscores": "Bewäertung vun den Ännerungen", "contributionscores": "Bewäertung vun den Ännerungen",
"contributionscores-desc": "Ufro un d'Wiki-Datebank no den héchste [[Special:ContributionScores|Benotzerscoren]]", "contributionscores-desc": "Ufro un d'Wiki-Datebank no den héichste [[Special:ContributionScores|Benotzerscoren]]",
"contributionscores-info": "D'Bewäertung moosst Zuel vu geännerte Säite a consideréiert d'Zuel vun den Ännerungen.", "contributionscores-info": "D'Bewäertung moosst Zuel vu geännerte Säite a consideréiert d'Zuel vun den Ännerungen.",
"contributionscores-top": "(Top $1)", "contributionscores-top": "(Top $1)",
"contributionscores-days": "{{PLURAL:$1|Leschten Dag|Lescht $1 Deeg}}", "contributionscores-days": "{{PLURAL:$1|Leschten Dag|Lescht $1 Deeg}}",

View file

@ -1,8 +0,0 @@
{
"@metadata": {
"authors": [
"Giromin Cangiaxo"
]
},
"contributionscores": "Pontezzi contributi"
}

View file

@ -6,7 +6,7 @@
}, },
"contributionscores": "Оцени за придонеси", "contributionscores": "Оцени за придонеси",
"contributionscores-desc": "Презема податоци од викибазата за [[Special:ContributionScores|корисници со највеќе придонеси]]", "contributionscores-desc": "Презема податоци од викибазата за [[Special:ContributionScores|корисници со највеќе придонеси]]",
"contributionscores-info": "Салдото е мерка што изразува уредувања на одделни страници, со оглед на големиот број на уредувања.", "contributionscores-info": "Салдото е мерка што изразува уредувања на засебни страници, со оглед на големиот број на уредувања.",
"contributionscores-top": "(Најдобри $1)", "contributionscores-top": "(Најдобри $1)",
"contributionscores-days": "{{PLURAL:$1|Последниот ден|Последните $1 дена}}", "contributionscores-days": "{{PLURAL:$1|Последниот ден|Последните $1 дена}}",
"contributionscores-allrevisions": "На сите времиња", "contributionscores-allrevisions": "На сите времиња",
@ -16,5 +16,5 @@
"contributionscores-changes": "Измени", "contributionscores-changes": "Измени",
"contributionscores-username": "Корисничко име", "contributionscores-username": "Корисничко име",
"contributionscores-invalidusername": "Неправилно корисничко име", "contributionscores-invalidusername": "Неправилно корисничко име",
"contributionscores-invalidmetric": "Грешно мерило" "contributionscores-invalidmetric": "Грешна метрика"
} }

View file

@ -1,13 +0,0 @@
{
"@metadata": {
"authors": [
"Awangba Mangang"
]
},
"contributionscores-allrevisions": "ꯃꯇꯝ ꯄꯨꯂꯞ",
"contributionscores-rank": "ꯊꯥꯛ",
"contributionscores-pages": "ꯂꯃꯥꯏꯁꯤꯡ",
"contributionscores-changes": "ꯑꯍꯣꯡꯕꯁꯤꯡ",
"contributionscores-username": "ꯁꯤꯖꯤꯟꯅꯔꯤꯕ ꯃꯃꯤꯡ",
"contributionscores-invalidusername": "ꯁꯤꯖꯤꯟꯅꯔꯤꯕ ꯃꯃꯤꯡ ꯌꯥꯎꯗꯦ"
}

View file

@ -1,8 +1,8 @@
{ {
"@metadata": { "@metadata": {
"authors": [ "authors": [
"Dr Lotus Black", "Ninjastrikers",
"Ninjastrikers" "Dr Lotus Black"
] ]
}, },
"contributionscores": "ပံ့ပို့မှု ရမှတ်များ", "contributionscores": "ပံ့ပို့မှု ရမှတ်များ",

View file

@ -1,10 +1,9 @@
{ {
"@metadata": { "@metadata": {
"authors": [ "authors": [
"Akapochtli",
"Fluence" "Fluence"
] ]
}, },
"contributionscores-changes": "Tlapatlaliztli", "contributionscores-changes": "Tlapatlaliztli",
"contributionscores-username": "Tequitiuhcatocaitll" "contributionscores-username": "Tlatequitiltilīltōcāitl"
} }

View file

@ -1,10 +1,10 @@
{ {
"@metadata": { "@metadata": {
"authors": [ "authors": [
"Danmichaelo", "Nghtwlkr",
"Helland", "Helland",
"Jon Harald Søby", "Danmichaelo",
"Nghtwlkr" "Jon Harald Søby"
] ]
}, },
"contributionscores": "Bidragspoeng", "contributionscores": "Bidragspoeng",

View file

@ -1,17 +1,8 @@
{ {
"@metadata": { "@metadata": {
"authors": [ "authors": [
"RajeshPandey", "RajeshPandey"
"पर्वत सुबेदी"
] ]
}, },
"contributionscores": "योगदान प्राप्ताङ्कहरू", "contributionscores-username": "प्रयोगकर्ता नाम"
"contributionscores-days": "अन्तिम {{PLURAL:$1|दिन|$1 दिनहरू}}",
"contributionscores-allrevisions": "सबै समय",
"contributionscores-score": "प्राप्ताङ्क",
"contributionscores-rank": "क्रम",
"contributionscores-pages": "पृष्ठहरू",
"contributionscores-changes": "परिवर्तनहरू",
"contributionscores-username": "प्रयोगकर्ता नाम",
"contributionscores-invalidusername": "अबैध प्रयोगकर्ता नाम"
} }

View file

@ -5,10 +5,10 @@
"Derbeth", "Derbeth",
"Equadus", "Equadus",
"McMonster", "McMonster",
"Rail",
"Railfail536",
"Sp5uhe", "Sp5uhe",
"Wpedzich" "Wpedzich",
"Railfail536",
"Rail"
] ]
}, },
"contributionscores": "Punkty za edycje", "contributionscores": "Punkty za edycje",

View file

@ -1,11 +1,9 @@
{ {
"@metadata": { "@metadata": {
"authors": [ "authors": [
"Abbas dhothar",
"BukhariSaeed" "BukhariSaeed"
] ]
}, },
"contributionscores-days": "پچھلے{{PLURAL:$1|دن|$1 دناں}}",
"contributionscores-changes": "تبدیلیاں", "contributionscores-changes": "تبدیلیاں",
"contributionscores-username": "ورتن آلے دا ناں" "contributionscores-username": "ورتن آلے دا ناں"
} }

View file

@ -2,8 +2,8 @@
"@metadata": { "@metadata": {
"authors": [ "authors": [
"Ahmed-Najib-Biabani-Ibrahimkhel", "Ahmed-Najib-Biabani-Ibrahimkhel",
"Amjad Khan", "Baloch Khan",
"Baloch Khan" "Amjad Khan"
] ]
}, },
"contributionscores-days": "وروستۍ {{PLURAL:$1|ورځ|$1 ورځې}}", "contributionscores-days": "وروستۍ {{PLURAL:$1|ورځ|$1 ورځې}}",

View file

@ -1,13 +1,13 @@
{ {
"@metadata": { "@metadata": {
"authors": [ "authors": [
"!Silent",
"Brunoy Anastasiya Seryozhenko", "Brunoy Anastasiya Seryozhenko",
"Crazymadlover", "Crazymadlover",
"Eduardo.mps", "Eduardo.mps",
"Giro720", "Giro720",
"HenriqueCrang",
"Luckas", "Luckas",
"HenriqueCrang",
"!Silent",
"Opraco" "Opraco"
] ]
}, },

View file

@ -1,11 +1,11 @@
{ {
"@metadata": { "@metadata": {
"authors": [ "authors": [
"Fúlvio",
"Hamilton Abreu", "Hamilton Abreu",
"Malafaya", "Malafaya",
"Vitorvicentevalente",
"Waldir", "Waldir",
"Vitorvicentevalente",
"Fúlvio",
"Waldyrious" "Waldyrious"
] ]
}, },

View file

@ -4,11 +4,11 @@
"Jon Harald Søby", "Jon Harald Søby",
"JtFuruhata", "JtFuruhata",
"Kalan", "Kalan",
"Liuxinyu970226",
"Mormegil", "Mormegil",
"Purodha", "Purodha",
"Raymond", "Raymond",
"Shirayuki", "Shirayuki",
"Liuxinyu970226",
"Tacsipacsi" "Tacsipacsi"
] ]
}, },

View file

@ -2,12 +2,12 @@
"@metadata": { "@metadata": {
"authors": [ "authors": [
"Ahonc", "Ahonc",
"Kaganer",
"Kalan", "Kalan",
"Lockal", "Lockal",
"Okras", "Okras",
"Ole Yves", "Ole Yves",
"Александр Сигачёв" "Александр Сигачёв",
"Kaganer"
] ]
}, },
"contributionscores": "Оценка вклада", "contributionscores": "Оценка вклада",

View file

@ -2,19 +2,16 @@
"@metadata": { "@metadata": {
"authors": [ "authors": [
"Helix84", "Helix84",
"Luky001", "Teslaton"
"Teslaton",
"Yardom78"
] ]
}, },
"contributionscores": "Skóre príspevkov", "contributionscores": "Skóre príspevkov",
"contributionscores-desc": "Získava údaje z databázy wiki o [[Special:ContributionScores|množstve používateľských príspevkov]]", "contributionscores-desc": "Zisťuje naväčší [[Special:ContributionScores|objem používateľských príspevkov]] z databázy wiki",
"contributionscores-info": "Skóre primárne meria jedinečné editované stránky s ohľadom na veľké množstvo úprav.", "contributionscores-info": "Skóre sa počíta nasledovne:\n*1 bod za každú jedinečnú stránku, ktorú používateľ upravoval\n*Odmocnina z (celkom úprav) - (celkom jedinečných stránok) * 2\nSkóre vypočítané týmto spôsobom vážia diverzitu úprav viac ako objem úprav. V podstate toto skóre meria najmä počet upravovaných jedinečných stránok s prihliadnutím na vysoký objem úprav; čo sa pokladá za stránku vyššej kvality.",
"contributionscores-top": "(Najlepších $1)", "contributionscores-top": "(Najlepších $1)",
"contributionscores-days": "{{PLURAL:$1|Posledný $1 deň|Posledné $1 dni|Posledných $1 dní}}", "contributionscores-days": "{{PLURAL:$1|Posledný $1 deň|Posledné $1 dni|Posledných $1 dní}}",
"contributionscores-allrevisions": "Celkom", "contributionscores-allrevisions": "Celá história",
"contributionscores-score": "Skóre", "contributionscores-score": "Skóre",
"contributionscores-rank": "Poradie",
"contributionscores-pages": "Stránky", "contributionscores-pages": "Stránky",
"contributionscores-changes": "Zmeny", "contributionscores-changes": "Zmeny",
"contributionscores-username": "Používateľské meno", "contributionscores-username": "Používateľské meno",

View file

@ -1,13 +1,12 @@
{ {
"@metadata": { "@metadata": {
"authors": [ "authors": [
"Acamicamacaraca",
"Kizule",
"Milicevic01", "Milicevic01",
"Rancher", "Rancher",
"Sasa Stefanovic", "Sasa Stefanovic",
"Михајло Анђелковић",
"Zoranzoki21", "Zoranzoki21",
"Михајло Анђелковић" "Acamicamacaraca"
] ]
}, },
"contributionscores": "Оцене доприноса", "contributionscores": "Оцене доприноса",

View file

@ -1,22 +1,18 @@
{ {
"@metadata": { "@metadata": {
"authors": [ "authors": [
"Aefgh39622", "Woraponboonkerd",
"Ans", "Ans"
"Woraponboonkerd"
] ]
}, },
"contributionscores": "คะแนนการแก้ไข", "contributionscores": "คะแนนการแก้ไข",
"contributionscores-desc": "จัดอันดับฐานข้อมูลของวิกิสำหรับ[[Special:ContributionScores|ผู้ใ้ช้ที่มีจำนวนการแก้ไขสูงสุด]]", "contributionscores-desc": "จัดอันดับฐานข้อมูลของวิกิสำหรับ[[Special:ContributionScores|ผู้ใ้ช้ที่มีจำนวนการแก้ไขสูงสุด]]",
"contributionscores-info": "คะแนนคิดจากจำนวนหน้าที่เข้าร่วมแก้ไข พร้อมพิจารณาปริมาณการแก้ไขเป็นหลัก", "contributionscores-info": "วิธีการคิดคะแนนเป็นดังต่อไปนี้:\n* หนึ่ง (1) คะแนนต่อจำนวนหน้าที่เข้าร่วมแก้ไข (ชื่อของหน้าไม่ซ้ำกัน)\n* รากที่สองของจำนวนการแก้ไขทั้งหมด - จำนวนหน้าทั้งหมดที่ร่วมแก้ไข * 2\nคะแนนจะถูกคิดโดยให้น้ำหนักของการแก้ไขที่หลากหลายมากกว่าจำนวนการแก้ไข\nโดยทั่วไป คะแนนนี้ชี้วัดถึงจำนวนหน้าต่างๆ ที่เข้าร่วมแก้ไข โดยคำนึงถึงจำนวนการแก้ไขทั้งหมดด้วย จึงคาดการณ์ได้ว่าจะทำให้มีหน้าที่มีคุณภาพสูงขึ้น",
"contributionscores-top": "($1 อันดับแรก)",
"contributionscores-days": "$1 {{PLURAL:$1|วัน|วัน}} ที่แล้ว", "contributionscores-days": "$1 {{PLURAL:$1|วัน|วัน}} ที่แล้ว",
"contributionscores-allrevisions": "ตลอดเวลา",
"contributionscores-score": "คะแนน", "contributionscores-score": "คะแนน",
"contributionscores-rank": "การจัดอันดับ", "contributionscores-rank": "การจัดอันดับ",
"contributionscores-pages": "จำนวนหน้า", "contributionscores-pages": "จำนวนหน้า",
"contributionscores-changes": "การเปลี่ยนแปลง", "contributionscores-changes": "การเปลี่ยนแปลง",
"contributionscores-username": "ชื่อผู้ใช้", "contributionscores-username": "ชื่อผู้ใช้",
"contributionscores-invalidusername": "ชื่อผู้ใช้ไม่ถูกต้อง", "contributionscores-invalidusername": "ชื่อผู้ใช้ไม่ถูกต้อง"
"contributionscores-invalidmetric": "เกณฑ์ชี้วัดไม่ถูกต้อง"
} }

View file

@ -1,10 +0,0 @@
{
"@metadata": {
"authors": [
"Joanmp17"
]
},
"contributionscores-pages": "ገጻት",
"contributionscores-changes": "ለውጥታት",
"contributionscores-username": "ስም ተጠቃሚ"
}

View file

@ -1,12 +1,12 @@
{ {
"@metadata": { "@metadata": {
"authors": [ "authors": [
"Hedda",
"Joseph", "Joseph",
"Karduelis", "Karduelis",
"Mach", "Mach",
"Suelnur", "Suelnur",
"Vito Genovese" "Vito Genovese",
"Hedda"
] ]
}, },
"contributionscores": "Katkı puanları", "contributionscores": "Katkı puanları",

View file

@ -1,7 +1,6 @@
{ {
"@metadata": { "@metadata": {
"authors": [ "authors": [
"Ерней",
"Ильнар" "Ильнар"
] ]
}, },
@ -11,10 +10,10 @@
"contributionscores-top": "(Иң әйбәт $1)", "contributionscores-top": "(Иң әйбәт $1)",
"contributionscores-days": "Соңгы {{PLURAL:$1|$1 көн өчен}}", "contributionscores-days": "Соңгы {{PLURAL:$1|$1 көн өчен}}",
"contributionscores-allrevisions": "Бөтен вакыт өчен", "contributionscores-allrevisions": "Бөтен вакыт өчен",
"contributionscores-score": әя", "contributionscores-score": илге",
"contributionscores-rank": "Ранг", "contributionscores-rank": "Ранг",
"contributionscores-pages": "Битләр", "contributionscores-pages": "Битләр саны",
"contributionscores-changes": "Төзәтмәләр", "contributionscores-changes": "Үзгәртүләр",
"contributionscores-username": "Кулланучы исеме", "contributionscores-username": "Кулланучы исеме",
"contributionscores-invalidusername": "Кулланучының исеме дөрес түгел", "contributionscores-invalidusername": "Кулланучының исеме дөрес түгел",
"contributionscores-invalidmetric": "Ялгыш билгеләү" "contributionscores-invalidmetric": "Ялгыш билгеләү"

View file

@ -1,18 +1,17 @@
{ {
"@metadata": { "@metadata": {
"authors": [ "authors": [
"Candalua", "Candalua"
"Fierodelveneto"
] ]
}, },
"contributionscores": "Ponteji contribusion", "contributionscores": "Puntegi contributi",
"contributionscores-desc": "Intèroga el database de la wiki par el pi grando [[Special:ContributionScores|volume de contributi utente]]", "contributionscores-desc": "Intèroga el database de la wiki par el pi grando [[Special:ContributionScores|volume de contributi utente]]",
"contributionscores-info": "I punti i vien calcolà come segue:\n*Un (1) punto par ogni diversa pagina modificà\n*Raìsa quadrata de (Tute le modifiche fate) - (Total de le pagine modificà) * 2\nFasendo i conti in sta maniera pesa piassè la diversità de le modifiche rispeto al nùmaro dei contributi.\nIn sostansa, sto puntegio el tien conto sopratuto de le diverse pagine modificà, tegnendo in considerazion anca un alto volume de modifiche - che fa pensar a na pi alta qualità de la pagina modificà.", "contributionscores-info": "I punti i vien calcolà come segue:\n*Un (1) punto par ogni diversa pagina modificà\n*Raìsa quadrata de (Tute le modifiche fate) - (Total de le pagine modificà) * 2\nFasendo i conti in sta maniera pesa piassè la diversità de le modifiche rispeto al nùmaro dei contributi.\nIn sostansa, sto puntegio el tien conto sopratuto de le diverse pagine modificà, tegnendo in considerazion anca un alto volume de modifiche - che fa pensar a na pi alta qualità de la pagina modificà.",
"contributionscores-top": "(Ultimi $1)", "contributionscores-top": "(Ultimi $1)",
"contributionscores-days": "{{PLURAL:$1|Ultimo zòrno|Ultimi $1 zòrni}}", "contributionscores-days": "{{PLURAL:$1|Ultimo zòrno|Ultimi $1 zòrni}}",
"contributionscores-allrevisions": "Tute le revision", "contributionscores-allrevisions": "Tute le revision",
"contributionscores-score": "Puntegio", "contributionscores-score": "Puntegio",
"contributionscores-pages": "Pàjine", "contributionscores-pages": "Pagine",
"contributionscores-changes": "Canbiamenti", "contributionscores-changes": "Canbiamenti",
"contributionscores-username": "Nome utente", "contributionscores-username": "Nome utente",
"contributionscores-invalidusername": "Nome utente mia valido", "contributionscores-invalidusername": "Nome utente mia valido",

View file

@ -2,7 +2,6 @@
"@metadata": { "@metadata": {
"authors": [ "authors": [
"Minh Nguyen", "Minh Nguyen",
"Phjtieudoc",
"Vinhtantran" "Vinhtantran"
] ]
}, },
@ -14,7 +13,7 @@
"contributionscores-allrevisions": "Từ trước đến nay", "contributionscores-allrevisions": "Từ trước đến nay",
"contributionscores-score": "Điểm số", "contributionscores-score": "Điểm số",
"contributionscores-pages": "Trang", "contributionscores-pages": "Trang",
"contributionscores-changes": "Thay đổi", "contributionscores-changes": "Các thay đổi",
"contributionscores-username": "Tên người dùng", "contributionscores-username": "Tên người dùng",
"contributionscores-invalidusername": "Tên người dùng không hợp lệ", "contributionscores-invalidusername": "Tên người dùng không hợp lệ",
"contributionscores-invalidmetric": "Chuẩn đo không hợp lệ" "contributionscores-invalidmetric": "Chuẩn đo không hợp lệ"

View file

@ -1,9 +1,7 @@
{ {
"@metadata": { "@metadata": {
"authors": [ "authors": [
"Moon0319",
"PhiLiP", "PhiLiP",
"Roy17",
"Shinjiman", "Shinjiman",
"Shirayuki", "Shirayuki",
"Yueman" "Yueman"
@ -14,7 +12,7 @@
"contributionscores-info": "呢個分數係會依主要嘅唯一編輯過嘅頁,同埋考慮高編輯量。", "contributionscores-info": "呢個分數係會依主要嘅唯一編輯過嘅頁,同埋考慮高編輯量。",
"contributionscores-top": "(最高$1名)", "contributionscores-top": "(最高$1名)",
"contributionscores-days": "最近$1日", "contributionscores-days": "最近$1日",
"contributionscores-allrevisions": "有史以來", "contributionscores-allrevisions": "全部時間",
"contributionscores-score": "分數", "contributionscores-score": "分數",
"contributionscores-rank": "等級", "contributionscores-rank": "等級",
"contributionscores-pages": "版", "contributionscores-pages": "版",

View file

@ -1,15 +1,15 @@
{ {
"@metadata": { "@metadata": {
"authors": [ "authors": [
"Cwlin0416",
"Kly",
"LNDDYL",
"Liuxinyu970226",
"Mark85296341", "Mark85296341",
"PhiLiP", "PhiLiP",
"Shinjiman", "Shinjiman",
"Shirayuki", "Shirayuki",
"Simon Shek" "Simon Shek",
"Cwlin0416",
"Liuxinyu970226",
"LNDDYL",
"Kly"
] ]
}, },
"contributionscores": "貢獻分數", "contributionscores": "貢獻分數",

7732
package-lock.json generated

File diff suppressed because it is too large Load diff

View file

@ -1,13 +1,13 @@
{ {
"name": "ContributionScores",
"private": true, "private": true,
"scripts": { "scripts": {
"test": "grunt test" "test": "grunt test"
}, },
"devDependencies": { "devDependencies": {
"eslint-config-wikimedia": "0.28.2", "grunt": "1.0.4",
"grunt": "1.6.1", "grunt-banana-checker": "0.4.0",
"grunt-banana-checker": "0.13.0", "grunt-contrib-jshint": "0.11.3",
"grunt-eslint": "24.3.0" "grunt-jscs": "2.5.0",
"grunt-jsonlint": "1.0.7"
} }
} }

View file

@ -1,436 +0,0 @@
<?php
/** \file
* \brief Contains code for the ContributionScores Class (extends SpecialPage).
*/
use MediaWiki\MediaWikiServices;
/// Special page class for the Contribution Scores extension
/**
* Special page that generates a list of wiki contributors based
* on edit diversity (unique pages edited) and edit volume (total
* number of edits.
*
* @ingroup Extensions
* @author Tim Laqua <t.laqua@gmail.com>
*/
class ContributionScores extends IncludableSpecialPage {
const CONTRIBUTIONSCORES_MAXINCLUDELIMIT = 50;
public function __construct() {
parent::__construct( 'ContributionScores' );
}
public static function onParserFirstCallInit( Parser $parser ) {
$parser->setFunctionHook( 'cscore', [ self::class, 'efContributionScoresRender' ] );
}
public static function efContributionScoresRender( $parser, $usertext, $metric = 'score' ) {
global $wgContribScoreDisableCache, $wgContribScoreUseRoughEditCount;
if ( $wgContribScoreDisableCache ) {
$parser->getOutput()->updateCacheExpiry( 0 );
}
$user = User::newFromName( $usertext );
$loadBalancer = MediaWikiServices::getInstance()->getDBLoadBalancer();
$dbr = $loadBalancer->getConnection( DB_REPLICA );
if ( $user instanceof User && $user->isRegistered() ) {
global $wgLang;
$revVar = $wgContribScoreUseRoughEditCount ? 'user_editcount' : 'COUNT(rev_id)';
$revWhere = ActorMigration::newMigration()->getWhere( $dbr, 'rev_user', $user );
if ( $metric == 'score' ) {
$row = $dbr->selectRow(
[ 'revision' ] + $revWhere['tables'],
[ 'wiki_rank' => "COUNT(DISTINCT rev_page)+SQRT($revVar-COUNT(DISTINCT rev_page))*2" ],
$revWhere['conds'],
__METHOD__,
[],
$revWhere['joins']
);
$output = $wgLang->formatNum( round( $row->wiki_rank, 0 ) );
} elseif ( $metric == 'changes' ) {
$row = $dbr->selectRow(
[ 'revision' ] + $revWhere['tables'],
[ 'rev_count' => $revVar ],
$revWhere['conds'],
__METHOD__,
[],
$revWhere['joins']
);
$output = $wgLang->formatNum( $row->rev_count );
} elseif ( $metric == 'pages' ) {
$row = $dbr->selectRow(
[ 'revision' ] + $revWhere['tables'],
[ 'page_count' => 'COUNT(DISTINCT rev_page)' ],
$revWhere['conds'],
__METHOD__,
[],
$revWhere['joins']
);
$output = $wgLang->formatNum( $row->page_count );
} else {
$output = wfMessage( 'contributionscores-invalidmetric' )->text();
}
} else {
$output = wfMessage( 'contributionscores-invalidusername' )->text();
}
return $parser->insertStripItem( $output, $parser->getStripState() );
}
/**
* Function fetch Contribution Scores data from database
*
* @param int $days Days in the past to run report for
* @param int $limit Maximum number of users to return (default 50)
* @return array Data including the requested Contribution Scores.
*/
public static function getContributionScoreData( $days, $limit ) {
global $wgContribScoreIgnoreBots, $wgContribScoreIgnoreBlockedUsers, $wgContribScoreIgnoreUsernames,
$wgContribScoreUseRoughEditCount;
$loadBalancer = MediaWikiServices::getInstance()->getDBLoadBalancer();
$dbr = $loadBalancer->getConnection( DB_REPLICA );
$revQuery = ActorMigration::newMigration()->getJoin( 'rev_user' );
$revQuery['tables'] = array_merge( [ 'revision' ], $revQuery['tables'] );
$revUser = $revQuery['fields']['rev_user'];
$revUsername = $revQuery['fields']['rev_user_text'];
$sqlWhere = [];
if ( $days > 0 ) {
$date = time() - ( 60 * 60 * 24 * $days );
$sqlWhere[] = 'rev_timestamp > ' . $dbr->addQuotes( $dbr->timestamp( $date ) );
}
$sqlVars = [
'rev_user' => $revUser,
'page_count' => 'COUNT(DISTINCT rev_page)'
];
if ( $wgContribScoreUseRoughEditCount ) {
$revQuery['tables'][] = 'user';
$revQuery['joins']['user'] = [ 'LEFT JOIN', [ "$revUser != 0", "user_id = $revUser" ] ];
$sqlVars['rev_count'] = 'user_editcount';
} else {
$sqlVars['rev_count'] = 'COUNT(rev_id)';
}
if ( $wgContribScoreIgnoreBlockedUsers ) {
$sqlWhere[] = "{$revUser} NOT IN " .
$dbr->buildSelectSubquery( [
'block',
'block_target'
],
'bt_user',
'bt_user <> 0',
__METHOD__,
[],
[
'block_target' => [ 'JOIN', [
'bl_target=bt_id'
] ]
]
);
}
if ( $wgContribScoreIgnoreBots ) {
$sqlWhere[] = "{$revUser} NOT IN " .
$dbr->buildSelectSubquery( 'user_groups', 'ug_user', [
'ug_group' => 'bot',
'ug_expiry IS NULL OR ug_expiry >= ' . $dbr->addQuotes( $dbr->timestamp() )
], __METHOD__ );
}
if ( count( $wgContribScoreIgnoreUsernames ) ) {
$listIgnoredUsernames = $dbr->makeList( $wgContribScoreIgnoreUsernames );
$sqlWhere[] = "{$revUsername} NOT IN ($listIgnoredUsernames)";
}
if ( $dbr->unionSupportsOrderAndLimit() ) {
$order = [
'GROUP BY' => 'rev_user',
'ORDER BY' => 'page_count DESC',
'LIMIT' => $limit
];
} else {
$order = [ 'GROUP BY' => 'rev_user' ];
}
$sqlMostPages = $dbr->selectSQLText(
$revQuery['tables'],
$sqlVars,
$sqlWhere,
__METHOD__,
$order,
$revQuery['joins']
);
if ( $dbr->unionSupportsOrderAndLimit() ) {
$order['ORDER BY'] = 'rev_count DESC';
}
$sqlMostRevs = $dbr->selectSQLText(
$revQuery['tables'],
$sqlVars,
$sqlWhere,
__METHOD__,
$order,
$revQuery['joins']
);
$sqlMostPagesOrRevs = $dbr->unionQueries( [ $sqlMostPages, $sqlMostRevs ], false );
$res = $dbr->select(
[
'u' => 'user',
's' => new Wikimedia\Rdbms\Subquery( $sqlMostPagesOrRevs ),
],
[
'user_id',
'user_name',
'user_real_name',
'page_count',
'rev_count',
'wiki_rank' => 'page_count+SQRT(rev_count-page_count)*2',
],
[],
__METHOD__,
[
'ORDER BY' => 'wiki_rank DESC',
'LIMIT' => $limit,
],
[
's' => [
'JOIN',
'user_id=rev_user'
]
]
);
$ret = iterator_to_array( $res );
return $ret;
}
/// Generates a "Contribution Scores" table for a given LIMIT and date range
/**
* Function generates Contribution Scores tables in HTML format (not wikiText)
*
* @param int $days Days in the past to run report for
* @param int $limit Maximum number of users to return (default 50)
* @param string|null $title The title of the table
* @param array $options array of options (default none; nosort/notools)
* @return string Html Table representing the requested Contribution Scores.
*/
function genContributionScoreTable( $days, $limit, $title = null, $options = 'none' ) {
global $wgContribScoresUseRealName, $wgContribScoreCacheTTL;
$opts = explode( ',', strtolower( $options ) );
$sortable = in_array( 'nosort', $opts ) ? '' : ' sortable';
$output = "<table class=\"wikitable contributionscores plainlinks{$sortable}\" >\n" .
"<tr class='header'>\n" .
Html::element( 'th', [], $this->msg( 'contributionscores-rank' )->text() ) .
Html::element( 'th', [], $this->msg( 'contributionscores-score' )->text() ) .
Html::element( 'th', [], $this->msg( 'contributionscores-pages' )->text() ) .
Html::element( 'th', [], $this->msg( 'contributionscores-changes' )->text() ) .
Html::element( 'th', [], $this->msg( 'contributionscores-username' )->text() );
$cache = MediaWikiServices::getInstance()->getMainWANObjectCache();
$data = $cache->getWithSetCallback(
$cache->makeKey( 'contributionscores', 'data-' . (string)$days ),
$wgContribScoreCacheTTL * 60,
function () use ( $days ) {
// Use max limit, as limit doesn't matter with performance.
// Avoid purge multiple times since limit on transclusion can be vary.
return self::getContributionScoreData( $days, self::CONTRIBUTIONSCORES_MAXINCLUDELIMIT );
} );
$lang = $this->getLanguage();
$altrow = '';
$user_rank = 1;
foreach ( $data as $row ) {
if ( $user_rank > $limit ) {
break;
}
// Use real name if option used and real name present.
if ( $wgContribScoresUseRealName && $row->user_real_name !== '' ) {
$userLink = Linker::userLink(
$row->user_id,
$row->user_name,
$row->user_real_name
);
} else {
$userLink = Linker::userLink(
$row->user_id,
$row->user_name
);
}
$output .= Html::closeElement( 'tr' );
$output .= "<tr class='{$altrow}'>\n" .
"<td class='content' style='padding-right:10px;text-align:right;'>" .
$lang->formatNum( $user_rank ) .
"\n</td><td class='content' style='padding-right:10px;text-align:right;'>" .
$lang->formatNum( round( $row->wiki_rank, 0 ) ) .
"\n</td><td class='content' style='padding-right:10px;text-align:right;'>" .
$lang->formatNum( $row->page_count ) .
"\n</td><td class='content' style='padding-right:10px;text-align:right;'>" .
$lang->formatNum( $row->rev_count ) .
"\n</td><td class='content'>" .
$userLink;
# Option to not display user tools
if ( !in_array( 'notools', $opts ) ) {
$output .= Linker::userToolLinks( $row->user_id, $row->user_name );
}
$output .= Html::closeElement( 'td' ) . "\n";
if ( $altrow == '' && empty( $sortable ) ) {
$altrow = 'odd ';
} else {
$altrow = '';
}
$user_rank++;
}
$output .= Html::closeElement( 'tr' );
$output .= Html::closeElement( 'table' );
// Transcluded on a normal wiki page.
if ( !empty( $title ) ) {
$output = Html::rawElement( 'table',
[
'style' => 'border-spacing: 0; padding: 0',
'class' => 'contributionscores-wrapper',
'lang' => htmlspecialchars( $lang->getCode() ),
'dir' => $lang->getDir()
],
"\n" .
"<tr>\n" .
"<td style='padding: 0px;'>{$title}</td>\n" .
"</tr>\n" .
"<tr>\n" .
"<td style='padding: 0px;'>{$output}</td>\n" .
"</tr>\n"
);
}
return $output;
}
function execute( $par ) {
$this->setHeaders();
if ( $this->including() ) {
$this->showInclude( $par );
} else {
$this->showPage();
}
return true;
}
/**
* Called when being included on a normal wiki page.
* Cache is disabled so it can depend on the user language.
* @param string|null $par A subpage give to the special page
*/
function showInclude( $par ) {
$days = null;
$limit = null;
$options = 'none';
if ( !empty( $par ) ) {
$params = explode( '/', $par );
$limit = intval( $params[0] );
if ( isset( $params[1] ) ) {
$days = intval( $params[1] );
}
if ( isset( $params[2] ) ) {
$options = $params[2];
}
}
if ( empty( $limit ) || $limit < 1 || $limit > self::CONTRIBUTIONSCORES_MAXINCLUDELIMIT ) {
$limit = 10;
}
if ( $days === null || $days < 0 ) {
$days = 7;
}
if ( $days > 0 ) {
$reportTitle = $this->msg( 'contributionscores-days' )->numParams( $days )->text();
} else {
$reportTitle = $this->msg( 'contributionscores-allrevisions' )->text();
}
$reportTitle .= ' ' . $this->msg( 'contributionscores-top' )->numParams( $limit )->text();
$title = Xml::element( 'h4',
[ 'class' => 'contributionscores-title' ],
$reportTitle
) . "\n";
$this->getOutput()->addHTML( $this->genContributionScoreTable(
$days,
$limit,
$title,
$options
) );
}
/**
* Show the special page
*/
function showPage() {
global $wgContribScoreReports;
if ( !is_array( $wgContribScoreReports ) ) {
$wgContribScoreReports = [
[ 7, 50 ],
[ 30, 50 ],
[ 0, 50 ]
];
}
$out = $this->getOutput();
$out->addWikiMsg( 'contributionscores-info' );
foreach ( $wgContribScoreReports as $scoreReport ) {
[ $days, $revs ] = $scoreReport;
if ( $days > 0 ) {
$reportTitle = $this->msg( 'contributionscores-days' )->numParams( $days )->text();
} else {
$reportTitle = $this->msg( 'contributionscores-allrevisions' )->text();
}
$reportTitle .= ' ' . $this->msg( 'contributionscores-top' )->numParams( $revs )->text();
$title = Xml::element( 'h2',
[ 'class' => 'contributionscores-title' ],
$reportTitle
) . "\n";
$out->addHTML( $title );
$out->addHTML( $this->genContributionScoreTable( $days, $revs ) );
}
}
public function maxIncludeCacheTime() {
global $wgContribScoreDisableCache, $wgContribScoreCacheTTL;
return $wgContribScoreDisableCache ? 0 : $wgContribScoreCacheTTL;
}
/**
* @inheritDoc
*/
protected function getGroupName() {
return 'wiki';
}
}