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
|