14 return (
int)$answer == (int)$info[
'answer'];
25 $resultArr[
'captcha'][
'id'] = $index;
26 $resultArr[
'captcha'][
'question'] =
$html;
35 'mime' =>
'text/html',
47 $form =
'<table><tr><td>' . $this->
fetchMath( $sum ) .
'</td>';
48 $form .=
'<td>' . Html::input(
'wpCaptchaWord',
false,
false, [
49 'tabindex' => $tabIndex,
50 'autocomplete' =>
'off',
52 ] ) .
'</td></tr></table>';
53 $form .= Html::hidden(
'wpCaptchaId', $index );
54 return [
'html' => $form ];
59 $a = mt_rand( 0, 100 );
60 $b = mt_rand( 0, 10 );
61 $op = mt_rand( 0, 1 ) ?
'+' :
'-';
62 $sum =
"{$a} {$op} {$b} = ";
63 $ans = $op ==
'+' ? ( $a + $b ) : ( $a - $b );
64 return [ $sum, $ans ];
69 if ( class_exists(
'MathRenderer' ) ) {
70 $math = MathRenderer::getRenderer( $sum, [],
'png' );
72 throw new LogicException(
73 'MathCaptcha requires the Math extension for MediaWiki versions 1.18 and above.' );
76 $html = $math->getHtmlOutput();
77 return preg_replace(
'/alt=".*?"/',
'',
$html );
85 return [
'question' => $sum,
'answer' => $answer ];
94 $sum = $captchaData[
'question'];
105 array &$formDescriptor,
$action ) {
107 $req = AuthenticationRequest::getRequestByClass(
109 CaptchaAuthenticationRequest::class,
116 $formDescriptor[
'captchaInfo'][
'raw'] =
true;
117 $formDescriptor[
'captchaWord'][
'label-message'] =
null;
addCaptchaAPI(&$resultArr)
pickSum()
Pick a random sum.
getFormInformation( $tabIndex=1)
keyMatch( $answer, $info)
Validate a captcha response.
getCaptchaInfo( $captchaData, $id)
onAuthChangeFormFields(array $requests, array $fieldInfo, array &$formDescriptor, $action)
fetchMath( $sum)
Fetch the math.
Demo CAPTCHA (not for production usage) and base class for real CAPTCHAs.
string $action
Used to select the right message.
storeCaptcha( $info)
Generate a captcha session ID and save the info in PHP's session storage.
deferred txt A few of the database updates required by various functions here can be deferred until after the result page is displayed to the user For updating the view updating the linked to tables after a etc PHP does not yet have any way to tell the server to actually return and disconnect while still running these but it might have such a feature in the future We handle these by creating a deferred update object and putting those objects on a global list
this hook is for auditing only $req
null means default in associative array with keys and values unescaped Should be merged with default with a value of false meaning to suppress the attribute in associative array with keys and values unescaped noclasses just before the function returns a value If you return an< a > element with HTML attributes $attribs and contents $html will be returned If you return $ret will be returned and may include noclasses & $html
Allows to change the fields on the form that will be generated are created Can be used to omit specific feeds from being outputted You must not use this hook to add use OutputPage::addFeedLink() instead. & $feedLinks hooks can tweak the array to change how login etc forms should look $requests