user_role_field.module in User role field 7
File
user_role_field.module
View source
<?php
function user_role_field_form_alter(&$form, $form_state, $form_id) {
if (isset($form['instance']) && ($form['instance']['entity_type']['#value'] == 'user' || $form['instance']['entity_type']['#value'] == 'profile2') && $form_id == 'field_ui_field_edit_form' && isset($form['field'])) {
module_load_include('inc', 'user_role_field', 'user_role_field.admin');
return _user_role_field_field_settings_form_alter($form, $form_state, $form_id);
}
}
function user_role_field_permission() {
return array(
'administer user field roles' => array(
'title' => t('Administer user field roles'),
'description' => t('Manage user field roles.'),
),
);
}
function _user_role_field_roles($field) {
return isset($field['settings']['user_role_field']) && is_array($field['settings']['user_role_field']) ? array_filter($field['settings']['user_role_field']) : array();
}
function user_role_field_field_access($op, $field, $obj_type, $object, $account) {
if ($obj_type != 'user' && $obj_type != 'profile2') {
return true;
}
if (arg(2) == 'create' && arg(0) == 'admin' && user_access('administer permissions')) {
return true;
}
if ($obj_type == 'profile2' && !empty($object->uid)) {
$object = user_load($object->uid);
}
$roles = _user_role_field_roles($field);
if (empty($roles)) {
return true;
}
if (!isset($object->roles)) {
return true;
}
$matching_roles = array_intersect_key($object->roles, $roles);
return !empty($matching_roles);
}