annotate sites/all/modules/ctools/plugins/access/node_access.inc @ 9:830c812b520f

added smtp module
author root <root@paio.local>
date Mon, 28 Oct 2013 15:34:27 +0000
parents ff03f76ab3fe
children
rev   line source
danielebarchiesi@0 1 <?php
danielebarchiesi@0 2
danielebarchiesi@0 3 /**
danielebarchiesi@0 4 * @file
danielebarchiesi@0 5 * Plugin to provide access control based upon node type.
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("Node: accessible"),
danielebarchiesi@0 14 'description' => t('Control access with built in Drupal node access test.'),
danielebarchiesi@0 15 'callback' => 'ctools_node_access_ctools_access_check',
danielebarchiesi@0 16 'default' => array('type' => 'view'),
danielebarchiesi@0 17 'settings form' => 'ctools_node_access_ctools_access_settings',
danielebarchiesi@0 18 'settings form submit' => 'ctools_node_access_ctools_access_settings_submit',
danielebarchiesi@0 19 'summary' => 'ctools_node_access_ctools_access_summary',
danielebarchiesi@0 20 'required context' => array(
danielebarchiesi@0 21 new ctools_context_required(t('User'), 'user'),
danielebarchiesi@0 22 new ctools_context_required(t('Node'), 'node'),
danielebarchiesi@0 23 ),
danielebarchiesi@0 24 );
danielebarchiesi@0 25
danielebarchiesi@0 26 /**
danielebarchiesi@0 27 * Settings form for the 'by node_access' access plugin
danielebarchiesi@0 28 */
danielebarchiesi@0 29 function ctools_node_access_ctools_access_settings($form, &$form_state, $conf) {
danielebarchiesi@0 30 $form['settings']['type'] = array(
danielebarchiesi@0 31 '#title' => t('Operation'),
danielebarchiesi@0 32 '#type' => 'radios',
danielebarchiesi@0 33 '#options' => array(
danielebarchiesi@0 34 'view' => t('View'),
danielebarchiesi@0 35 'update' => t('Update'),
danielebarchiesi@0 36 'delete' => t('Delete'),
danielebarchiesi@0 37 'create' => t('Create nodes of the same type'),
danielebarchiesi@0 38 ),
danielebarchiesi@0 39 '#description' => t('Using built in Drupal node access rules, determine if the user can perform the selected operation on the node.'),
danielebarchiesi@0 40 '#default_value' => $conf['type'],
danielebarchiesi@0 41 );
danielebarchiesi@0 42 return $form;
danielebarchiesi@0 43 }
danielebarchiesi@0 44
danielebarchiesi@0 45 /**
danielebarchiesi@0 46 * Check for access.
danielebarchiesi@0 47 */
danielebarchiesi@0 48 function ctools_node_access_ctools_access_check($conf, $context) {
danielebarchiesi@0 49 // As far as I know there should always be a context at this point, but this
danielebarchiesi@0 50 // is safe.
danielebarchiesi@0 51 list($user_context, $node_context) = $context;
danielebarchiesi@0 52 if (empty($node_context) || empty($node_context->data) || empty($node_context->data->type)) {
danielebarchiesi@0 53 return FALSE;
danielebarchiesi@0 54 }
danielebarchiesi@0 55
danielebarchiesi@0 56 if (empty($user_context) || empty($user_context->data)) {
danielebarchiesi@0 57 return FALSE;
danielebarchiesi@0 58 }
danielebarchiesi@0 59
danielebarchiesi@0 60 if ($conf['type'] == 'create') {
danielebarchiesi@0 61 return node_access('create', $node_context->data->type, $user_context->data);
danielebarchiesi@0 62 }
danielebarchiesi@0 63 else {
danielebarchiesi@0 64 return node_access($conf['type'], $node_context->data, $user_context->data);
danielebarchiesi@0 65 }
danielebarchiesi@0 66 }
danielebarchiesi@0 67
danielebarchiesi@0 68 /**
danielebarchiesi@0 69 * Provide a summary description based upon the checked node_accesss.
danielebarchiesi@0 70 */
danielebarchiesi@0 71 function ctools_node_access_ctools_access_summary($conf, $context) {
danielebarchiesi@0 72 list($user_context, $node_context) = $context;
danielebarchiesi@0 73 $replacement = array('@user' => $user_context->identifier, '@node' => $node_context->identifier);
danielebarchiesi@0 74
danielebarchiesi@0 75 switch ($conf['type']) {
danielebarchiesi@0 76 case 'view':
danielebarchiesi@0 77 return t('@user can view @node.', $replacement);
danielebarchiesi@0 78
danielebarchiesi@0 79 case 'update':
danielebarchiesi@0 80 return t('@user can edit @node.', $replacement);
danielebarchiesi@0 81
danielebarchiesi@0 82 case 'delete':
danielebarchiesi@0 83 return t('@user can delete @node.', $replacement);
danielebarchiesi@0 84
danielebarchiesi@0 85 case 'create':
danielebarchiesi@0 86 return t('@user can create nodes of the same type as @node.', $replacement);
danielebarchiesi@0 87 }
danielebarchiesi@0 88 }
danielebarchiesi@0 89