MediaWiki REL1_30
MathCaptcha.class.php
Go to the documentation of this file.
1<?php
2
4
6
13 function keyMatch( $answer, $info ) {
14 return (int)$answer == (int)$info['answer'];
15 }
16
20 function addCaptchaAPI( &$resultArr ) {
21 list( $sum, $answer ) = $this->pickSum();
22 $html = $this->fetchMath( $sum );
23 $index = $this->storeCaptcha( [ 'answer' => $answer ] );
24 $resultArr['captcha'] = $this->describeCaptchaType();
25 $resultArr['captcha']['id'] = $index;
26 $resultArr['captcha']['question'] = $html;
27 }
28
32 public function describeCaptchaType() {
33 return [
34 'type' => 'math',
35 'mime' => 'text/html',
36 ];
37 }
38
43 function getFormInformation( $tabIndex = 1 ) {
44 list( $sum, $answer ) = $this->pickSum();
45 $index = $this->storeCaptcha( [ 'answer' => $answer ] );
46
47 $form = '<table><tr><td>' . $this->fetchMath( $sum ) . '</td>';
48 $form .= '<td>' . Html::input( 'wpCaptchaWord', false, false, [
49 'tabindex' => $tabIndex,
50 'autocomplete' => 'off',
51 'required'
52 ] ) . '</td></tr></table>';
53 $form .= Html::hidden( 'wpCaptchaId', $index );
54 return [ 'html' => $form ];
55 }
56
58 function pickSum() {
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 ];
65 }
66
68 function fetchMath( $sum ) {
69 if ( class_exists( 'MathRenderer' ) ) {
70 $math = MathRenderer::getRenderer( $sum, [], 'png' );
71 } else {
72 throw new LogicException(
73 'MathCaptcha requires the Math extension for MediaWiki versions 1.18 and above.' );
74 }
75 $math->render();
76 $html = $math->getHtmlOutput();
77 return preg_replace( '/alt=".*?"/', '', $html );
78 }
79
83 public function getCaptcha() {
84 list( $sum, $answer ) = $this->pickSum();
85 return [ 'question' => $sum, 'answer' => $answer ];
86 }
87
93 public function getCaptchaInfo( $captchaData, $id ) {
94 $sum = $captchaData['question'];
95 return $this->fetchMath( $sum );
96 }
97
104 public function onAuthChangeFormFields( array $requests, array $fieldInfo,
105 array &$formDescriptor, $action ) {
107 $req = AuthenticationRequest::getRequestByClass(
108 $requests,
109 CaptchaAuthenticationRequest::class,
110 true
111 );
112 if ( !$req ) {
113 return;
114 }
115
116 $formDescriptor['captchaInfo']['raw'] = true;
117 $formDescriptor['captchaWord']['label-message'] = null;
118 }
119}
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.
This is a value object for authentication requests.
Demo CAPTCHA (not for production usage) and base class for real CAPTCHAs.
Definition Captcha.php:9
string $action
Used to select the right message.
Definition Captcha.php:20
storeCaptcha( $info)
Generate a captcha session ID and save the info in PHP's session storage.
Definition Captcha.php:1030
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
Definition deferred.txt:11
this hook is for auditing only $req
Definition hooks.txt:988
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
Definition hooks.txt:1983
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
Definition hooks.txt:304