* @copyright (c) 2010-16 by Ralf Becker * @version $Id$ */ namespace EGroupware\Api\CalDAV; use EGroupware\Api; /** * GroupDAV hooks: eg. preferences */ class Hooks { public $public_functions = array( 'log' => true, ); /** * Show GroupDAV preferences link in preferences * * @param string|array $args */ public static function menus($args) { $appname = 'groupdav'; $location = is_array($args) ? $args['location'] : $args; if ($location == 'preferences') { $file = array( 'Preferences' => Api\Framework::link('/index.php','menuaction=preferences.preference_settings.index&appname='.$appname), ); if ($location == 'preferences') { display_section($appname,$file); } else { display_sidebox($appname,lang('Preferences'),$file); } } } /** * populates $settings for the preferences * * @param array|string $hook_data * @return array */ static function settings($hook_data) { $settings = array(); if ($hook_data['setup']) { $apps = array('addressbook','calendar','infolog'); } else { $apps = array_keys($GLOBALS['egw_info']['user']['apps']); } foreach($apps as $app) { $class_name = $app.'_groupdav'; if (class_exists($class_name, true)) { $settings[] = array( 'type' => 'section', 'title' => $app, ); $settings += call_user_func(array($class_name,'get_settings'), $hook_data); } } $settings[] = array( 'type' => 'section', 'title' => 'Logging / debuging', ); $settings['debug_level'] = array( 'type' => 'select', 'label' => 'Enable logging', 'name' => 'debug_level', 'help' => 'Enables logging of CalDAV/CardDAV traffic to diagnose problems with devices.', 'values' => array( '0' => lang('Off'), 'r' => lang('Requests and truncated responses to Apache error-log'), 'f' => lang('Requests and full responses to files directory'), ), 'xmlrpc' => true, 'admin' => false, 'default' => '0', ); if ($GLOBALS['type'] === 'forced' || $GLOBALS['type'] === 'user' && $GLOBALS['egw_info']['user']['preferences']['groupdav']['debug-log'] !== 'never') { if ($GLOBALS['type'] === 'user') { $logs = array(); $relativ_log_dir = 'groupdav/'.Api\CalDAV::sanitize_filename(Api\Accounts::id2name($hook_data['account_id'])); $log_dir = $GLOBALS['egw_info']['server']['files_dir'].'/'.$relativ_log_dir; if (file_exists($log_dir) && ($files = scandir($log_dir))) { foreach($files as $log) { if (substr($log, -4) == '.log') { $logs[$relativ_log_dir.'/'.$log] = Api\DateTime::to(filemtime($log_dir.'/'.$log)).': '. str_replace('!', '/', $log); } } } $link = Api\Framework::link('/index.php',array( 'menuaction' => 'api.'.__CLASS__.'.log', 'filename' => '', )); $onchange = "egw_openWindowCentered('$link'+encodeURIComponent(this.value), '_blank', 1000, 500); this.value=''"; } else // allow to force users to NOT be able to delete their profiles { $logs = array('never' => lang('Never')); } $settings['show-log'] = array( 'type' => 'select', 'label' => 'Show log of following device', 'name' => 'show-log', 'help' => lang('You need to set enable logging to "%1" to create/update a log.', lang('Requests and full responses to files directory')), 'values' => $logs, 'xmlrpc' => True, 'admin' => False, 'onchange' => $onchange, ); } return $settings; } /** * Open log window for log-file specified in GET parameter filename (relative to files_dir) * * $_GET['filename'] has to be in groupdav sub-dir of files_dir and start with account_lid of current user * * @throws Api\Exception\WrongParameter */ public static function log() { $filename = $_GET['filename']; $matches = null; if (!preg_match('|^groupdav/'.($GLOBALS['egw_info']['user']['apps']['admin'] ? '[^/]+/' : preg_quote(Api\CalDAV::sanitize_filename($GLOBALS['egw_info']['user']['account_lid']), '|')).'(.*)\.log$|', $filename, $matches)) { throw new Api\Exception\WrongParameter("Access denied to file '$filename'!"); } $GLOBALS['egw_info']['flags']['css'] = ' body { background-color: #e0e0e0; overflow: hidden; } pre.tail { background-color: white; padding-left: 5px; margin-left: 5px; } '; $tail = new Api\Json\Tail($filename); $GLOBALS['egw']->framework->render($tail->show(str_replace('!', '/', $matches[1])),false,false); } }