function mobile_tools_get_active_device_group in Mobile Tools 7.3
Same name and namespace in other branches
- 7.2 mobile_tools.module \mobile_tools_get_active_device_group()
Get the active device group.
Parameters
object $modifier [optional]: PURL modifier
boolean $clear [optional]: Flush cache
Return value
object Returns the active device group object, FALSE otherwise.
5 calls to mobile_tools_get_active_device_group()
- mobile_tools_activate_device_group in ./
mobile_tools.module - Initialize the device group
- mobile_tools_context_device_group_access_check in mobile_tools_context/
plugins/ access/ is_device_group.inc - Check for access.
- mobile_tools_context_init in mobile_tools_context/
mobile_tools_context.module - Implements hook_init().
- mobile_tools_httpheaders_context_http_header_build in mobile_tools_httpheaders/
mobile_tools_httpheaders.module - Implements hook_context_http_header_build().
- mobile_tools_init in ./
mobile_tools.module - Implements hook_init().
File
- ./
mobile_tools.module, line 666 - Functionality to ease the creation of mixed device environments.
Code
function mobile_tools_get_active_device_group($modifier = NULL, $clear = FALSE) {
// @todo add logic to use the given modifier instead of scanning all of
// them
$device_group =& drupal_static(__FUNCTION__);
if (!isset($device_group) or $clear) {
$device_group = FALSE;
// Check the active modifiers
$active = purl_active();
$active = _mobile_tools_get_active_purl_modifiers($active
->get());
if (!empty($active)) {
foreach ($active as $key => $object) {
$device_group = mobile_tools_device_group_load($object->id);
if (is_object($device_group)) {
// @todo add extra check to see if it's the right provider
// Only one device group can be active at a time.
// So if we get a loaded device group, just return it.
return $device_group;
}
}
}
}
return $device_group;
}