aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGravatar Ethan Galstad <egalstad@users.sourceforge.net> 2003-02-16 02:46:40 +0000
committerGravatar Ethan Galstad <egalstad@users.sourceforge.net> 2003-02-16 02:46:40 +0000
commit33139519aaac2a964975c6da5c4efa3fde6f8585 (patch)
tree98a36b4537ec07447d536331e3f4ad194a851a82
parent983b1edec4399c7bb473785567bbeb7d338d705b (diff)
downloadmonitoring-plugins-33139519aaac2a964975c6da5c4efa3fde6f8585.tar.gz
Interface patch byor Clemens Resen
git-svn-id: https://nagiosplug.svn.sourceforge.net/svnroot/nagiosplug/nagiosplug/trunk@326 f882894a-f735-0410-b71e-b25c423dba1c
-rw-r--r--contrib/check_dhcp.c8
1 files changed, 8 insertions, 0 deletions
diff --git a/contrib/check_dhcp.c b/contrib/check_dhcp.c
index 24b82f98..2aea579d 100644
--- a/contrib/check_dhcp.c
+++ b/contrib/check_dhcp.c
@@ -515,6 +515,7 @@ int receive_dhcp_packet(void *buffer, int buffer_size, int sock, int timeout, st
/* creates a socket for DHCP communication */
int create_dhcp_socket(void){
struct sockaddr_in myname;
+ struct ifreq interface;
int sock;
int flag=1;
@@ -549,6 +550,13 @@ int create_dhcp_socket(void){
exit(STATE_UNKNOWN);
}
+ /* bind socket to interface */
+ strncpy(interface.ifr_ifrn.ifrn_name,network_interface_name,IFNAMSIZ);
+ if(setsockopt(sock,SOL_SOCKET,SO_BINDTODEVICE,(char *)&interface,sizeof(interface))<0){
+ printf("Error: Could not bind socket to interface %s. Check your privileges...\n",network_interface_name);
+ exit(STATE_UNKNOWN);
+ }
+
/* bind the socket */
if(bind(sock,(struct sockaddr *)&myname,sizeof(myname))<0){
printf("Error: Could not bind to DHCP socket (port %d)! Check your privileges...\n",DHCP_CLIENT_PORT);