126 $this->
addTables( [ $this->bl_table,
'page' ] );
127 $this->
addWhere(
"{$this->bl_from}=page_id" );
128 if ( is_null( $resultPageSet ) ) {
129 $this->
addFields( [
'page_id',
'page_title',
'page_namespace' ] );
131 $this->
addFields( $resultPageSet->getPageTableFields() );
133 $this->
addFields( [
'page_is_redirect',
'from_ns' =>
'page_namespace' ] );
135 $this->
addWhereFld( $this->bl_title, $this->rootTitle->getDBkey() );
136 if ( $this->hasNS ) {
137 $this->
addWhereFld( $this->bl_ns, $this->rootTitle->getNamespace() );
139 $this->
addWhereFld( $this->bl_from_ns, $this->params[
'namespace'] );
141 if ( count( $this->cont ) >= 2 ) {
142 $op = $this->params[
'dir'] ==
'descending' ?
'<' :
'>';
143 if ( $this->params[
'namespace'] !==
null && count( $this->params[
'namespace'] ) > 1 ) {
145 "{$this->bl_from_ns} $op {$this->cont[0]} OR " .
146 "({$this->bl_from_ns} = {$this->cont[0]} AND " .
147 "{$this->bl_from} $op= {$this->cont[1]})"
150 $this->
addWhere(
"{$this->bl_from} $op= {$this->cont[1]}" );
154 if ( $this->params[
'filterredir'] ==
'redirects' ) {
156 } elseif ( $this->params[
'filterredir'] ==
'nonredirects' && !$this->redirect ) {
162 $this->
addOption(
'LIMIT', $this->params[
'limit'] + 1 );
163 $sort = ( $this->params[
'dir'] ==
'descending' ?
' DESC' :
'' );
165 if ( $this->params[
'namespace'] !==
null && count( $this->params[
'namespace'] ) > 1 ) {
166 $orderBy[] = $this->bl_from_ns .
$sort;
168 $orderBy[] = $this->bl_from .
$sort;
169 $this->
addOption(
'ORDER BY', $orderBy );
174 foreach (
$res as $row ) {
175 if ( ++$count > $this->params[
'limit'] ) {
179 $this->continueStr =
"{$row->from_ns}|{$row->page_id}";
184 if ( count( $this->cont ) < 2 ) {
185 $this->cont[] = $row->from_ns;
186 $this->cont[] = $row->page_id;
189 $this->pageMap[$row->page_namespace][$row->page_title] = $row->page_id;
190 $t = Title::makeTitle( $row->page_namespace, $row->page_title );
191 if ( $row->page_is_redirect ) {
192 $this->redirTitles[] =
$t;
195 if ( is_null( $resultPageSet ) ) {
196 $a = [
'pageid' => (int)$row->page_id ];
198 if ( $row->page_is_redirect ) {
199 $a[
'redirect'] =
true;
202 $this->resultArr[$a[
'pageid']] = $a;
204 $resultPageSet->processDbRow( $row );
214 $db = $this->
getDB();
215 $this->
addTables( [
'page', $this->bl_table ] );
216 $this->
addWhere(
"{$this->bl_from}=page_id" );
218 if ( is_null( $resultPageSet ) ) {
219 $this->
addFields( [
'page_id',
'page_title',
'page_namespace',
'page_is_redirect' ] );
221 $this->
addFields( $resultPageSet->getPageTableFields() );
224 $this->
addFields( [ $this->bl_title,
'from_ns' =>
'page_namespace' ] );
225 if ( $this->hasNS ) {
234 foreach ( $this->redirTitles as
$t ) {
235 $redirNs =
$t->getNamespace();
236 $redirDBkey =
$t->getDBkey();
237 $titleWhere[] =
"{$this->bl_title} = " . $db->addQuotes( $redirDBkey ) .
238 ( $this->hasNS ?
" AND {$this->bl_ns} = {$redirNs}" :
'' );
239 $allRedirNs[$redirNs] =
true;
240 $allRedirDBkey[$redirDBkey] =
true;
243 $this->
addWhereFld(
'page_namespace', $this->params[
'namespace'] );
245 if ( count( $this->cont ) >= 6 ) {
246 $op = $this->params[
'dir'] ==
'descending' ?
'<' :
'>';
248 $where =
"{$this->bl_from} $op= {$this->cont[5]}";
251 if ( $this->params[
'namespace'] !==
null && count( $this->params[
'namespace'] ) > 1 ) {
252 $where =
"{$this->bl_from_ns} $op {$this->cont[4]} OR " .
253 "({$this->bl_from_ns} = {$this->cont[4]} AND ($where))";
255 if ( count( $allRedirDBkey ) > 1 ) {
256 $title = $db->addQuotes( $this->cont[3] );
257 $where =
"{$this->bl_title} $op $title OR " .
258 "({$this->bl_title} = $title AND ($where))";
260 if ( $this->hasNS && count( $allRedirNs ) > 1 ) {
261 $where =
"{$this->bl_ns} $op {$this->cont[2]} OR " .
262 "({$this->bl_ns} = {$this->cont[2]} AND ($where))";
267 if ( $this->params[
'filterredir'] ==
'redirects' ) {
269 } elseif ( $this->params[
'filterredir'] ==
'nonredirects' ) {
273 $this->
addOption(
'LIMIT', $this->params[
'limit'] + 1 );
275 $sort = ( $this->params[
'dir'] ==
'descending' ?
' DESC' :
'' );
277 if ( $this->hasNS && count( $allRedirNs ) > 1 ) {
278 $orderBy[] = $this->bl_ns .
$sort;
280 if ( count( $allRedirDBkey ) > 1 ) {
281 $orderBy[] = $this->bl_title .
$sort;
283 if ( $this->params[
'namespace'] !==
null && count( $this->params[
'namespace'] ) > 1 ) {
284 $orderBy[] = $this->bl_from_ns .
$sort;
286 $orderBy[] = $this->bl_from .
$sort;
287 $this->
addOption(
'ORDER BY', $orderBy );
288 $this->
addOption(
'USE INDEX', [
'page' =>
'PRIMARY' ] );
292 foreach (
$res as $row ) {
293 $ns = $this->hasNS ? $row->{$this->bl_ns} :
NS_FILE;
295 if ( ++$count > $this->params[
'limit'] ) {
300 $title = $row->{$this->bl_title};
301 $this->continueStr = implode(
'|', array_slice( $this->cont, 0, 2 ) ) .
302 "|$ns|$title|{$row->from_ns}|{$row->page_id}";
307 if ( count( $this->cont ) < 6 ) {
309 $this->cont[] = $row->{$this->bl_title};
310 $this->cont[] = $row->from_ns;
311 $this->cont[] = $row->page_id;
314 if ( is_null( $resultPageSet ) ) {
315 $a = [
'pageid' => (int)$row->page_id ];
317 if ( $row->page_is_redirect ) {
318 $a[
'redirect'] =
true;
320 $parentID = $this->pageMap[$ns][$row->{$this->bl_title}];
322 $this->resultArr[$parentID][
'redirlinks'][$row->page_id] = $a;
324 $resultPageSet->processDbRow( $row );
333 private function run( $resultPageSet =
null ) {
334 $this->params = $this->extractRequestParams(
false );
335 $this->redirect = isset( $this->params[
'redirect'] ) && $this->params[
'redirect'];
339 $result = $this->getResult();
341 if ( $this->params[
'limit'] ==
'max' ) {
342 $this->params[
'limit'] = $this->getMain()->canApiHighLimits() ? $botMax : $userMax;
343 $result->addParsedLimit( $this->getModuleName(), $this->params[
'limit'] );
345 $this->params[
'limit'] = (int)$this->params[
'limit'];
346 $this->validateLimit(
'limit', $this->params[
'limit'], 1, $userMax, $botMax );
349 $this->rootTitle = $this->getTitleFromTitleOrPageId( $this->params );
352 if ( !$this->hasNS && $this->rootTitle->getNamespace() !==
NS_FILE ) {
354 [
'apierror-imageusage-badtitle', $this->getModuleName() ],
361 if ( $this->params[
'continue'] !==
null ) {
362 $cont = explode(
'|', $this->params[
'continue'] );
364 switch ( count( $cont ) ) {
367 $this->cont[7] = (int)$cont[7];
368 $this->dieContinueUsageIf( $cont[7] !== (
string)$this->cont[7] );
374 $this->cont[6] = (int)$cont[6];
375 $this->dieContinueUsageIf( $cont[6] !== (
string)$this->cont[6] );
381 $this->cont[2] = (int)$cont[2];
382 $this->dieContinueUsageIf( $cont[2] !== (
string)$this->cont[2] );
385 $this->cont[3] = $cont[3];
388 $this->cont[4] = (int)$cont[4];
389 $this->dieContinueUsageIf( $cont[4] !== (
string)$this->cont[4] );
392 $this->cont[5] = (int)$cont[5];
393 $this->dieContinueUsageIf( $cont[5] !== (
string)$this->cont[5] );
399 $this->cont[0] = (int)$cont[0];
400 $this->dieContinueUsageIf( $cont[0] !== (
string)$this->cont[0] );
403 $this->cont[1] = (int)$cont[1];
404 $this->dieContinueUsageIf( $cont[1] !== (
string)$this->cont[1] );
409 $this->dieContinueUsageIf(
true );
412 ksort( $this->cont );
415 $this->runFirstQuery( $resultPageSet );
416 if ( $this->redirect && count( $this->redirTitles ) ) {
417 $this->resetQueryParams();
418 $this->runSecondQuery( $resultPageSet );
422 $this->cont += [ 0, 0, 0,
'', 0, 0, 0 ];
424 if ( is_null( $resultPageSet ) ) {
426 $code = $this->bl_code;
427 $data = array_map(
function ( $arr ) use ( $code ) {
428 if ( isset( $arr[
'redirlinks'] ) ) {
429 $arr[
'redirlinks'] = array_values( $arr[
'redirlinks'] );
433 }, array_values( $this->resultArr ) );
434 $fit = $result->addValue(
'query', $this->getModuleName(), $data );
438 ksort( $this->resultArr );
439 if ( count( $this->cont ) >= 7 ) {
440 $startAt = $this->cont[6];
442 reset( $this->resultArr );
443 $startAt = key( $this->resultArr );
446 foreach ( $this->resultArr as $pageID => $arr ) {
447 if ( $pageID < $startAt ) {
452 $fit = $result->addValue(
453 [
'query', $this->getModuleName() ],
454 $idx, array_diff_key( $arr, [
'redirlinks' =>
'' ] ) );
456 $this->continueStr = implode(
'|', array_slice( $this->cont, 0, 6 ) ) .
462 $redirLinks = isset( $arr[
'redirlinks'] ) ? (array)$arr[
'redirlinks'] : [];
463 ksort( $redirLinks );
464 if ( count( $this->cont ) >= 8 && $pageID == $startAt ) {
465 $redirStartAt = $this->cont[7];
467 reset( $redirLinks );
468 $redirStartAt = key( $redirLinks );
470 foreach ( $redirLinks as $key => $redir ) {
471 if ( $key < $redirStartAt ) {
475 $fit = $result->addValue(
476 [
'query', $this->getModuleName(), $idx,
'redirlinks' ],
479 $this->continueStr = implode(
'|', array_slice( $this->cont, 0, 6 ) ) .
486 $result->addIndexedTagName(
487 [
'query', $this->getModuleName(), $idx,
'redirlinks' ],
498 $result->addIndexedTagName(
499 [
'query', $this->getModuleName() ],
503 if ( !is_null( $this->continueStr ) ) {
504 $this->setContinueEnumParameter(
'continue', $this->continueStr );