diff options
author | jim-p <jimp@pfsense.org> | 2011-06-29 16:06:42 -0400 |
---|---|---|
committer | jim-p <jimp@pfsense.org> | 2011-06-29 16:06:42 -0400 |
commit | d368b334584bfaf68d33fad6be885440b513b28e (patch) | |
tree | ae5dd17ec4312afdfa712335249a25e544272f30 /etc/inc/interfaces.inc | |
parent | 8ee623f3a98dca5681274d6a14450223236b4013 (diff) | |
download | pfsense-d368b334584bfaf68d33fad6be885440b513b28e.zip pfsense-d368b334584bfaf68d33fad6be885440b513b28e.tar.gz |
Move interfaces_staticarp_configure() to interfaces.inc where it really belongs.
Diffstat (limited to 'etc/inc/interfaces.inc')
-rw-r--r-- | etc/inc/interfaces.inc | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/etc/inc/interfaces.inc b/etc/inc/interfaces.inc index 4a3498b..5abea03 100644 --- a/etc/inc/interfaces.inc +++ b/etc/inc/interfaces.inc @@ -3772,4 +3772,36 @@ function get_vip_descr($ipaddress) { return ""; } +function interfaces_staticarp_configure($if) { + global $config, $g; + if(isset($config['system']['developerspew'])) { + $mt = microtime(); + echo "interfaces_staticarp_configure($if) being called $mt\n"; + } + + $ifcfg = $config['interfaces'][$if]; + + if (empty($if) || empty($ifcfg['if'])) + return 0; + + /* Enable staticarp, if enabled */ + if(isset($config['dhcpd'][$if]['staticarp'])) { + mwexec("/sbin/ifconfig " . escapeshellarg($ifcfg['if']) . " staticarp " ); + mwexec("/usr/sbin/arp -d -i " . escapeshellarg($ifcfg['if']) . " -a > /dev/null 2>&1 "); + if (is_array($config['dhcpd'][$if]['staticmap'])) { + + foreach ($config['dhcpd'][$if]['staticmap'] as $arpent) { + mwexec("/usr/sbin/arp -s " . escapeshellarg($arpent['ipaddr']) . " " . escapeshellarg($arpent['mac'])); + + } + + } + } else { + mwexec("/sbin/ifconfig " . escapeshellarg($ifcfg['if']) . " -staticarp " ); + mwexec("/usr/sbin/arp -d -i " . escapeshellarg($ifcfg['if']) . " -a > /dev/null 2>&1 "); + } + + return 0; +} + ?> |