12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455 |
- <?php
- /**
- * @file
- * Builds placeholder replacement tokens for user-related data.
- */
- /**
- * Implements hook_token_info().
- */
- function googleanalytics_token_info() {
- $user['role-names'] = array(
- 'name' => t('User role names'),
- 'description' => t('The role names the user account is a member of as comma separated list.'),
- 'needs-data' => 'user',
- );
- $user['role-ids'] = array(
- 'name' => t('User role ids'),
- 'description' => t('The role ids the user account is a member of as comma separated list.'),
- 'needs-data' => 'user',
- );
- return array(
- 'tokens' => array('user' => $user),
- );
- }
- /**
- * Implements hook_tokens().
- */
- function googleanalytics_tokens($type, $tokens, array $data = array(), array $options = array()) {
- $sanitize = !empty($options['sanitize']);
- $replacements = array();
- if ($type == 'user' && !empty($data['user']->roles)) {
- $account = $data['user'];
- foreach ($tokens as $name => $original) {
- switch ($name) {
- // Basic user account information.
- case 'role-names':
- $names = implode(',', $account->roles);
- $replacements[$original] = $sanitize ? check_plain($names) : $names;
- break;
- case 'role-ids':
- $ids = implode(',', array_keys($account->roles));
- $replacements[$original] = $sanitize ? check_plain($ids) : $ids;
- break;
- }
- }
- }
- return $replacements;
- }
|