5 * Builds placeholder replacement tokens for user-related data.
9 * Implements hook_token_info().
11 function piwik_token_info() {
12 $user['piwik-role-names'] = array(
13 'name' => t('User role names'),
14 'description' => t('The role names the user account is a member of as comma separated list.'),
15 'needs-data' => 'user',
17 $user['piwik-role-ids'] = array(
18 'name' => t('User role ids'),
19 'description' => t('The role ids the user account is a member of as comma separated list.'),
20 'needs-data' => 'user',
24 'tokens' => array('user' => $user),
29 * Implements hook_tokens().
31 function piwik_tokens($type, $tokens, array $data = array(), array $options = array()) {
32 $sanitize = !empty($options['sanitize']);
33 $replacements = array();
35 if ($type == 'user' && !empty($data['user']->roles)) {
36 $account = $data['user'];
38 foreach ($tokens as $name => $original) {
40 // Basic user account information.
41 case 'piwik-role-names':
42 $names = implode(',', $account->roles);
43 $replacements[$original] = $sanitize ? check_plain($names) : $names;
46 case 'piwik-role-ids':
47 $ids = implode(',', array_keys($account->roles));
48 $replacements[$original] = $sanitize ? check_plain($ids) : $ids;