mediawiki-extensions-Confir.../QuestyCaptcha/includes/QuestyCaptcha.php

139 lines
3.5 KiB
PHP
Raw Normal View History

2009-07-19 04:15:55 +00:00
<?php
/**
* QuestyCaptcha class
*
* @file
2009-07-19 04:15:55 +00:00
* @author Benjamin Lees <emufarmers@gmail.com>
* @ingroup Extensions
2009-07-19 04:15:55 +00:00
*/
use MediaWiki\Auth\AuthenticationRequest;
2009-07-19 04:15:55 +00:00
class QuestyCaptcha extends SimpleCaptcha {
// used for questycaptcha-edit, questycaptcha-addurl, questycaptcha-badlogin,
// questycaptcha-createaccount, questycaptcha-create, questycaptcha-sendemail via getMessage()
protected static $messagePrefix = 'questycaptcha-';
2009-07-19 04:15:55 +00:00
/**
* Validate a captcha response
* @param string $answer
* @param array $info
* @return bool
*/
protected function keyMatch( $answer, $info ) {
if ( is_array( $info['answer'] ) ) {
return in_array( strtolower( $answer ), array_map( 'strtolower', $info['answer'] ) );
} else {
return strtolower( $answer ) == strtolower( $info['answer'] );
}
2009-07-19 04:15:55 +00:00
}
/**
* @param array &$resultArr
*/
protected function addCaptchaAPI( &$resultArr ) {
2009-07-19 04:15:55 +00:00
$captcha = $this->getCaptcha();
$index = $this->storeCaptcha( $captcha );
$resultArr['captcha'] = $this->describeCaptchaType();
2009-07-19 04:15:55 +00:00
$resultArr['captcha']['id'] = $index;
$resultArr['captcha']['question'] = $captcha['question'];
}
/**
* @return array
*/
public function describeCaptchaType() {
return [
'type' => 'question',
'mime' => 'text/html',
];
}
/**
* @return array
*/
public function getCaptcha() {
2009-07-19 04:15:55 +00:00
global $wgCaptchaQuestions;
// Backwards compatibility
if ( $wgCaptchaQuestions === array_values( $wgCaptchaQuestions ) ) {
return $wgCaptchaQuestions[ mt_rand( 0, count( $wgCaptchaQuestions ) - 1 ) ];
}
$question = array_rand( $wgCaptchaQuestions, 1 );
$answer = $wgCaptchaQuestions[ $question ];
return [ 'question' => $question, 'answer' => $answer ];
2009-07-19 04:15:55 +00:00
}
/**
* @param int $tabIndex
* @return array
*/
public function getFormInformation( $tabIndex = 1 ) {
2009-07-19 04:15:55 +00:00
$captcha = $this->getCaptcha();
if ( !$captcha ) {
die(
"No questions found; set some in LocalSettings.php using the format from QuestyCaptcha.php."
);
2009-07-19 04:15:55 +00:00
}
$index = $this->storeCaptcha( $captcha );
return [
'html' => "<p><label for=\"wpCaptchaWord\">{$captcha['question']}</label> " .
Html::element( 'input', [
'name' => 'wpCaptchaWord',
'id' => 'wpCaptchaWord',
'class' => 'mw-ui-input',
'required',
'autocomplete' => 'off',
// tab in before the edit textarea
'tabindex' => $tabIndex ] ) .
"</p>\n" .
Xml::element( 'input', [
'type' => 'hidden',
'name' => 'wpCaptchaId',
'id' => 'wpCaptchaId',
'value' => $index ] )
];
2009-07-19 04:15:55 +00:00
}
public function showHelp() {
global $wgOut;
$wgOut->setPageTitle( wfMessage( 'captchahelp-title' )->text() );
$wgOut->addWikiMsg( 'questycaptchahelp-text' );
if ( CaptchaStore::get()->cookiesNeeded() ) {
$wgOut->addWikiMsg( 'captchahelp-cookies-needed' );
2009-07-19 04:15:55 +00:00
}
}
/**
* @param array $captchaData
* @param string $id
* @return mixed
*/
public function getCaptchaInfo( $captchaData, $id ) {
return $captchaData['question'];
}
/**
* @param array $requests
* @param array $fieldInfo
* @param array &$formDescriptor
* @param string $action
*/
public function onAuthChangeFormFields( array $requests, array $fieldInfo,
array &$formDescriptor, $action ) {
/** @var CaptchaAuthenticationRequest $req */
$req =
AuthenticationRequest::getRequestByClass( $requests,
CaptchaAuthenticationRequest::class, true );
if ( !$req ) {
return;
}
// declare RAW HTML output.
$formDescriptor['captchaInfo']['raw'] = true;
$formDescriptor['captchaWord']['label-message'] = null;
}
}