summaryrefslogtreecommitdiffstats
path: root/usr/local/www/xmlrpc.php
diff options
context:
space:
mode:
authorScott Ullrich <sullrich@pfsense.org>2011-05-31 14:28:13 -0400
committerScott Ullrich <sullrich@pfsense.org>2011-05-31 14:28:13 -0400
commit0b581a8acf9fa470e66afebc1834660d0ee81942 (patch)
tree106a5574013fe8d5ef706020b6892d47793ec48b /usr/local/www/xmlrpc.php
parent456026b5425b64cba3d4632712c63a0c661a5e27 (diff)
downloadpfsense-0b581a8acf9fa470e66afebc1834660d0ee81942.zip
pfsense-0b581a8acf9fa470e66afebc1834660d0ee81942.tar.gz
Use array_extend
Diffstat (limited to 'usr/local/www/xmlrpc.php')
-rwxr-xr-xusr/local/www/xmlrpc.php17
1 files changed, 16 insertions, 1 deletions
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;
+}
+
?>
OpenPOWER on IntegriCloud