annotate sites/all/modules/captcha/captcha.install @ 9:830c812b520f

added smtp module
author root <root@paio.local>
date Mon, 28 Oct 2013 15:34:27 +0000
parents b74b41bb73f0
children
rev   line source
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 }