array( 'arguments' => array('element' => NULL), ), 'email_formatter_default' => array( 'arguments' => array('element' => NULL), ), 'email_formatter_spamspan' => array( 'arguments' => array('element' => NULL), ), 'email_formatter_contact' => array( 'arguments' => array('element' => NULL), ), ); } /** * Implementation of hook_field_info(). */ function email_field_info() { return array( 'email' => array( 'label' => 'Email', 'callbacks' => array( 'tables' => CONTENT_CALLBACK_DEFAULT, 'arguments' => CONTENT_CALLBACK_DEFAULT, ), ), ); } /** * Implementation of hook_field_settings(). */ function email_field_settings($op, $field) { switch ($op) { case 'database columns': $columns['email'] = array('type' => 'varchar', 'length' => 255, 'not null' => FALSE, 'sortable' => TRUE); return $columns; } } /** * Implementation of hook_field(). */ function email_field($op, &$node, $field, &$items, $teaser, $page) { switch ($op) { case 'validate': if (is_array($items)) { foreach ($items as $delta => $item) { if ($item['email'] != '' && !valid_email_address(trim($item['email']))) { form_set_error($field['field_name'],t('"%mail" is not a valid email address',array('%mail' => $item['email']))); } } } break; case 'sanitize': foreach ($items as $delta => $item) { $items[$delta]['safe'] = check_plain($item['email']); } break; } } /** * Implementation of hook_content_is_empty(). */ function email_content_is_empty($item, $field) { if (empty($item['email'])) { return TRUE; } return FALSE; } /** * Implementation of hook_field_formatter_info(). * */ function email_field_formatter_info() { $formats = array( 'default' => array( 'label' => t('Default email link'), 'field types' => array('email'), 'multiple values' => CONTENT_HANDLE_CORE, ), 'contact' => array( 'label' => t('Email contact form'), 'field types' => array('email'), 'multiple values' => CONTENT_HANDLE_CORE, ), ); if (module_exists('spamspan')) { $formats += array( 'spamspan' => array( 'label' => t('Email SpamSpan'), 'field types' => array('email'), 'multiple values' => CONTENT_HANDLE_CORE, ), ); } return $formats; } /** * Theme function for 'default' email field formatter. */ function theme_email_formatter_default($element) { return !empty($element['#item']['safe']) ? ''. $element['#item']['safe'] .'' : ''; } /** * Theme function for 'spamspan' email field formatter. */ function theme_email_formatter_spamspan($element) { if (empty($element['#item']['safe'])) { return ''; } if (module_exists('spamspan')) { return spamspan($element['#item']['email']); } else { return ''. $element['#item']['safe'] .''; } } /** * Theme function for 'contact' email field formatter. */ function theme_email_formatter_contact($element) { return !empty($element['#item']['safe']) ? l(t('Email contact form'), 'email/'. $element['#node']->nid .'/'. $element['#field_name']) : ''; } /** * Implementation of hook_widget_info(). */ function email_widget_info() { return array( 'email_textfield' => array( 'label' => t('Text field'), 'field types' => array('email'), 'multiple values' => CONTENT_HANDLE_CORE, 'callbacks' => array( 'default value' => CONTENT_CALLBACK_DEFAULT, ), ), ); } /** * Implementation of FAPI hook_elements(). */ function email_elements() { return array( 'email_textfield' => array( '#input' => TRUE, '#columns' => array('email'), '#delta' => 0, '#process' => array('email_textfield_process'), ), ); } /** * Implementation of hook_widget_settings(). */ function email_widget_settings($op, $widget) { switch ($op) { case 'form': $form = array(); $form['size'] = array( '#type' => 'textfield', '#title' => t('Size'), '#default_value' => isset($widget['size']) ? $widget['size'] : 60, '#required' => FALSE, '#description' => t('Size of textfield'), ); return $form; case 'validate': if (!empty($widget['size']) && (!is_numeric($widget['size']) || intval($widget['size']) != $widget['size'] || $widget['size'] <= 0)) { form_set_error('size', t('"Size" must be a positive integer.')); } break; case 'save': return array('size'); } } /** * Implementation of hook_widget(). */ function email_widget(&$form, &$form_state, $field, $items, $delta = 0) { $element = array( '#type' => $field['widget']['type'], '#default_value' => isset($items[$delta]) ? $items[$delta] : '', ); return $element; } /** * Process an individual element. */ function email_textfield_process($element, $edit, $form_state, $form) { $field = $form['#field_info'][$element['#field_name']]; $field_key = $element['#columns'][0]; $delta = $element['#delta']; $element[$field_key] = array( '#type' => 'textfield', '#title' => t($field['widget']['label']), '#description' => t($field['widget']['description']), '#required' => $element['#required'], '#maxlength' => 255, '#size' => isset($field['widget']['size']) ? $field['widget']['size'] : 60, '#default_value' => isset($element['#value'][$field_key]) ? $element['#value'][$field_key] : NULL, ); return $element; } /** * FAPI theme for an individual text elements. */ function theme_email_textfield($element) { return $element['#children']; } /** * Implementation of hook_menu(). */ function email_menu() { $items['email/%/%'] = array( 'title' => t('Email Contact Form'), 'page callback' => 'email_mail_page', 'page arguments' => array(1, 2), 'access callback' => 'user_access', 'access arguments' => array('access content'), 'type' => MENU_CALLBACK, ); return $items; } /** * The contact form page. */ function email_mail_page($nid, $field_name) { if (!is_numeric($nid)) { drupal_not_found(); return; } if (module_exists('content_permissions')) { if (!user_access('view '. $field_name)) { drupal_not_found(); return; } } $node = node_load(intval($nid)); if (!$node) { drupal_not_found(); return; } $field = $node->$field_name; $email = $field[0]['email']; $types = content_types($node->type); // Validate field name $types = content_types($node->type); if (empty($email) || !isset($types['fields'][$field_name]) || $types['fields'][$field_name]['type'] != 'email' || ($types['fields'][$field_name]['display_settings']['teaser']['format'] != 'contact' && $types['fields'][$field_name]['display_settings']['full']['format'] != 'contact')) { drupal_not_found(); return; } if (!flood_is_allowed('email', variable_get('email_hourly_threshold', 3))) { $output = t("You cannot send more than %number messages per hour. Please try again later.", array('%number' => variable_get('email_hourly_threshold', 3))); } else { $output = drupal_get_form('email_mail_page_form', $node, $field_name, $email); } return $output; } /** * Contact form */ function email_mail_page_form($form_state, $node, $field_name, $email) { global $user; $form['node'] = array( '#type' => 'value', '#value' => $node, ); $form['field_name'] = array( '#type' => 'value', '#value' => $field_name, ); $form['email'] = array( '#type' => 'value', '#value' => $email, ); $form['name'] = array( '#type' => 'textfield', '#title' => t('Your name'), '#maxlength' => 255, '#default_value' => $user->uid ? $user->name : '', '#required' => TRUE, ); $form['mail'] = array( '#type' => 'textfield', '#title' => t('Your e-mail address'), '#maxlength' => 255, '#default_value' => $user->uid ? $user->mail : '', '#required' => TRUE, ); $form['subject'] = array( '#type' => 'textfield', '#title' => t('Subject'), '#maxlength' => 255, '#required' => TRUE, ); $form['message'] = array( '#type' => 'textarea', '#title' => t('Message'), '#required' => TRUE, ); $form['submit'] = array( '#type' => 'submit', '#value' => t('Send e-mail'), '#validate' => array('email_mail_page_form_validate'), '#submit' => array('email_mail_page_form_submit'), ); return $form; } /** * Validate the site-wide contact page form submission. */ function email_mail_page_form_validate($form, &$form_state) { if (!valid_email_address($form_state['values']['mail'])) { form_set_error('mail', t('You must enter a valid e-mail address.')); } if (preg_match("/\r|\n/", $form_state['values']['subject'])) { form_set_error('subject', t('The subject cannot contain linebreaks.')); watchdog('mail', 'Email injection exploit attempted in email form subject: '. check_plain($form_state['values']['subject']), WATCHDOG_NOTICE); } } /** * Process the site-wide contact page form submission. */ function email_mail_page_form_submit($form, &$form_state) { $node = $form_state['values']['node']; $field_name = $form_state['values']['field_name']; $email = $form_state['values']['email']; // E-mail address of the sender: as the form field is a text field, // all instances of \r and \n have been automatically stripped from it. $from = $form_state['values']['mail']; $params['node'] = $node; $params['subject'] = $form_state['values']['subject']; $params['name'] = $form_state['values']['name']; $params['message'] = $form_state['values']['message']; $params['url'] = url('node/' . $node->nid, array('absolute' => TRUE)); // Send the e-mail to the recipients: drupal_mail('email', 'contact', $email, language_default(), $params, $from); // Log the operation: flood_register_event('email'); watchdog('mail', t('%name-from sent an e-mail at %form.', array('%name-from' => theme('placeholder', $form_state['values']['name'] ." <$from>"), '%form' => url($_GET['q'], array('absolute' => TRUE))))); // Update user: drupal_set_message(t('Your message has been sent.')); // Jump to home page rather than back to contact page to avoid contradictory messages if flood control has been activated. $form_state['redirect'] = 'node/'. $node->nid; } /** * Implementation of hook_mail() */ function email_mail($key, &$message, $params) { $language = $message['language']; switch($key) { case 'contact': $node = $params['node']; // Compose the body: $msg[] = t('@name sent a message using the contact form at @node.', array('@name' => $params['name'], '@node' => $params['url']), $language->language); $msg[] = $params['message']; // Tidy up the body: foreach ($msg as $index_key => $value) { $msg[$index_key] = wordwrap($value); } // Prepare the body: $message['body'] = implode("\n\n", $msg); $message['subject'] = t('[@title] @subject', array('@title' => preg_replace("/\r|\n/",'', $node->title), '@subject' => $params['subject']), $language->language); break; } } /** * Implementation of hook token_list */ function email_token_list($type = 'all') { if ($type == 'field' || $type == 'all') { $tokens['email']['raw'] = t('Raw email address'); $tokens['email']['formatted'] = t('Formatted email address'); return $tokens; } } /** * Implementation of hook token_values */ function email_token_values($type, $object = NULL, $options = array()) { if ($type == 'field') { $item = $object[0]; $tokens['raw'] = $item['email']; $tokens['formatted'] = $item['view']; return $tokens; } }