danielebarchiesi@0
|
1 <?php
|
danielebarchiesi@0
|
2
|
danielebarchiesi@0
|
3 /**
|
danielebarchiesi@0
|
4 * @file
|
danielebarchiesi@0
|
5 * Plugin to provide access control based on evaluated PHP.
|
danielebarchiesi@0
|
6 */
|
danielebarchiesi@0
|
7
|
danielebarchiesi@0
|
8 /**
|
danielebarchiesi@0
|
9 * Plugins are described by creating a $plugin array which will be used
|
danielebarchiesi@0
|
10 * by the system that includes this file.
|
danielebarchiesi@0
|
11 */
|
danielebarchiesi@0
|
12 $plugin = array(
|
danielebarchiesi@0
|
13 'title' => t("PHP Code"),
|
danielebarchiesi@0
|
14 'description' => t('Control access through arbitrary PHP code.'),
|
danielebarchiesi@0
|
15 'callback' => 'ctools_php_ctools_access_check',
|
danielebarchiesi@0
|
16 'default' => array('description' => '', 'php' => ''),
|
danielebarchiesi@0
|
17 'settings form' => 'ctools_php_ctools_access_settings',
|
danielebarchiesi@0
|
18 'summary' => 'ctools_php_ctools_access_summary',
|
danielebarchiesi@0
|
19 'all contexts' => TRUE,
|
danielebarchiesi@0
|
20 );
|
danielebarchiesi@0
|
21
|
danielebarchiesi@0
|
22 /**
|
danielebarchiesi@0
|
23 * Settings form for the 'by perm' access plugin
|
danielebarchiesi@0
|
24 *
|
danielebarchiesi@0
|
25 * @todo Need a way to provide a list of all available contexts to be used by
|
danielebarchiesi@0
|
26 * the eval-ed PHP.
|
danielebarchiesi@0
|
27 */
|
danielebarchiesi@0
|
28 function ctools_php_ctools_access_settings($form, &$form_state, $conf) {
|
danielebarchiesi@0
|
29 $perms = array();
|
danielebarchiesi@0
|
30
|
danielebarchiesi@0
|
31 $form['settings']['description'] = array(
|
danielebarchiesi@0
|
32 '#type' => 'textfield',
|
danielebarchiesi@0
|
33 '#title' => t('Administrative desc'),
|
danielebarchiesi@0
|
34 '#default_value' => $conf['description'],
|
danielebarchiesi@0
|
35 '#description' => t('A description for this test for administrative purposes.'),
|
danielebarchiesi@0
|
36 );
|
danielebarchiesi@0
|
37 $form['settings']['php'] = array(
|
danielebarchiesi@0
|
38 '#type' => 'textarea',
|
danielebarchiesi@0
|
39 '#title' => t('PHP Code'),
|
danielebarchiesi@0
|
40 '#default_value' => $conf['php'],
|
danielebarchiesi@0
|
41 '#description' => t('Access will be granted if the following PHP code returns <code>TRUE</code>. Do not include <?php ?>. Note that executing incorrect PHP-code can break your Drupal site. All contexts will be available in the <em>$contexts</em> variable.'),
|
danielebarchiesi@0
|
42 );
|
danielebarchiesi@0
|
43 if (!user_access('use PHP for settings')) {
|
danielebarchiesi@0
|
44 $form['settings']['php']['#disabled'] = TRUE;
|
danielebarchiesi@0
|
45 $form['settings']['php']['#value'] = $conf['php'];
|
danielebarchiesi@0
|
46 $form['settings']['php']['#description'] .= ' ' . t('You do not have sufficient permissions to edit PHP code.');
|
danielebarchiesi@0
|
47 }
|
danielebarchiesi@0
|
48 return $form;
|
danielebarchiesi@0
|
49 }
|
danielebarchiesi@0
|
50
|
danielebarchiesi@0
|
51 /**
|
danielebarchiesi@0
|
52 * Check for access.
|
danielebarchiesi@0
|
53 */
|
danielebarchiesi@0
|
54 function ctools_php_ctools_access_check($__conf, $contexts) {
|
danielebarchiesi@0
|
55 $access = eval($__conf['php']);
|
danielebarchiesi@0
|
56 return $access;
|
danielebarchiesi@0
|
57 }
|
danielebarchiesi@0
|
58
|
danielebarchiesi@0
|
59 /**
|
danielebarchiesi@0
|
60 * Provide a summary description based upon the checked roles.
|
danielebarchiesi@0
|
61 */
|
danielebarchiesi@0
|
62 function ctools_php_ctools_access_summary($conf, $contexts) {
|
danielebarchiesi@0
|
63 return !empty($conf['description']) ? check_plain($conf['description']) : t('No description');
|
danielebarchiesi@0
|
64 }
|