webform_encrypt.module 2.86 KB
Newer Older
Jake Bell's avatar
Jake Bell committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
<?php

/**
 * Implementation of hook_permission().
 */
function webform_encrypt_permission() {
  return array(
    'view encrypted values' => array(
      'title' => t('View Encrypted Values in Webform Results'),
      'description' => t('Users that do not have this permission will see placeholder text.'),
    ),
  );
}

/**
 * Implementation of hook_form_alter()
 */
function webform_encrypt_form_alter(&$form, $form_state, $form_id) {
  // Add our fields to the component add/edit form.
  if ($form_id == 'webform_component_edit_form') {

22
    $component = $form_state['build_info']['args'][1];
Jake Bell's avatar
Jake Bell committed
23

24 25 26
    // Exclude webform component types that don't make sense to encrypt.
    $excluded_types = array('fieldset', 'file', 'markup', 'pagebreak');
    if (!in_array($form['type']['#value'], $excluded_types)) {
Jake Bell's avatar
Jake Bell committed
27

28 29 30 31 32 33 34 35 36 37 38 39 40
      // Add settings for encryption.
      $form['encryption'] = array(
        '#type' => 'fieldset',
        '#title' => t('Encryption'),
        '#tree' => TRUE,
      );
      $form['encryption']['encrypt'] = array(
        '#type' => 'checkbox',
        '#title' => t('Encrypt this field\'s value'),
        '#description' => t('!link to edit encryption settings.', array('!link' => l('Click here', 'admin/settings/aes'))),
        '#default_value' => isset($component['extra']['encrypt']) ? $component['extra']['encrypt'] : 0,
      );
    }
Jake Bell's avatar
Jake Bell committed
41 42 43 44 45

  }
}

/**
46 47
 * Implementation of hook_webform_component_presave().
 * Save encryption settings for a component.
Jake Bell's avatar
Jake Bell committed
48
 */
49 50 51
function webform_encrypt_webform_component_presave(&$component) {
  $component['extra'] = array_merge($component['extra'], $component['encryption']);
  unset($component['encryption']);
Jake Bell's avatar
Jake Bell committed
52 53 54 55 56 57 58 59
}

/**
 * Implementation of hook_webform_submission_presave().
 * Encrypt the value if the component has been marked as such.
 */
function webform_encrypt_webform_submission_presave($node, &$submission) {
  foreach ($submission->data as $cid => $entry) {
60 61 62
    if (isset($node->webform['components'][$cid]['extra']['encrypt']) &&
        $node->webform['components'][$cid]['extra']['encrypt']) {
      $submission->data[$cid]['value'][0] = encrypt($entry['value'][0], array('base64' => TRUE));
Jake Bell's avatar
Jake Bell committed
63 64 65 66 67 68 69 70 71 72
    }
  }
}

/**
 * Implementation of hook_webform_submission_render_alter().
 * Decrypt values when displaying webform submissions.
 */
function webform_encrypt_webform_submission_render_alter(&$renderable) {
  foreach ($renderable['#submission']->data as $cid => $entry) {
73 74
    if (isset($renderable['#node']->webform['components'][$cid]['extra']['encrypt']) &&
        $renderable['#node']->webform['components'][$cid]['extra']['encrypt']) {
Jake Bell's avatar
Jake Bell committed
75 76
      $form_key = $renderable['#node']->webform['components'][$cid]['form_key'];
      if (user_access('view encrypted values')) {
77
        $renderable[$form_key]['#value'] = decrypt($entry['value'][0], array('base64' => TRUE));
Jake Bell's avatar
Jake Bell committed
78
      } else {
79
        $renderable[$form_key]['#value'] = t('[Value Encrypted]');
Jake Bell's avatar
Jake Bell committed
80 81 82 83
      }
    }
  }
}