function execute() { global $wgOut; $opts = new FormOptions(); $opts->add('target', ''); $opts->add('namespace', '', FormOptions::INTNULL); $opts->add('limit', 50); $opts->add('from', 0); $opts->add('back', 0); $opts->add('hideredirs', false); $opts->add('hidetrans', false); $opts->add('hidelinks', false); $opts->add('hideimages', false); $opts->fetchValuesFromRequest($this->request); $opts->validateIntBounds('limit', 0, 5000); // Give precedence to subpage syntax if (isset($this->par)) { $opts->setValue('target', $this->par); } // Bind to member variable $this->opts = $opts; $this->target = Title::newFromURL($opts->getValue('target')); if (!$this->target) { $wgOut->addHTML($this->whatlinkshereForm()); return; } $this->selfTitle = SpecialPage::getTitleFor('Whatlinkshere', $this->target->getPrefixedDBkey()); $wgOut->setPageTitle(wfMsg('whatlinkshere-title', $this->target->getPrefixedText())); $wgOut->setSubtitle(wfMsg('whatlinkshere-backlink', $this->skin->link($this->target, $this->target->getPrefixedText(), array(), array('redirect' => 'no')))); $this->showIndirectLinks(0, $this->target, $opts->getValue('limit'), $opts->getValue('from'), $opts->getValue('back')); }
public function execute($par) { // Shortcut by using $par if ($par) { $this->getOutput()->redirect($this->getTitle()->getLinkURL(array('user' => $par))); return; } $this->setHeaders(); $this->outputHeader(); // Parse options $opt = new \FormOptions(); $opt->add('user', ''); $opt->add('delete', ''); $opt->add('reason', ''); $opt->fetchValuesFromRequest($this->getRequest()); // Parse user $user = $opt->getValue('user'); $userObj = \User::newFromName($user); $userExists = $userObj && $userObj->getId() !== 0; // If current task is delete and user is not allowed $canDoAdmin = $this->getUser()->isAllowed('avataradmin'); if ($opt->getValue('delete')) { if (!$canDoAdmin) { throw new \PermissionsError('avataradmin'); } // Delete avatar if the user exists if ($userExists) { if (Avatars::deleteAvatar($userObj)) { global $wgAvatarLogInRC; $logEntry = new \ManualLogEntry('avatar', 'delete'); $logEntry->setPerformer($this->getUser()); $logEntry->setTarget($userObj->getUserPage()); $logEntry->setComment($opt->getValue('reason')); $logId = $logEntry->insert(); $logEntry->publish($logId, $wgAvatarLogInRC ? 'rcandudp' : 'udp'); } } } $this->getOutput()->addModules(array('mediawiki.userSuggest')); $this->showForm($user); if ($userExists) { $haveAvatar = Avatars::hasAvatar($userObj); if ($haveAvatar) { $html = \Xml::tags('img', array('src' => Avatars::getLinkFor($user, 'original') . '&nocache&ver=' . dechex(time()), 'height' => 400), ''); $html = \Xml::tags('p', array(), $html); $this->getOutput()->addHTML($html); // Add a delete button if ($canDoAdmin) { $this->showDeleteForm($user); } } else { $this->getOutput()->addWikiMsg('viewavatar-noavatar'); } } else { if ($user) { $this->getOutput()->addWikiMsg('viewavatar-nouser'); } } }
protected function buildForm() { $formDescriptor = ['like' => ['type' => 'text', 'label-message' => 'newimages-label', 'name' => 'like'], 'showbots' => ['type' => 'check', 'label-message' => 'newimages-showbots', 'name' => 'showbots'], 'hidepatrolled' => ['type' => 'check', 'label-message' => 'newimages-hidepatrolled', 'name' => 'hidepatrolled'], 'limit' => ['type' => 'hidden', 'default' => $this->opts->getValue('limit'), 'name' => 'limit'], 'offset' => ['type' => 'hidden', 'default' => $this->opts->getValue('offset'), 'name' => 'offset']]; if ($this->getConfig()->get('MiserMode')) { unset($formDescriptor['like']); } if (!$this->getUser()->useFilePatrol()) { unset($formDescriptor['hidepatrolled']); } $form = HTMLForm::factory('ooui', $formDescriptor, $this->getContext())->setWrapperLegendMsg('newimages-legend')->setSubmitTextMsg('ilsubmit')->setMethod('get')->prepareForm()->displayForm(false); }
public function __construct(FormOptions $opts, Title $title) { $this->opts = $opts; $this->title = $title; $this->userMode = $opts->getValue('mode') === SpecialAPC::MODE_USER_CACHE; $this->fieldKey = $this->userMode ? 'info' : (ini_get('apc.stat') ? 'inode' : 'filename'); }
function getPageHeader() { global $wgScript; $self = $this->getTitle(); $limit = $this->mLimit ? Html::hidden( 'limit', $this->mLimit ) : ''; $out = Xml::openElement( 'form', array( 'method' => 'get', 'action' => $wgScript ) ); # Form tag $out .= Xml::fieldset( $this->msg( 'activeusers' )->text() ) . "\n"; $out .= Html::hidden( 'title', $self->getPrefixedDBkey() ) . $limit . "\n"; $out .= Xml::inputLabel( $this->msg( 'activeusers-from' )->text(), 'username', 'offset', 20, $this->requestedUser, array( 'tabindex' => 1 ) ) . '<br />';# Username field $out .= Xml::checkLabel( $this->msg( 'activeusers-hidebots' )->text(), 'hidebots', 'hidebots', $this->opts->getValue( 'hidebots' ), array( 'tabindex' => 2 ) ); $out .= Xml::checkLabel( $this->msg( 'activeusers-hidesysops' )->text(), 'hidesysops', 'hidesysops', $this->opts->getValue( 'hidesysops' ), array( 'tabindex' => 3 ) ) . '<br />'; $out .= Xml::submitButton( $this->msg( 'allpagessubmit' )->text(), array( 'tabindex' => 4 ) ) . "\n";# Submit button and form bottom $out .= Xml::closeElement( 'fieldset' ); $out .= Xml::closeElement( 'form' ); return $out; }
function formatRevisionRow($row) { $rev = new Revision($row); $stxt = ''; $last = $this->msg('last')->escaped(); $ts = wfTimestamp(TS_MW, $row->rev_timestamp); $checkBox = Xml::radio('mergepoint', $ts, $this->mOpts->getValue('mergepoint') === $ts); $user = $this->getUser(); $pageLink = Linker::linkKnown($rev->getTitle(), htmlspecialchars($this->getLanguage()->userTimeAndDate($ts, $user)), [], ['oldid' => $rev->getId()]); if ($rev->isDeleted(Revision::DELETED_TEXT)) { $pageLink = '<span class="history-deleted">' . $pageLink . '</span>'; } # Last link if (!$rev->userCan(Revision::DELETED_TEXT, $user)) { $last = $this->msg('last')->escaped(); } elseif (isset($this->prevId[$row->rev_id])) { $last = Linker::linkKnown($rev->getTitle(), $this->msg('last')->escaped(), [], ['diff' => $row->rev_id, 'oldid' => $this->prevId[$row->rev_id]]); } $userLink = Linker::revUserTools($rev); $size = $row->rev_len; if (!is_null($size)) { $stxt = Linker::formatRevisionSize($size); } $comment = Linker::revComment($rev); return Html::rawElement('li', [], $this->msg('mergehistory-revisionrow')->rawParams($checkBox, $last, $pageLink, $userLink, $stxt, $comment)->escaped()); }
/** * Output a subscription feed listing recent edits to this page. * * @param $type String */ protected function feed( $type ) { global $wgFeed, $wgFeedClasses, $wgFeedLimit; if ( !$wgFeed ) { $this->getOutput()->addWikiMsg( 'feed-unavailable' ); return; } if ( !isset( $wgFeedClasses[$type] ) ) { $this->getOutput()->addWikiMsg( 'feed-invalid' ); return; } $feed = new $wgFeedClasses[$type]( $this->feedTitle(), $this->msg( 'tagline' )->text(), $this->getTitle()->getFullURL() ); $pager = new NewPagesPager( $this, $this->opts ); $limit = $this->opts->getValue( 'limit' ); $pager->mLimit = min( $limit, $wgFeedLimit ); $feed->outHeader(); if ( $pager->getNumRows() > 0 ) { foreach ( $pager->mResult as $row ) { $feed->outItem( $this->feedItem( $row ) ); } } $feed->outFooter(); }
/** * @param IContextSource $context * @param FormOptions $opts */ function __construct(IContextSource $context = null, FormOptions $opts) { parent::__construct($context); $this->RCMaxAge = $this->getConfig()->get('ActiveUserDays'); $this->requestedUser = ''; $un = $opts->getValue('username'); if ($un != '') { $username = Title::makeTitleSafe(NS_USER, $un); if (!is_null($username)) { $this->requestedUser = $username->getText(); } } if ($opts->getValue('hidebots') == 1) { $this->hideRights[] = 'bot'; } if ($opts->getValue('hidesysops') == 1) { $this->hideGroups[] = 'sysop'; } }
protected function messageSelector() { $nondefaults = $this->opts->getChangedValues(); $output = Html::openElement('div', array('class' => 'row tux-messagetable-header')); $output .= Html::openElement('div', array('class' => 'nine columns')); $output .= Html::openElement('ul', array('class' => 'row tux-message-selector')); $tabs = array('default' => '', 'translated' => 'translated', 'untranslated' => 'untranslated'); $ellipsisOptions = array('outdated' => 'fuzzy'); $selected = $this->opts->getValue('filter'); $keys = array_keys($tabs); if (in_array($selected, array_values($ellipsisOptions))) { $key = $keys[count($keys) - 1]; $ellipsisOptions = array($key => $tabs[$key]); // Remove the last tab unset($tabs[$key]); $tabs = array_merge($tabs, array('outdated' => $selected)); } elseif (!in_array($selected, array_values($tabs))) { $selected = ''; } $container = Html::openElement('ul', array('class' => 'column tux-message-selector')); foreach ($ellipsisOptions as $optKey => $optValue) { $container .= $this->ellipsisSelector($optKey, $optValue); } $sourcelanguage = $this->opts->getValue('sourcelanguage'); $sourcelanguage = TranslateUtils::getLanguageName($sourcelanguage); foreach ($tabs as $tab => $filter) { // Messages for grepping: // tux-sst-default // tux-sst-translated // tux-sst-untranslated // tux-sst-outdated $tabClass = "tux-sst-{$tab}"; $taskParams = array('filter' => $filter) + $nondefaults; ksort($taskParams); $href = $this->getTitle()->getLocalUrl($taskParams); if ($tab === 'default') { $link = Html::element('a', array('href' => $href), $this->msg($tabClass)->text()); } else { $link = Html::element('a', array('href' => $href), $this->msg($tabClass, $sourcelanguage)->text()); } if ($selected === $filter) { $tabClass = $tabClass . ' selected'; } $output .= Html::rawElement('li', array('class' => array('column', $tabClass), 'data-filter' => $filter, 'data-title' => $tab), $link); } // More column $output .= Html::openElement('li', array('class' => 'column more')) . '...' . $container . Html::closeElement('li'); $output .= Html::closeElement('ul'); $output .= Html::closeElement('div'); $output .= Html::closeElement('div'); return $output; }
protected function setup($par) { global $wgRequest, $wgUser; // Options $opts = new FormOptions(); $this->opts = $opts; // bind $opts->add('page1', ''); $opts->add('page2', ''); $opts->add('rev1', ''); $opts->add('rev2', ''); $opts->add('action', ''); // Set values $opts->fetchValuesFromRequest($wgRequest); $title1 = Title::newFromText($opts->getValue('page1')); $title2 = Title::newFromText($opts->getValue('page2')); if ($title1 && $title1->exists() && $opts->getValue('rev1') == '') { $pda = new Article($title1); $pdi = $pda->getID(); $pdLastRevision = Revision::loadFromPageId(wfGetDB(DB_SLAVE), $pdi); $opts->setValue('rev1', $pdLastRevision->getId()); } elseif ($opts->getValue('rev1') != '') { $pdrev = Revision::newFromId($opts->getValue('rev1')); if ($pdrev) { $opts->setValue('page1', $pdrev->getTitle()->getPrefixedText()); } } if ($title2 && $title2->exists() && $opts->getValue('rev2') == '') { $pda = new Article($title2); $pdi = $pda->getID(); $pdLastRevision = Revision::loadFromPageId(wfGetDB(DB_SLAVE), $pdi); $opts->setValue('rev2', $pdLastRevision->getId()); } elseif ($opts->getValue('rev2') != '') { $pdrev = Revision::newFromId($opts->getValue('rev2')); if ($pdrev) { $opts->setValue('page2', $pdrev->getTitle()->getPrefixedText()); } } // Store some objects $this->skin = $wgUser->getSkin(); }
protected function doPage() { global $wgOut; $wgOut->addHTML(Xml::openElement('div', array('class' => 'mw-apc-content'))); switch ($this->opts->getValue('mode')) { case self::MODE_STATS: $this->doObHostStats(); break; case self::MODE_SYSTEM_CACHE: case self::MODE_USER_CACHE: $mode = new APCCacheMode($this->opts, $this->title); $mode->cacheView(); break; case self::MODE_VERSION_CHECK: $this->versionCheck(); break; } $wgOut->addHTML(Xml::closeElement('div')); }
function getPageHeader() { $self = $this->getTitle(); $limit = $this->mLimit ? Html::hidden('limit', $this->mLimit) : ''; # Form tag $out = Xml::openElement('form', array('method' => 'get', 'action' => wfScript())); $out .= Xml::fieldset($this->msg('activeusers')->text()) . "\n"; $out .= Html::hidden('title', $self->getPrefixedDBkey()) . $limit . "\n"; # Username field (with autocompletion support) $this->getOutput()->addModules('mediawiki.userSuggest'); $out .= Xml::inputLabel($this->msg('activeusers-from')->text(), 'username', 'offset', 20, $this->requestedUser, array('class' => 'mw-ui-input-inline mw-autocomplete-user', 'tabindex' => 1, 'autofocus' => $this->requestedUser === '')) . '<br />'; $out .= Xml::checkLabel($this->msg('activeusers-hidebots')->text(), 'hidebots', 'hidebots', $this->opts->getValue('hidebots'), array('tabindex' => 2)); $out .= Xml::checkLabel($this->msg('activeusers-hidesysops')->text(), 'hidesysops', 'hidesysops', $this->opts->getValue('hidesysops'), array('tabindex' => 3)) . '<br />'; # Submit button and form bottom $out .= Xml::submitButton($this->msg('activeusers-submit')->text(), array('tabindex' => 4)) . "\n"; $out .= Xml::closeElement('fieldset'); $out .= Xml::closeElement('form'); return $out; }
/** * Create filter panel * * @return string HTML fieldset and filter panel with the show/hide links */ function getFilterPanel() { $show = wfMsgHtml('show'); $hide = wfMsgHtml('hide'); $changed = $this->opts->getChangedValues(); unset($changed['target']); // Already in the request title $links = array(); $types = array('hidetrans', 'hidelinks', 'hideredirs'); if ($this->target->getNamespace() == NS_FILE) { $types[] = 'hideimages'; } // Combined message keys: 'whatlinkshere-hideredirs', 'whatlinkshere-hidetrans', 'whatlinkshere-hidelinks', 'whatlinkshere-hideimages' // To be sure they will be find by grep foreach ($types as $type) { $chosen = $this->opts->getValue($type); $msg = $chosen ? $show : $hide; $overrides = array($type => !$chosen); $links[] = wfMsgHtml("whatlinkshere-{$type}", $this->makeSelfLink($msg, array_merge($changed, $overrides))); } return Xml::fieldset(wfMsg('whatlinkshere-filters'), $this->getLanguage()->pipeList($links)); }
private function show(FormOptions $opts, array $extraConds) { global $wgOut; # Create a LogPager item to get the results and a LogEventsList item to format them... $loglist = new LogEventsList($this->getSkin(), $wgOut, 0); $pager = new LogPager($loglist, $opts->getValue('type'), $opts->getValue('user'), $opts->getValue('page'), $opts->getValue('pattern'), $extraConds, $opts->getValue('year'), $opts->getValue('month'), $opts->getValue('tagfilter')); # Set title and add header $loglist->showHeader($pager->getType()); # Set relevant user if ($pager->getUser()) { $this->getSkin()->setRelevantUser(User::newFromName($pager->getUser())); } # Show form options $loglist->showOptions($pager->getType(), $pager->getUser(), $pager->getPage(), $pager->getPattern(), $pager->getYear(), $pager->getMonth(), $pager->getFilterParams(), $opts->getValue('tagfilter')); # Insert list $logBody = $pager->getBody(); if ($logBody) { $wgOut->addHTML($pager->getNavigationBar() . $loglist->beginLogEventsList() . $logBody . $loglist->endLogEventsList() . $pager->getNavigationBar()); } else { $wgOut->addWikiMsg('logempty'); } }
private function show(FormOptions $opts, array $extraConds) { # Create a LogPager item to get the results and a LogEventsList item to format them... $loglist = new LogEventsList($this->getContext(), null, LogEventsList::USE_REVDEL_CHECKBOXES); $pager = new LogPager($loglist, $opts->getValue('type'), $opts->getValue('user'), $opts->getValue('page'), $opts->getValue('pattern'), $extraConds, $opts->getValue('year'), $opts->getValue('month'), $opts->getValue('tagfilter')); $this->addHeader($opts->getValue('type')); # Set relevant user if ($pager->getPerformer()) { $this->getSkin()->setRelevantUser(User::newFromName($pager->getPerformer())); } # Show form options $loglist->showOptions($pager->getType(), $opts->getValue('user'), $pager->getPage(), $pager->getPattern(), $pager->getYear(), $pager->getMonth(), $pager->getFilterParams(), $opts->getValue('tagfilter')); # Reuben, upgrade 1.23: apply a special hack where we insert FORCE INDEX (times) # into the sql query, because Mysql chooses the wrong index and the Database # class has a bug where it generates sql with syntax errors. if (!$pager->getType() && !$opts->getValue('user') && !$pager->getPage()) { $pager->setIndexHack(); } # Insert list $logBody = $pager->getBody(); if ($logBody) { $this->getOutput()->addHTML($pager->getNavigationBar() . $this->getRevisionButton($loglist->beginLogEventsList() . $logBody . $loglist->endLogEventsList()) . $pager->getNavigationBar()); } else { $this->getOutput()->addWikiMsg('logempty'); } }
/** * @param IContextSource $context * @param FormOptions $opts */ function __construct(IContextSource $context, FormOptions $opts) { $this->opts = $opts; $this->setLimit($opts->getValue('limit')); parent::__construct($context); }
/** * Adds raw image data of the graph to the output. * @param $opts FormOptions */ public function draw( FormOptions $opts ) { global $wgTranslatePHPlotFont, $wgLang; $width = $opts->getValue( 'width' ); $height = $opts->getValue( 'height' ); // Define the object $plot = new PHPlot( $width, $height ); list( $legend, $resData ) = $this->getData( $opts ); $count = count( $resData ); $skip = intval( $count / ( $width / 60 ) - 1 ); $i = $count; foreach ( $resData as $date => $edits ) { if ( $skip > 0 ) { if ( ( $count - $i ) % $skip !== 0 ) $date = ''; } if ( strpos( $date, ';' ) !== false ) { list( , $date ) = explode( ';', $date, 2 ); } array_unshift( $edits, $date ); $data[] = $edits; $i--; } $font = FCFontFinder::find( $wgLang->getCode() ); if ( $font ) { $plot->SetDefaultTTFont( $font ); } else { $plot->SetDefaultTTFont( $wgTranslatePHPlotFont ); } $plot->SetDataValues( $data ); if ( $legend !== null ) { $plot->SetLegend( $legend ); } $numberFont = FCFontFinder::find( 'en' ); $plot->setFont( 'x_label', $numberFont, 8 ); $plot->setFont( 'y_label', $numberFont, 8 ); $yTitle = wfMsg( 'translate-stats-' . $opts['count'] ); // Turn off X axis ticks and labels because they get in the way: $plot->SetYTitle( $yTitle ); $plot->SetXTickLabelPos( 'none' ); $plot->SetXTickPos( 'none' ); $plot->SetXLabelAngle( 45 ); $max = max( array_map( 'max', $resData ) ); $max = self::roundToSignificant( $max, 1 ); $max = round( $max, intval( -log( $max, 10 ) ) ); $yTick = 10; while ( $max / $yTick > $height / 20 ) { $yTick *= 2; } // If we have very small case, ensure that there is at least one tick $yTick = min( $max, $yTick ); $yTick = self::roundToSignificant( $yTick ); $plot->SetYTickIncrement( $yTick ); $plot->SetPlotAreaWorld( null, 0, null, $max ); $plot->SetTransparentColor( 'white' ); $plot->SetBackgroundColor( 'white' ); // Draw it $plot->DrawGraph(); }
private function show(FormOptions $opts, array $extraConds) { # Create a LogPager item to get the results and a LogEventsList item to format them... $loglist = new LogEventsList($this->getContext(), null, LogEventsList::USE_REVDEL_CHECKBOXES); $pager = new LogPager($loglist, $opts->getValue('type'), $opts->getValue('user'), $opts->getValue('page'), $opts->getValue('pattern'), $extraConds, $opts->getValue('year'), $opts->getValue('month'), $opts->getValue('tagfilter')); $this->addHeader($opts->getValue('type')); # Set relevant user if ($pager->getPerformer()) { $this->getSkin()->setRelevantUser(User::newFromName($pager->getPerformer())); } # Show form options $loglist->showOptions($pager->getType(), $opts->getValue('user'), $pager->getPage(), $pager->getPattern(), $pager->getYear(), $pager->getMonth(), $pager->getFilterParams(), $opts->getValue('tagfilter')); # Insert list $logBody = $pager->getBody(); if ($logBody) { $this->getOutput()->addHTML($pager->getNavigationBar() . $this->getRevisionButton($loglist->beginLogEventsList() . $logBody . $loglist->endLogEventsList()) . $pager->getNavigationBar()); } else { $this->getOutput()->addWikiMsg('logempty'); } }
public function execute($par) { $user = $this->getUser(); if (!$this->userCanExecute($user)) { throw new \PermissionsError('commentadmin-restricted'); } // Parse request $opt = new \FormOptions(); $opt->add('user', ''); $opt->add('page', ''); $opt->add('filter', 'all'); $opt->add('keyword', ''); $opt->add('offset', '0'); $opt->add('limit', '20'); $opt->add('dir', ''); $opt->fetchValuesFromRequest($this->getRequest()); // Reset filter to all if it cannot be recognized $filter = $opt->getValue('filter'); if (!in_array($filter, $this->getPossibleFilters())) { $filter = 'all'; } $this->filter = $filter; // Set local variable $this->page = $opt->getValue('page'); $this->user = $opt->getValue('user'); $this->keyword = $opt->getValue('keyword'); $this->offset = intval($opt->getValue('offset')); $this->limit = intval($opt->getValue('limit')); $this->revDir = $opt->getValue('dir') === 'prev'; // Limit the max limit if ($this->limit >= 500) { $this->limit = 500; } global $wgScript; $this->setHeaders(); $this->outputHeader(); $output = $this->getOutput(); $output->addModules('mediawiki.userSuggest'); # This is used for user input field $output->addModules('ext.flowthread.manage'); $this->showForm(); $json = array(); $res = $this->queryDatabase(); $count = 0; foreach ($res as $row) { if ($count === $this->limit) { $this->haveMore = true; break; } else { $count++; } $post = Post::newFromDatabaseRow($row); $title = \Title::newFromId($row->flowthread_pageid); $json[] = array('id' => $post->id->getHex(), 'userid' => $post->userid, 'username' => $post->username, 'title' => $title ? $title->getPrefixedText() : null, 'text' => $post->text, 'timestamp' => $post->id->getTimestamp(), 'parentid' => $post->parentid ? $post->parentid->getHex() : '', 'like' => $post->getFavorCount(), 'report' => $post->getReportCount()); } // Pager can only be generated after query $output->addHTML($this->getPager()); $output->addJsConfigVars(array('commentfilter' => $this->filter, 'commentjson' => $json)); if ($this->getUser()->isAllowed('commentadmin')) { $output->addJsConfigVars(array('commentadmin' => '')); } global $wgFlowThreadConfig; $output->addJsConfigVars(array('wgFlowThreadConfig' => array('Avatar' => $wgFlowThreadConfig['Avatar'], 'AnonymousAvatar' => $wgFlowThreadConfig['AnonymousAvatar']))); }