diff options
author | Andrew Thompson <andrew@clonedev.co.nz> | 2012-01-26 19:55:40 +1300 |
---|---|---|
committer | Andrew Thompson <andrew@clonedev.co.nz> | 2012-01-26 19:55:40 +1300 |
commit | 202901f628b6feb3c106630f87db42876752221d (patch) | |
tree | ed3af7678bff70c3783c954849a10d0713f35fdc /config | |
parent | a5cc204fcc3ad150083c6b2b78faaf805adc7cfe (diff) | |
download | pfsense-packages-202901f628b6feb3c106630f87db42876752221d.tar.gz pfsense-packages-202901f628b6feb3c106630f87db42876752221d.tar.bz2 pfsense-packages-202901f628b6feb3c106630f87db42876752221d.zip |
provide upgrade from old haproxy
Diffstat (limited to 'config')
-rw-r--r-- | config/haproxy-dev/haproxy.inc | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/config/haproxy-dev/haproxy.inc b/config/haproxy-dev/haproxy.inc index d9d3923a..72d9535d 100644 --- a/config/haproxy-dev/haproxy.inc +++ b/config/haproxy-dev/haproxy.inc @@ -156,6 +156,52 @@ EOD; fclose($fd); exec("/etc/rc.d/devd restart"); + /* Do XML upgrade from haproxy 0.31 to haproxy-dev */ + if (is_array($config['installedpackages']['haproxy']['ha_servers'])) { + /* We have an old config */ + $config['installedpackages']['haproxy']['ha_pools']['item'] = array(); + $a_global = &$config['installedpackages']['haproxy']; + $a_backends = &$config['installedpackages']['haproxy']['ha_backends']['item']; + $a_oldservers = &$config['installedpackages']['haproxy']['ha_servers']['item']; + $a_pools = &$config['installedpackages']['haproxy']['ha_pools']['item']; + + foreach ($a_backends as $id => $be) { + $a_backends[$id]['status'] = 'active'; + } + $id = 0; + foreach ($a_oldservers as $oldserver) { + $pool=$oldserver; + /* make server sub array */ + $server=array(); + $server['name'] = $oldserver['name']; + $server['address'] = $oldserver['address']; + $server['port'] = $oldserver['port']; + $server['weight'] = $oldserver['weight']; + $a_servers=array(); + $a_servers[]=$server; + /* set new pool */ + $pool['name'] = "pool$id"; + $id++; + $pool['ha_servers']['item']=$a_servers; + /* link to frontend */ + foreach ($a_backends as $id => $be) { + if ($a_backends[$id]['name'] == $oldserver['backend']) { + $a_backends[$id]['pool'] = $pool['name']; + $pool['monitor_uri'] = $be['monitor_uri']; + unset($a_backends[$id]['monitor_uri']); + break; + } + } + unset($pool['backend']); + unset($pool['address']); + unset($pool['port']); + unset($pool['weight']); + $a_pools[] = $pool; + } + unset($config['installedpackages']['haproxy']['ha_servers']); + write_config(); + } + conf_mount_ro(); exec("/usr/local/etc/rc.d/haproxy.sh start"); |