t("User: compare"), 'description' => t('Compare two users (logged-in user and user being viewed, for example)'), 'callback' => 'ctools_compare_users_access_check', 'default' => array( 'equality' => 1, ), 'settings form' => 'ctools_compare_users_settings', 'summary' => 'ctools_compare_users_ctools_access_summary', 'required context' => array( new ctools_context_required(t('First User'), 'user'), new ctools_context_required(t("Second User"), 'user') ), ); /** * Settings form for the 'by perm' access plugin */ function ctools_compare_users_settings($form, &$form_state, $conf) { $form['settings']['helptext'] = array( '#type' => 'markup', '#value' => '
' . t('Grant access based on comparison of the two user contexts. For example, to grant access to a user to view their own profile, choose "logged in user" and "user being viewed" and say "grant access if equal". When they\'re the same, access will be granted.') . '
', ); $form['settings']['equality'] = array( '#type' => 'radios', '#title' => t('Grant access if user contexts are'), '#options' => array(1 => t('Equal'), 0 => t('Not equal')), '#default_value' => $conf['equality'], ); return $form; } /** * Check for access. */ function ctools_compare_users_access_check($conf, $context) { if (empty($context) || count($context) != 2 || empty($context[0]->data) || empty($context[1]->data)) { return FALSE; } $account1 = $context[0]->data; $account2 = $context[1]->data; // xor returns false if the two bools are the same, and true if they are not. // i.e, if we asked for equality and they are equal, return true. // If we asked for inequality and they are equal, return false. return ($account1->uid == $account2->uid) xor empty($conf['equality']); } /** * Describe an instance of this plugin. */ function ctools_compare_users_ctools_access_summary($conf, $context) { $comparison = !empty($conf['equality']) ? "is" : 'is not'; return t('@id1 @comp @id2', array('@comp' => $comparison, '@id1' => $context[0]->identifier, '@id2' => $context[1]->identifier)); }