True, 'process_array' => True ); var $xml_functions = array(); var $xmlrpc_methods = array(); var $soap_functions = array( 'read' => array( 'in' => array('int','int','struct','string','int'), 'out' => array('array') ), 'process_array' => array( 'in' => array('int','struct'), 'out' => array('array') ), 'list_methods' => array( 'in' => array('string'), 'out' => array('struct') ) ); function bosettings($appname='') { $this->xmlrpc = @is_object($GLOBALS['server']) && $GLOBALS['server']->last_method; $this->session_data = $GLOBALS['egw']->session->appsession('session_data','preferences'); $this->appname = $appname; } function save_session($appname,$type,$show_help,$prefix,$notifies='',$referer='') { $GLOBALS['egw']->session->appsession('session_data','preferences',array( 'type' => $type, // save our state in the app-session 'show_help' => $show_help, 'prefix' => $prefix, 'appname' => $appname, // we use this to reset prefix on appname-change 'notifies' => $notifies, 'referer' => $referer ? $referer : $this->session_data['referer'], )); } function call_hook($appname) { $this->appname = $appname; $GLOBALS['egw']->translation->add_app($this->appname); if($this->appname != 'preferences') { $GLOBALS['egw']->translation->add_app('preferences'); // we need the prefs translations too } if(!$GLOBALS['egw']->hooks->single('settings',$this->appname)) { return False; } $this->settings = array_merge($this->settings,$GLOBALS['settings']); /* Remove ui-only settings */ if($this->xmlrpc) { foreach($this->settings as $key => $valarray) { if(!$valarray['xmlrpc']) { unset($this->settings[$key]); } } } else { /* Here we include the settings hook file for the current template, if it exists. This is not handled by the hooks class and is only valid if not using xml-rpc. */ $tmpl_settings = EGW_TEMPLATE_DIR . '/hook_settings.inc.php'; if($this->appname == 'preferences' && file_exists($tmpl_settings)) { include($tmpl_settings); $this->settings = array_merge($this->settings,$GLOBALS['settings']); } } if($this->debug) { // _debug_array($this->settings); } return True; } function read($app,$prefix='',$type='user') { switch($type) // set up some class vars to be used when processing the hooks { case 'forced': $this->prefs = &$GLOBALS['egw']->preferences->forced[$this->check_app()]; break; case 'default': $this->prefs = &$GLOBALS['egw']->preferences->default[$this->check_app()]; break; default: $this->prefs = &$GLOBALS['egw']->preferences->user[$this->check_app()]; // use prefix if given in the url, used for email extra-accounts if($prefix != '') { $prefix_arr = explode('/',$prefix); foreach($prefix_arr as $pre) { $this->prefs = &$this->prefs[$pre]; } } } if($this->debug) { echo 'Preferences array:' . "\n"; _debug_array($this->prefs); } /* Ensure that a struct will be returned via xml-rpc (this might change) */ if($this->xmlrpc) { return $this->prefs; } else { return False; } } function _write($appname,$prefix,$type='user') { } function process_array(&$repository,$array,$notifies,$type,$prefix='') { //_debug_array($repository); $appname = $this->check_app(); $prefs = &$repository[$appname]; if($prefix != '') { $prefix_arr = explode('/',$prefix); foreach($prefix_arr as $pre) { $prefs = &$prefs[$pre]; } } unset($prefs['']); //_debug_array($array);exit; while(is_array($array) && list($var,$value) = each($array)) { if(isset($value) && $value != '' && $value != '**NULL**') { if(is_array($value)) { $value = $value['pw']; if(empty($value)) { continue; // dont write empty password-fields } } $prefs[$var] = get_magic_quotes_gpc() ? stripslashes($value) : $value; if($notifies[$var]) // need to translate the key-words back { $prefs[$var] = $GLOBALS['egw']->preferences->lang_notify($prefs[$var],$notifies[$var],True); } } else { unset($prefs[$var]); } } //echo "prefix='$prefix', prefs=
"; print_r($repository[$_appname]); echo "
\n"; // the following hook can be used to verify the prefs // if you return something else than False, it is treated as an error-msg and // displayed to the user (the prefs are not saved) // if($error = $GLOBALS['egw']->hooks->single(array( 'location' => 'verify_settings', 'prefs' => $repository[$appname], 'prefix' => $prefix, 'type' => $type ), $appname )) { return $error; } $GLOBALS['egw']->preferences->save_repository(True,$type); return $this->prefs; } function check_app() { if($this->appname == 'preferences') { return 'common'; } else { return $this->appname; } } /* TODO these need work and may change without notice. Please remove this line when this is settled. */ function list_methods($_type='xmlrpc') { /* This handles introspection or discovery by the logged in client, in which case the input might be an array. The server always calls this function to fill the server dispatch map using a string. */ if(is_array($_type)) { $_type = $_type['type'] ? $_type['type'] : $_type[0]; } switch($_type) { case 'xmlrpc': $xml_functions = array( 'read' => array( 'function' => 'read', 'signature' => array(array(xmlrpcStruct,xmlrpcString,xmlrpcString,xmlrpcString)), 'docstring' => lang('Read prefs for the specified application.') ), 'write' => array( 'function' => 'process_array', 'signature' => array(array(xmlrpcStruct,xmlrpcStruct,xmlrpcStruct,xmlrpcStruct,xmlrpcString,xmlrpcString)), 'docstring' => lang('Write prefs for the specified application.') ), 'list_methods' => array( 'function' => 'list_methods', 'signature' => array(array(xmlrpcStruct,xmlrpcString)), 'docstring' => lang('Read this list of methods.') ) ); return $xml_functions; break; case 'soap': return $this->soap_functions; break; default: return array(); break; } } }