From 0b581a8acf9fa470e66afebc1834660d0ee81942 Mon Sep 17 00:00:00 2001 From: Scott Ullrich Date: Tue, 31 May 2011 14:28:13 -0400 Subject: Use array_extend --- usr/local/www/xmlrpc.php | 17 ++++++++++++++++- 1 file changed, 16 insertions(+), 1 deletion(-) (limited to 'usr/local/www/xmlrpc.php') diff --git a/usr/local/www/xmlrpc.php b/usr/local/www/xmlrpc.php index c534b43..c869137 100755 --- a/usr/local/www/xmlrpc.php +++ b/usr/local/www/xmlrpc.php @@ -274,7 +274,7 @@ function merge_config_section_xmlrpc($raw_params) { $params = xmlrpc_params_to_php($raw_params); if(!xmlrpc_auth($params)) return $xmlrpc_g['return']['authfail']; - $config_new = array_merge($config, $params[0]); + $config_new = array_extend($config, $params[0]); $config = $config_new; $mergedkeys = implode(",", array_keys($params[0])); write_config(sprintf(gettext("Merged in config (%s sections) from XMLRPC client."), $mergedkeys)); @@ -454,4 +454,19 @@ $server = new XML_RPC_Server( unlock($xmlrpclockkey); +function array_extend($a, $b) { + foreach($b as $k=>$v) { + if( is_array($v) ) { + if( !isset($a[$k]) ) { + $a[$k] = $v; + } else { + $a[$k] = array_extend($a[$k], $v); + } + } else { + $a[$k] = $v; + } + } + return $a; +} + ?> -- cgit v1.1