danielebarchiesi@2
|
1 <?php
|
danielebarchiesi@2
|
2
|
danielebarchiesi@2
|
3 /**
|
danielebarchiesi@2
|
4 * @file
|
danielebarchiesi@2
|
5 * Install, update and uninstall functions for the CAPTCHA module.
|
danielebarchiesi@2
|
6 */
|
danielebarchiesi@2
|
7
|
danielebarchiesi@2
|
8 /**
|
danielebarchiesi@2
|
9 * Implementation of hook_schema().
|
danielebarchiesi@2
|
10 */
|
danielebarchiesi@2
|
11 function captcha_schema() {
|
danielebarchiesi@2
|
12 // Table for positions and types of the challenges.
|
danielebarchiesi@2
|
13 $schema['captcha_points'] = array(
|
danielebarchiesi@2
|
14 'description' => 'This table describes which challenges should be added to which forms.',
|
danielebarchiesi@2
|
15 'fields' => array(
|
danielebarchiesi@2
|
16 'form_id' => array(
|
danielebarchiesi@2
|
17 'description' => 'The form_id of the form to add a CAPTCHA to.',
|
danielebarchiesi@2
|
18 'type' => 'varchar',
|
danielebarchiesi@2
|
19 'length' => 128,
|
danielebarchiesi@2
|
20 'not null' => TRUE,
|
danielebarchiesi@2
|
21 'default' => '',
|
danielebarchiesi@2
|
22 ),
|
danielebarchiesi@2
|
23 'module' => array(
|
danielebarchiesi@2
|
24 'description' => 'The module that provides the challenge.',
|
danielebarchiesi@2
|
25 'type' => 'varchar',
|
danielebarchiesi@2
|
26 'length' => 64,
|
danielebarchiesi@2
|
27 ),
|
danielebarchiesi@2
|
28 'captcha_type' => array(
|
danielebarchiesi@2
|
29 'description' => 'The challenge type to use.',
|
danielebarchiesi@2
|
30 'type' => 'varchar',
|
danielebarchiesi@2
|
31 'length' => 64,
|
danielebarchiesi@2
|
32 ),
|
danielebarchiesi@2
|
33 ),
|
danielebarchiesi@2
|
34 'primary key' => array('form_id'),
|
danielebarchiesi@2
|
35 );
|
danielebarchiesi@2
|
36 // Table for the CAPTCHA sessions.
|
danielebarchiesi@2
|
37 $schema['captcha_sessions'] = array(
|
danielebarchiesi@2
|
38 'description' => 'Stores the data about CAPTCHA sessions (solution, IP address, timestamp, ...).',
|
danielebarchiesi@2
|
39 'fields' => array(
|
danielebarchiesi@2
|
40 'csid' => array(
|
danielebarchiesi@2
|
41 'description' => 'CAPTCHA session ID.',
|
danielebarchiesi@2
|
42 'type' => 'serial',
|
danielebarchiesi@2
|
43 'not null' => TRUE,
|
danielebarchiesi@2
|
44 ),
|
danielebarchiesi@2
|
45 'token' => array(
|
danielebarchiesi@2
|
46 'description' => 'One time CAPTCHA token.',
|
danielebarchiesi@2
|
47 'type' => 'varchar',
|
danielebarchiesi@2
|
48 'length' => 64,
|
danielebarchiesi@2
|
49 'not null' => FALSE,
|
danielebarchiesi@2
|
50 ),
|
danielebarchiesi@2
|
51 'uid' => array(
|
danielebarchiesi@2
|
52 'description' => "User's {users}.uid.",
|
danielebarchiesi@2
|
53 'type' => 'int',
|
danielebarchiesi@2
|
54 'not null' => TRUE,
|
danielebarchiesi@2
|
55 'default' => 0,
|
danielebarchiesi@2
|
56 ),
|
danielebarchiesi@2
|
57 'sid' => array(
|
danielebarchiesi@2
|
58 'description' => "Session ID of the user.",
|
danielebarchiesi@2
|
59 'type' => 'varchar',
|
danielebarchiesi@2
|
60 'length' => 64,
|
danielebarchiesi@2
|
61 'not null' => TRUE,
|
danielebarchiesi@2
|
62 'default' => '',
|
danielebarchiesi@2
|
63 ),
|
danielebarchiesi@2
|
64 'ip_address' => array(
|
danielebarchiesi@2
|
65 'description' => 'IP address of the visitor.',
|
danielebarchiesi@2
|
66 'type' => 'varchar',
|
danielebarchiesi@2
|
67 'length' => 128,
|
danielebarchiesi@2
|
68 'not null' => FALSE,
|
danielebarchiesi@2
|
69 ),
|
danielebarchiesi@2
|
70 'timestamp' => array(
|
danielebarchiesi@2
|
71 'description' => 'A Unix timestamp indicating when the challenge was generated.',
|
danielebarchiesi@2
|
72 'type' => 'int',
|
danielebarchiesi@2
|
73 'not null' => TRUE,
|
danielebarchiesi@2
|
74 'default' => 0,
|
danielebarchiesi@2
|
75 ),
|
danielebarchiesi@2
|
76 'form_id' => array(
|
danielebarchiesi@2
|
77 'description' => 'The form_id of the form where the CAPTCHA is added to.',
|
danielebarchiesi@2
|
78 'type' => 'varchar',
|
danielebarchiesi@2
|
79 'length' => 128,
|
danielebarchiesi@2
|
80 'not null' => TRUE,
|
danielebarchiesi@2
|
81 ),
|
danielebarchiesi@2
|
82 'solution' => array(
|
danielebarchiesi@2
|
83 'description' => 'Solution of the challenge.',
|
danielebarchiesi@2
|
84 'type' => 'varchar',
|
danielebarchiesi@2
|
85 'length' => 128,
|
danielebarchiesi@2
|
86 'not null' => TRUE,
|
danielebarchiesi@2
|
87 'default' => '',
|
danielebarchiesi@2
|
88 ),
|
danielebarchiesi@2
|
89 'status' => array(
|
danielebarchiesi@2
|
90 'description' => 'Status of the CAPTCHA session (unsolved, solved, ...)',
|
danielebarchiesi@2
|
91 'type' => 'int',
|
danielebarchiesi@2
|
92 'not null' => TRUE,
|
danielebarchiesi@2
|
93 'default' => 0,
|
danielebarchiesi@2
|
94 ),
|
danielebarchiesi@2
|
95 'attempts' => array(
|
danielebarchiesi@2
|
96 'description' => 'The number of attempts.',
|
danielebarchiesi@2
|
97 'type' => 'int',
|
danielebarchiesi@2
|
98 'not null' => TRUE,
|
danielebarchiesi@2
|
99 'default' => 0,
|
danielebarchiesi@2
|
100 )
|
danielebarchiesi@2
|
101 ),
|
danielebarchiesi@2
|
102 'primary key' => array('csid'),
|
danielebarchiesi@2
|
103 'indexes' => array(
|
danielebarchiesi@2
|
104 'csid_ip' => array('csid', 'ip_address'),
|
danielebarchiesi@2
|
105 ),
|
danielebarchiesi@2
|
106 );
|
danielebarchiesi@2
|
107
|
danielebarchiesi@2
|
108 return $schema;
|
danielebarchiesi@2
|
109 }
|
danielebarchiesi@2
|
110
|
danielebarchiesi@2
|
111 /**
|
danielebarchiesi@2
|
112 * Implementation of hook_requirements().
|
danielebarchiesi@2
|
113 */
|
danielebarchiesi@2
|
114 function captcha_requirements($phase) {
|
danielebarchiesi@2
|
115 $requirements = array();
|
danielebarchiesi@2
|
116 $t = get_t();
|
danielebarchiesi@2
|
117 if ($phase == 'runtime' && variable_get('captcha_enable_stats', FALSE)) {
|
danielebarchiesi@2
|
118 // Show the wrong response counter in the status report.
|
danielebarchiesi@2
|
119 $requirements['captcha_wrong_response_counter'] = array(
|
danielebarchiesi@2
|
120 'title' => $t('CAPTCHA'),
|
danielebarchiesi@2
|
121 'value' => format_plural(
|
danielebarchiesi@2
|
122 variable_get('captcha_wrong_response_counter', 0),
|
danielebarchiesi@2
|
123 'Already 1 blocked form submission',
|
danielebarchiesi@2
|
124 'Already @count blocked form submissions'
|
danielebarchiesi@2
|
125 ),
|
danielebarchiesi@2
|
126 'severity' => REQUIREMENT_INFO,
|
danielebarchiesi@2
|
127 );
|
danielebarchiesi@2
|
128 }
|
danielebarchiesi@2
|
129 return $requirements;
|
danielebarchiesi@2
|
130 }
|
danielebarchiesi@2
|
131
|
danielebarchiesi@2
|
132 /**
|
danielebarchiesi@2
|
133 * Implementation of hook_install().
|
danielebarchiesi@2
|
134 */
|
danielebarchiesi@2
|
135 function captcha_install() {
|
danielebarchiesi@2
|
136 $t = get_t();
|
danielebarchiesi@2
|
137 // Insert some default CAPTCHA points.
|
danielebarchiesi@2
|
138 $form_ids = array(
|
danielebarchiesi@2
|
139 'contact_site_form', 'contact_personal_form',
|
danielebarchiesi@2
|
140 'user_register_form', 'user_pass', 'user_login', 'user_login_block',
|
danielebarchiesi@2
|
141 'forum_node_form'
|
danielebarchiesi@2
|
142 );
|
danielebarchiesi@2
|
143 // Add form_ids of all currently known node types too.
|
danielebarchiesi@2
|
144 foreach (node_type_get_names() as $type => $name) {
|
danielebarchiesi@2
|
145 $form_ids[] = 'comment_node_' . $type . '_form';
|
danielebarchiesi@2
|
146 }
|
danielebarchiesi@2
|
147 foreach ($form_ids as $form_id) {
|
danielebarchiesi@2
|
148 db_insert('captcha_points')
|
danielebarchiesi@2
|
149 ->fields(array(
|
danielebarchiesi@2
|
150 'form_id' => $form_id,
|
danielebarchiesi@2
|
151 'module' => NULL,
|
danielebarchiesi@2
|
152 'captcha_type' => NULL,
|
danielebarchiesi@2
|
153 ))
|
danielebarchiesi@2
|
154 ->execute();
|
danielebarchiesi@2
|
155 }
|
danielebarchiesi@2
|
156
|
danielebarchiesi@2
|
157 // Be friendly to your users: what to do after install?
|
danielebarchiesi@2
|
158 drupal_set_message($t('You can now <a href="!captcha_admin">configure the CAPTCHA module</a> for your site.',
|
danielebarchiesi@2
|
159 array('!captcha_admin' => url('admin/config/people/captcha'))), 'status');
|
danielebarchiesi@2
|
160
|
danielebarchiesi@2
|
161 // Explain to users that page caching may be disabled.
|
danielebarchiesi@2
|
162 if (variable_get('cache', 0) != 0) {
|
danielebarchiesi@2
|
163 drupal_set_message($t('Note that the CAPTCHA module disables <a href="!performance_admin">page caching</a> of pages that include a CAPTCHA challenge.',
|
danielebarchiesi@2
|
164 array('!performance_admin' => url('admin/config/development/performance'))), 'warning');
|
danielebarchiesi@2
|
165 }
|
danielebarchiesi@2
|
166
|
danielebarchiesi@2
|
167 }
|
danielebarchiesi@2
|
168
|
danielebarchiesi@2
|
169 /**
|
danielebarchiesi@2
|
170 * Implementation of hook_uninstall().
|
danielebarchiesi@2
|
171 */
|
danielebarchiesi@2
|
172 function captcha_uninstall() {
|
danielebarchiesi@2
|
173 drupal_uninstall_schema('captcha');
|
danielebarchiesi@2
|
174 db_query("DELETE FROM {variable} WHERE name LIKE 'captcha_%'");
|
danielebarchiesi@2
|
175 cache_clear_all('variables', 'cache');
|
danielebarchiesi@2
|
176 }
|
danielebarchiesi@2
|
177
|
danielebarchiesi@2
|
178 /**
|
danielebarchiesi@2
|
179 * Implementation of hook_update_N()
|
danielebarchiesi@2
|
180 */
|
danielebarchiesi@2
|
181 function captcha_update_6200() {
|
danielebarchiesi@2
|
182 $items = array();
|
danielebarchiesi@2
|
183
|
danielebarchiesi@2
|
184 // Table for the CAPTCHA sessions.
|
danielebarchiesi@2
|
185 $schema['captcha_sessions'] = array(
|
danielebarchiesi@2
|
186 'description' => 'Stores the data about CAPTCHA sessions (solution, IP address, timestamp, ...).',
|
danielebarchiesi@2
|
187 'fields' => array(
|
danielebarchiesi@2
|
188 'csid' => array(
|
danielebarchiesi@2
|
189 'description' => 'CAPTCHA session ID.',
|
danielebarchiesi@2
|
190 'type' => 'serial',
|
danielebarchiesi@2
|
191 'not null' => TRUE,
|
danielebarchiesi@2
|
192 ),
|
danielebarchiesi@2
|
193 'uid' => array(
|
danielebarchiesi@2
|
194 'description' => "User's {users}.uid.",
|
danielebarchiesi@2
|
195 'type' => 'int',
|
danielebarchiesi@2
|
196 'not null' => TRUE,
|
danielebarchiesi@2
|
197 'default' => 0,
|
danielebarchiesi@2
|
198 ),
|
danielebarchiesi@2
|
199 'sid' => array(
|
danielebarchiesi@2
|
200 'description' => "Session ID of the user.",
|
danielebarchiesi@2
|
201 'type' => 'varchar',
|
danielebarchiesi@2
|
202 'length' => 64,
|
danielebarchiesi@2
|
203 'not null' => TRUE,
|
danielebarchiesi@2
|
204 'default' => '',
|
danielebarchiesi@2
|
205 ),
|
danielebarchiesi@2
|
206 'ip_address' => array(
|
danielebarchiesi@2
|
207 'description' => 'IP address of the visitor.',
|
danielebarchiesi@2
|
208 'type' => 'varchar',
|
danielebarchiesi@2
|
209 'length' => 128,
|
danielebarchiesi@2
|
210 'not null' => FALSE,
|
danielebarchiesi@2
|
211 ),
|
danielebarchiesi@2
|
212 'timestamp' => array(
|
danielebarchiesi@2
|
213 'description' => 'A Unix timestamp indicating when the challenge was generated.',
|
danielebarchiesi@2
|
214 'type' => 'int',
|
danielebarchiesi@2
|
215 'not null' => TRUE,
|
danielebarchiesi@2
|
216 'default' => 0,
|
danielebarchiesi@2
|
217 ),
|
danielebarchiesi@2
|
218 'form_id' => array(
|
danielebarchiesi@2
|
219 'description' => 'The form_id of the form where the CAPTCHA is added to.',
|
danielebarchiesi@2
|
220 'type' => 'varchar',
|
danielebarchiesi@2
|
221 'length' => 128,
|
danielebarchiesi@2
|
222 'not null' => TRUE,
|
danielebarchiesi@2
|
223 ),
|
danielebarchiesi@2
|
224 'solution' => array(
|
danielebarchiesi@2
|
225 'description' => 'Solution of the challenge.',
|
danielebarchiesi@2
|
226 'type' => 'varchar',
|
danielebarchiesi@2
|
227 'length' => 128,
|
danielebarchiesi@2
|
228 'not null' => TRUE,
|
danielebarchiesi@2
|
229 'default' => '',
|
danielebarchiesi@2
|
230 ),
|
danielebarchiesi@2
|
231 'status' => array(
|
danielebarchiesi@2
|
232 'description' => 'Status of the CAPTCHA session (unsolved, solved, ...)',
|
danielebarchiesi@2
|
233 'type' => 'int',
|
danielebarchiesi@2
|
234 'not null' => TRUE,
|
danielebarchiesi@2
|
235 'default' => 0,
|
danielebarchiesi@2
|
236 ),
|
danielebarchiesi@2
|
237 'attempts' => array(
|
danielebarchiesi@2
|
238 'description' => 'The number of attempts.',
|
danielebarchiesi@2
|
239 'type' => 'int',
|
danielebarchiesi@2
|
240 'not null' => TRUE,
|
danielebarchiesi@2
|
241 'default' => 0,
|
danielebarchiesi@2
|
242 )
|
danielebarchiesi@2
|
243 ),
|
danielebarchiesi@2
|
244 'primary key' => array('csid'),
|
danielebarchiesi@2
|
245 'indexes' => array(
|
danielebarchiesi@2
|
246 'csid_ip' => array('csid', 'ip_address'),
|
danielebarchiesi@2
|
247 ),
|
danielebarchiesi@2
|
248 );
|
danielebarchiesi@2
|
249
|
danielebarchiesi@2
|
250 db_create_table($items, 'captcha_sessions', $schema['captcha_sessions']);
|
danielebarchiesi@2
|
251
|
danielebarchiesi@2
|
252 return $items;
|
danielebarchiesi@2
|
253 }
|
danielebarchiesi@2
|
254
|
danielebarchiesi@2
|
255 /**
|
danielebarchiesi@2
|
256 * Implementation of hook_update_N()
|
danielebarchiesi@2
|
257 * Change the captcha points with the old text CAPTCHA, which was
|
danielebarchiesi@2
|
258 * removed from the 6.x-2.x branch, to the simple math CAPTCHA.
|
danielebarchiesi@2
|
259 */
|
danielebarchiesi@2
|
260 function captcha_update_6201() {
|
danielebarchiesi@2
|
261 $items = array();
|
danielebarchiesi@2
|
262 $items[] = update_sql("UPDATE {captcha_points} SET module = 'captcha', type = 'Math' WHERE module = 'text_captcha' AND type = 'Text';");
|
danielebarchiesi@2
|
263 return $items;
|
danielebarchiesi@2
|
264 }
|
danielebarchiesi@2
|
265
|
danielebarchiesi@2
|
266
|
danielebarchiesi@2
|
267 /**
|
danielebarchiesi@2
|
268 * Implementation of hook_update_N()
|
danielebarchiesi@2
|
269 * Add a CAPTCHA token column to captcha_sessions table.
|
danielebarchiesi@2
|
270 */
|
danielebarchiesi@2
|
271 function captcha_update_6202() {
|
danielebarchiesi@2
|
272 $ret = array();
|
danielebarchiesi@2
|
273 db_add_column($ret, 'captcha_sessions', 'token', 'varchar(64)');
|
danielebarchiesi@2
|
274 return $ret;
|
danielebarchiesi@2
|
275 }
|
danielebarchiesi@2
|
276
|
danielebarchiesi@2
|
277
|
danielebarchiesi@2
|
278
|
danielebarchiesi@2
|
279 /**
|
danielebarchiesi@2
|
280 * Implementation of hook_update_N()
|
danielebarchiesi@2
|
281 * Rename the type field to captcha_type in captcha_points.
|
danielebarchiesi@2
|
282 */
|
danielebarchiesi@2
|
283 function captcha_update_6203() {
|
danielebarchiesi@2
|
284 $ret = array();
|
danielebarchiesi@2
|
285 db_change_field($ret, 'captcha_points', 'type', 'captcha_type', array('type' => 'varchar', 'length' => 64));
|
danielebarchiesi@2
|
286 return $ret;
|
danielebarchiesi@2
|
287 }
|
danielebarchiesi@2
|
288
|
danielebarchiesi@2
|
289
|
danielebarchiesi@2
|
290 /**
|
danielebarchiesi@2
|
291 * Migrate form configuration for changed form ids in Drupal 7.
|
danielebarchiesi@2
|
292 */
|
danielebarchiesi@2
|
293 function captcha_update_7000() {
|
danielebarchiesi@2
|
294 // 'user_register' became 'user_register_form'.
|
danielebarchiesi@2
|
295 db_update('captcha_points')
|
danielebarchiesi@2
|
296 ->fields(array('form_id' => 'user_register_form'))
|
danielebarchiesi@2
|
297 ->condition('form_id', 'user_register')
|
danielebarchiesi@2
|
298 ->execute();
|
danielebarchiesi@2
|
299 // 'contact_mail_page' became 'contact_site_form'.
|
danielebarchiesi@2
|
300 db_update('captcha_points')
|
danielebarchiesi@2
|
301 ->fields(array('form_id' => 'contact_site_form'))
|
danielebarchiesi@2
|
302 ->condition('form_id', 'contact_mail_page')
|
danielebarchiesi@2
|
303 ->execute();
|
danielebarchiesi@2
|
304 // 'contact_mail_user' became 'contact_personal_form'.
|
danielebarchiesi@2
|
305 db_update('captcha_points')
|
danielebarchiesi@2
|
306 ->fields(array('form_id' => 'contact_personal_form'))
|
danielebarchiesi@2
|
307 ->condition('form_id', 'contact_mail_user')
|
danielebarchiesi@2
|
308 ->execute();
|
danielebarchiesi@2
|
309
|
danielebarchiesi@2
|
310 // The D6-style comment_form form_id is split per node type
|
danielebarchiesi@2
|
311 // in D7: comment_node_{type}_form, e.g. comment_node_page_form.
|
danielebarchiesi@2
|
312 // Get the current settings for 'comment_form'.
|
danielebarchiesi@2
|
313 $captcha_point = db_query(
|
danielebarchiesi@2
|
314 "SELECT * FROM {captcha_points} WHERE form_id = :comment_form_id",
|
danielebarchiesi@2
|
315 array(':comment_form_id' => 'comment_form')
|
danielebarchiesi@2
|
316 )->fetchObject();
|
danielebarchiesi@2
|
317 if ($captcha_point !== FALSE) {
|
danielebarchiesi@2
|
318 // Create entries for D7-style node form IDs.
|
danielebarchiesi@2
|
319 $module = $captcha_point->module;
|
danielebarchiesi@2
|
320 $captcha_type = $captcha_point->captcha_type;
|
danielebarchiesi@2
|
321 foreach (node_type_get_names() as $type => $name) {
|
danielebarchiesi@2
|
322 $form_id = 'comment_node_' . $type . '_form';
|
danielebarchiesi@2
|
323 db_insert('captcha_points')
|
danielebarchiesi@2
|
324 ->fields(array(
|
danielebarchiesi@2
|
325 'form_id' => $form_id,
|
danielebarchiesi@2
|
326 'module' => $module,
|
danielebarchiesi@2
|
327 'captcha_type' => $captcha_type,
|
danielebarchiesi@2
|
328 ))
|
danielebarchiesi@2
|
329 ->execute();
|
danielebarchiesi@2
|
330 }
|
danielebarchiesi@2
|
331 // Delete outdated entry.
|
danielebarchiesi@2
|
332 db_delete('captcha_points')
|
danielebarchiesi@2
|
333 ->condition('form_id', 'comment_form')
|
danielebarchiesi@2
|
334 ->execute();
|
danielebarchiesi@2
|
335 }
|
danielebarchiesi@2
|
336 }
|