Add ldap patched bind and dhcp
git-svn-id: https://svn.disconnected-by-peer.at/svn/linamh/trunk/linamh@373 6952d904-891a-0410-993b-d76249ca496b
This commit is contained in:
		
							
								
								
									
										13
									
								
								net-misc/dhcp/files/dhcp-3.0-ddns-example.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								net-misc/dhcp/files/dhcp-3.0-ddns-example.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,13 @@ | ||||
| diff -ur a/server/dhcpd.conf b/server/dhcpd.conf | ||||
| --- a/server/dhcpd.conf	2001-01-25 08:33:11 +0000 | ||||
| +++ b/server/dhcpd.conf	2007-07-19 10:29:43 +0100 | ||||
| @@ -21,6 +21,9 @@ | ||||
|  # No service will be given on this subnet, but declaring it helps the  | ||||
|  # DHCP server to understand the network topology. | ||||
|   | ||||
| +# Disable dynamic DNS updates. | ||||
| +ddns-update-style none; | ||||
| + | ||||
|  subnet 10.152.187.0 netmask 255.255.255.0 { | ||||
|  } | ||||
|   | ||||
							
								
								
									
										15
									
								
								net-misc/dhcp/files/dhcp-3.0-fix-perms.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								net-misc/dhcp/files/dhcp-3.0-fix-perms.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,15 @@ | ||||
| --- server/dhcpd.c	2003-11-05 14:08:09.000000000 -0800 | ||||
| +++ server/dhcpd.c	2003-11-05 14:15:32.000000000 -0800 | ||||
| @@ -602,6 +602,12 @@ | ||||
|  	if (lftest) | ||||
|  		exit (0); | ||||
|   | ||||
| +#if defined (PARANOIA) | ||||
| +	/* Set proper permissions... */ | ||||
| +	if (lchown (path_dhcpd_db, set_uid, set_gid)) | ||||
| +		log_fatal ("lchown(%s, %d, %d): %m", path_dhcpd_db, (int) set_uid, (int) set_gid); | ||||
| +#endif /* PARANOIA */ | ||||
| + | ||||
|  	/* Discover all the network interfaces and initialize them. */ | ||||
|  	discover_interfaces (DISCOVER_SERVER); | ||||
|   | ||||
							
								
								
									
										207
									
								
								net-misc/dhcp/files/dhcp-3.0-paranoia.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										207
									
								
								net-misc/dhcp/files/dhcp-3.0-paranoia.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,207 @@ | ||||
|  | ||||
| paranoia (non-root/chroot) patch for ISC dhcp 3.0 | ||||
| file to patch: dhcp-3.0/server/dhcpd.c | ||||
|  | ||||
| update from paranoia patch for ISC dhcp 2.0 | ||||
|  | ||||
| Adds 3 options: | ||||
|  | ||||
| 	-user <user> | ||||
| 	-group <group> | ||||
| 	-chroot <chroot_dir> | ||||
|  | ||||
| Notes: | ||||
| 	-DPARANOIA must be passed as an argument to the --copts option | ||||
| 	of configure.  Otherwise, the paranoia code will not be compiled | ||||
| 	in.  Example:  ./configure --copts -DPARANOIA | ||||
|  | ||||
| 	The chroot() call has been delayed in order to allow /dev/log to | ||||
| 	be reopened after the configuration file has been read.  This is | ||||
| 	beneficial for systems on which /dev/log is a unix domain socket. | ||||
| 	The main side effect is that dhcpd.conf should be placed in /etc, | ||||
| 	instead of <chroot_dir>/etc. | ||||
|  | ||||
| 	If dhcpd is to be run on a sysV-style architecture (or, more | ||||
| 	generally, if /dev/log is a character device), one may opt to | ||||
| 	create the <chroot_dir>/dev/log character device and add | ||||
| 	-DEARLY_CHROOT to the --copts option of configure (in addition to | ||||
| 	-DPARANOIA).  This will perform the chroot() call at the earliest | ||||
| 	convenience (before reading the configuration file). | ||||
|  | ||||
| 	If the -user option is used, the lease and pid file directories | ||||
| 	should be writable to the server process after it drops | ||||
| 	privileges. | ||||
|  | ||||
|  | ||||
| ari edelkind (12/10/2001) | ||||
| last modified 12/10/2001 | ||||
|  | ||||
|  | ||||
| --- dhcp-3.0/server/dhcpd.c	Thu Jun 21 22:12:58 2001 | ||||
| +++ dhcp-3.0+paranoia/server/dhcpd.c	Wed Oct 17 08:23:00 2001 | ||||
| @@ -56,6 +56,16 @@ | ||||
|  #include "version.h" | ||||
|  #include <omapip/omapip_p.h> | ||||
|   | ||||
| +#if defined (PARANOIA) | ||||
| +#  include <sys/types.h> | ||||
| +#  include <unistd.h> | ||||
| +#  include <pwd.h> | ||||
| +/* get around the ISC declaration of group */ | ||||
| +#  define group real_group  | ||||
| +#    include <grp.h> | ||||
| +#  undef group | ||||
| +#endif /* PARANOIA */ | ||||
| + | ||||
|  static void usage PROTO ((void)); | ||||
|   | ||||
|  TIME cur_time; | ||||
| @@ -204,6 +214,22 @@ | ||||
|  	omapi_object_dereference (&listener, MDL); | ||||
|  } | ||||
|   | ||||
| +#if defined (PARANOIA) | ||||
| +/* to be used in one of two possible scenarios */ | ||||
| +static void setup_chroot (char *chroot_dir) { | ||||
| +	if (geteuid()) | ||||
| +		log_fatal ("you must be root to use chroot"); | ||||
| + | ||||
| +	if (chroot(chroot_dir)) { | ||||
| +		log_fatal ("chroot(\"%s\"): %m", chroot_dir); | ||||
| +	} | ||||
| +	if (chdir ("/")) { | ||||
| +		/* probably permission denied */ | ||||
| +		log_fatal ("chdir(\"/\"): %m"); | ||||
| +	} | ||||
| +} | ||||
| +#endif /* PARANOIA */ | ||||
| + | ||||
|  int main (argc, argv, envp) | ||||
|  	int argc; | ||||
|  	char **argv, **envp; | ||||
| @@ -236,6 +262,14 @@ | ||||
|  	char *traceinfile = (char *)0; | ||||
|  	char *traceoutfile = (char *)0; | ||||
|  #endif | ||||
| +#if defined (PARANOIA) | ||||
| +	char *set_user   = 0; | ||||
| +	char *set_group  = 0; | ||||
| +	char *set_chroot = 0; | ||||
| + | ||||
| +	uid_t set_uid = 0; | ||||
| +	gid_t set_gid = 0; | ||||
| +#endif /* PARANOIA */ | ||||
|   | ||||
|  	/* Make sure we have stdin, stdout and stderr. */ | ||||
|  	status = open ("/dev/null", O_RDWR); | ||||
| @@ -298,6 +332,20 @@ | ||||
|  			if (++i == argc) | ||||
|  				usage (); | ||||
|  			server = argv [i]; | ||||
| +#if defined (PARANOIA) | ||||
| +		} else if (!strcmp (argv [i], "-user")) { | ||||
| +			if (++i == argc) | ||||
| +				usage (); | ||||
| +			set_user = argv [i]; | ||||
| +		} else if (!strcmp (argv [i], "-group")) { | ||||
| +			if (++i == argc) | ||||
| +				usage (); | ||||
| +			set_group = argv [i]; | ||||
| +		} else if (!strcmp (argv [i], "-chroot")) { | ||||
| +			if (++i == argc) | ||||
| +				usage (); | ||||
| +			set_chroot = argv [i]; | ||||
| +#endif /* PARANOIA */ | ||||
|  		} else if (!strcmp (argv [i], "-cf")) { | ||||
|  			if (++i == argc) | ||||
|  				usage (); | ||||
| @@ -397,6 +445,44 @@ | ||||
|  					     trace_seed_stop, MDL); | ||||
|  #endif | ||||
|   | ||||
| +#if defined (PARANOIA) | ||||
| +	/* get user and group info if those options were given */ | ||||
| +	if (set_user) { | ||||
| +		struct passwd *tmp_pwd; | ||||
| + | ||||
| +		if (geteuid()) | ||||
| +			log_fatal ("you must be root to set user"); | ||||
| + | ||||
| +		if (!(tmp_pwd = getpwnam(set_user))) | ||||
| +			log_fatal ("no such user: %s", set_user); | ||||
| + | ||||
| +		set_uid = tmp_pwd->pw_uid; | ||||
| + | ||||
| +		/* use the user's group as the default gid */ | ||||
| +		if (!set_group) | ||||
| +			set_gid = tmp_pwd->pw_gid; | ||||
| +	} | ||||
| + | ||||
| +	if (set_group) { | ||||
| +/* get around the ISC declaration of group */ | ||||
| +#define group real_group | ||||
| +		struct group *tmp_grp; | ||||
| + | ||||
| +		if (geteuid()) | ||||
| +			log_fatal ("you must be root to set group"); | ||||
| + | ||||
| +		if (!(tmp_grp = getgrnam(set_group))) | ||||
| +			log_fatal ("no such group: %s", set_group); | ||||
| + | ||||
| +		set_gid = tmp_grp->gr_gid; | ||||
| +#undef group | ||||
| +	} | ||||
| + | ||||
| +#  if defined (EARLY_CHROOT) | ||||
| +	if (set_chroot) setup_chroot (set_chroot); | ||||
| +#  endif /* EARLY_CHROOT */ | ||||
| +#endif /* PARANOIA */ | ||||
| + | ||||
|  	/* Default to the DHCP/BOOTP port. */ | ||||
|  	if (!local_port) | ||||
|  	{ | ||||
| @@ -500,6 +586,10 @@ | ||||
|   | ||||
|  	postconf_initialization (quiet); | ||||
|   | ||||
| +#if defined (PARANOIA) && !defined (EARLY_CHROOT) | ||||
| +	if (set_chroot) setup_chroot (set_chroot); | ||||
| +#endif /* PARANOIA && !EARLY_CHROOT */ | ||||
| + | ||||
|          /* test option should cause an early exit */ | ||||
|   	if (cftest && !lftest)  | ||||
|   		exit(0); | ||||
| @@ -543,6 +633,22 @@ | ||||
|  			exit (0); | ||||
|  	} | ||||
|   | ||||
| +#if defined (PARANOIA) | ||||
| +	/* change uid to the specified one */ | ||||
| + | ||||
| +	if (set_gid) { | ||||
| +		if (setgroups (0, (void *)0)) | ||||
| +			log_fatal ("setgroups: %m"); | ||||
| +		if (setgid (set_gid)) | ||||
| +			log_fatal ("setgid(%d): %m", (int) set_gid); | ||||
| +	}	 | ||||
| + | ||||
| +	if (set_uid) { | ||||
| +		if (setuid (set_uid)) | ||||
| +			log_fatal ("setuid(%d): %m", (int) set_uid); | ||||
| +	} | ||||
| +#endif /* PARANOIA */ | ||||
| + | ||||
|  	/* Read previous pid file. */ | ||||
|  	if ((i = open (path_dhcpd_pid, O_RDONLY)) >= 0) { | ||||
|  		status = read (i, pbuf, (sizeof pbuf) - 1); | ||||
| @@ -888,6 +994,10 @@ | ||||
|   | ||||
|  	log_fatal ("Usage: dhcpd [-p <UDP port #>] [-d] [-f]%s%s%s%s", | ||||
|  		   "\n             [-cf config-file] [-lf lease-file]", | ||||
| +#if defined (PARANOIA) | ||||
| +		   /* meld into the following string */ | ||||
| +		   "\n             [-user user] [-group group] [-chroot dir]" | ||||
| +#endif /* PARANOIA */ | ||||
|  #if defined (TRACING) | ||||
|  		   "\n		   [-tf trace-output-file]", | ||||
|  		   "\n		   [-play trace-input-file]", | ||||
							
								
								
									
										66
									
								
								net-misc/dhcp/files/dhcp-3.0.2-gmake.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										66
									
								
								net-misc/dhcp/files/dhcp-3.0.2-gmake.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,66 @@ | ||||
| Index: dhcp-3.0.2/Makefile | ||||
| =================================================================== | ||||
| --- dhcp-3.0.2.orig/Makefile | ||||
| +++ dhcp-3.0.2/Makefile | ||||
| @@ -33,7 +33,7 @@ all: | ||||
|  	 if [ ! -d work.$$sysname ]; then \ | ||||
|  	   echo No build directory for $$sysname - please run ./configure.; \ | ||||
|  	else \ | ||||
| -	   (cd work.$$sysname; make all); \ | ||||
| +	   (cd work.$$sysname; $(MAKE) all); \ | ||||
|  	fi | ||||
|   | ||||
|  install: | ||||
| @@ -41,7 +41,7 @@ install: | ||||
|  	 if [ ! -d work.$$sysname ]; then \ | ||||
|  	   echo No build directory for $$sysname - please run ./configure.; \ | ||||
|  	else \ | ||||
| -	   (cd work.$$sysname; make install); \ | ||||
| +	   (cd work.$$sysname; $(MAKE) install); \ | ||||
|  	fi | ||||
|   | ||||
|  depend: | ||||
| @@ -49,7 +49,7 @@ depend: | ||||
|  	 if [ ! -d work.$$sysname ]; then \ | ||||
|  	   echo No build directory for $$sysname - please run ./configure.; \ | ||||
|  	else \ | ||||
| -	   (cd work.$$sysname; make depend); \ | ||||
| +	   (cd work.$$sysname; $(MAKE) depend); \ | ||||
|  	fi | ||||
|   | ||||
|  clean: | ||||
| @@ -57,7 +57,7 @@ clean: | ||||
|  	 if [ ! -d work.$$sysname ]; then \ | ||||
|  	   echo No build directory for $$sysname - please run ./configure.; \ | ||||
|  	else \ | ||||
| -	   (cd work.$$sysname; make clean); \ | ||||
| +	   (cd work.$$sysname; $(MAKE) clean); \ | ||||
|  	fi | ||||
|   | ||||
|  realclean: | ||||
| @@ -65,7 +65,7 @@ realclean: | ||||
|  	 if [ ! -d work.$$sysname ]; then \ | ||||
|  	   echo No build directory for $$sysname - please run ./configure.; \ | ||||
|  	else \ | ||||
| -	   (cd work.$$sysname; make realclean); \ | ||||
| +	   (cd work.$$sysname; $(MAKE) realclean); \ | ||||
|  	fi | ||||
|   | ||||
|  distclean: | ||||
| @@ -73,7 +73,7 @@ distclean: | ||||
|  	 if [ ! -d work.$$sysname ]; then \ | ||||
|  	   echo No build directory for $$sysname - please run ./configure.; \ | ||||
|  	else \ | ||||
| -	   (cd work.$$sysname; make distclean); \ | ||||
| +	   (cd work.$$sysname; $(MAKE) distclean); \ | ||||
|  	fi | ||||
|   | ||||
|  links: | ||||
| @@ -81,6 +81,6 @@ links: | ||||
|  	 if [ ! -d work.$$sysname ]; then \ | ||||
|  	   echo No build directory for $$sysname - please run ./configure.; \ | ||||
|  	else \ | ||||
| -	   (cd work.$$sysname; make links); \ | ||||
| +	   (cd work.$$sysname; $(MAKE) links); \ | ||||
|  	fi | ||||
|   | ||||
							
								
								
									
										84
									
								
								net-misc/dhcp/files/dhcp-3.0.3-dhclient-dbus.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										84
									
								
								net-misc/dhcp/files/dhcp-3.0.3-dhclient-dbus.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,84 @@ | ||||
| --- client/scripts/bsdos | ||||
| +++ client/scripts/bsdos | ||||
| @@ -47,6 +47,11 @@ | ||||
|      . /etc/dhcp/dhclient-exit-hooks | ||||
|    fi | ||||
|  # probably should do something with exit status of the local script | ||||
| +  if [ x$dhc_dbus != x -a $exit_status -eq 0 ]; then | ||||
| +    dbus-send --system --dest=com.redhat.dhcp \ | ||||
| +      --type=method_call /com/redhat/dhcp/$interface com.redhat.dhcp.set \ | ||||
| +      'string:'"`env | grep -Ev '^(PATH|SHLVL|_|PWD|dhc_dbus)\='`" | ||||
| +  fi | ||||
|    exit $exit_status | ||||
|  } | ||||
|   | ||||
| --- client/scripts/freebsd | ||||
| +++ client/scripts/freebsd | ||||
| @@ -57,6 +57,11 @@ | ||||
|      . /etc/dhcp/dhclient-exit-hooks | ||||
|    fi | ||||
|  # probably should do something with exit status of the local script | ||||
| +  if [ x$dhc_dbus != x -a $exit_status -eq 0 ]; then | ||||
| +    dbus-send --system --dest=com.redhat.dhcp \ | ||||
| +      --type=method_call /com/redhat/dhcp/$interface com.redhat.dhcp.set \ | ||||
| +      'string:'"`env | grep -Ev '^(PATH|SHLVL|_|PWD|dhc_dbus)\='`" | ||||
| +  fi | ||||
|    exit $exit_status | ||||
|  } | ||||
|   | ||||
| --- client/scripts/linux | ||||
| +++ client/scripts/linux | ||||
| @@ -69,6 +69,11 @@ | ||||
|      . /etc/dhcp/dhclient-exit-hooks | ||||
|    fi | ||||
|  # probably should do something with exit status of the local script | ||||
| +  if [ x$dhc_dbus != x -a $exit_status -eq 0 ]; then | ||||
| +    dbus-send --system --dest=com.redhat.dhcp \ | ||||
| +      --type=method_call /com/redhat/dhcp/$interface com.redhat.dhcp.set \ | ||||
| +      'string:'"`env | grep -Ev '^(PATH|SHLVL|_|PWD|dhc_dbus)\='`" | ||||
| +  fi | ||||
|    exit $exit_status | ||||
|  } | ||||
|   | ||||
| --- client/scripts/netbsd | ||||
| +++ client/scripts/netbsd | ||||
| @@ -47,6 +47,11 @@ | ||||
|      . /etc/dhcp/dhclient-exit-hooks | ||||
|    fi | ||||
|  # probably should do something with exit status of the local script | ||||
| +  if [ x$dhc_dbus != x -a $exit_status -eq 0 ]; then | ||||
| +    dbus-send --system --dest=com.redhat.dhcp \ | ||||
| +      --type=method_call /com/redhat/dhcp/$interface com.redhat.dhcp.set \ | ||||
| +      'string:'"`env | grep -Ev '^(PATH|SHLVL|_|PWD|dhc_dbus)\='`" | ||||
| +  fi | ||||
|    exit $exit_status | ||||
|  } | ||||
|   | ||||
| --- client/scripts/openbsd | ||||
| +++ client/scripts/openbsd | ||||
| @@ -47,6 +47,11 @@ | ||||
|      . /etc/dhcp/dhclient-exit-hooks | ||||
|    fi | ||||
|  # probably should do something with exit status of the local script | ||||
| +  if [ x$dhc_dbus != x -a $exit_status -eq 0 ]; then | ||||
| +    dbus-send --system --dest=com.redhat.dhcp \ | ||||
| +      --type=method_call /com/redhat/dhcp/$interface com.redhat.dhcp.set \ | ||||
| +      'string:'"`env | grep -Ev '^(PATH|SHLVL|_|PWD|dhc_dbus)\='`" | ||||
| +  fi | ||||
|    exit $exit_status | ||||
|  } | ||||
|   | ||||
| --- client/scripts/solaris | ||||
| +++ client/scripts/solaris | ||||
| @@ -47,6 +47,11 @@ | ||||
|      . /etc/dhcp/dhclient-exit-hooks | ||||
|    fi | ||||
|  # probably should do something with exit status of the local script | ||||
| +  if [ x$dhc_dbus != x -a $exit_status -eq 0 ]; then | ||||
| +    dbus-send --system --dest=com.redhat.dhcp \ | ||||
| +      --type=method_call /com/redhat/dhcp/$interface com.redhat.dhcp.set \ | ||||
| +      'string:'"`env | grep -Ev '^(PATH|SHLVL|_|PWD|dhc_dbus)\='`" | ||||
| +  fi | ||||
|    exit $exit_status | ||||
|  } | ||||
|   | ||||
							
								
								
									
										16
									
								
								net-misc/dhcp/files/dhcp-3.0.3-dhclient-hostname.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								net-misc/dhcp/files/dhcp-3.0.3-dhclient-hostname.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | ||||
| --- client/scripts/linux | ||||
| +++ client/scripts/linux | ||||
| @@ -138,10 +138,12 @@ | ||||
|     [ x$reason = xREBIND ] || [ x$reason = xREBOOT ]; then | ||||
|    current_hostname=`hostname` | ||||
|    if [ x$current_hostname = x ] || \ | ||||
| +     [ x$current_hostname = "x(none)" ] || \ | ||||
| +     [ x$current_hostname = xlocalhost ] || \ | ||||
|       [ x$current_hostname = x$old_host_name ]; then | ||||
|      if [ x$current_hostname = x ] || \ | ||||
|         [ x$new_host_name != x$old_host_name ]; then | ||||
| -      hostname $new_host_name | ||||
| +      hostname "$new_host_name" | ||||
|      fi | ||||
|    fi | ||||
|       | ||||
							
								
								
									
										200
									
								
								net-misc/dhcp/files/dhcp-3.0.3-dhclient-metric.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										200
									
								
								net-misc/dhcp/files/dhcp-3.0.3-dhclient-metric.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,200 @@ | ||||
| --- client/scripts/bsdos | ||||
| +++ client/scripts/bsdos | ||||
| @@ -84,6 +84,9 @@ | ||||
|  if [ x$new_interface_mtu != x ]; then | ||||
|    mtu_arg="mtu $new_interface_mtu" | ||||
|  fi | ||||
| +if [ x$IF_METRIC != x ]; then | ||||
| +  metric_arg="metric $IF_METRIC" | ||||
| +fi | ||||
|   | ||||
|  if [ x$reason = xMEDIUM ]; then | ||||
|    eval "ifconfig $interface $medium" | ||||
| @@ -141,7 +144,7 @@ | ||||
|    if [ x$old_ip_address = x ] || [ x$old_ip_address != x$new_ip_address ] || \ | ||||
|       [ x$reason = xBOUND ] || [ x$reason = xREBOOT ]; then | ||||
|      eval "ifconfig $interface inet $new_ip_address $new_netmask_arg \ | ||||
| -					$new_broadcast_arg $mtu_arg $medium" | ||||
| +			$new_broadcast_arg $mtu_arg $metric_arg $medium" | ||||
|      route add $new_ip_address 127.1 >/dev/null 2>&1 | ||||
|      for router in $new_routers; do | ||||
|        route add default $router >/dev/null 2>&1 | ||||
| @@ -198,7 +201,7 @@ | ||||
|      route delete $alias_ip_address 127.0.0.1 > /dev/null 2>&1 | ||||
|    fi | ||||
|    eval "ifconfig $interface inet $new_ip_address $new_netmask_arg \ | ||||
| -					$new_broadcast_arg $mtu_arg $medium" | ||||
| +			$new_broadcast_arg $mtu_arg $metric_arg $medium" | ||||
|    sleep 1 | ||||
|    if [ "$new_routers" != "" ]; then | ||||
|      set $new_routers | ||||
| --- client/scripts/freebsd | ||||
| +++ client/scripts/freebsd | ||||
| @@ -94,6 +94,9 @@ | ||||
|  if [ x$new_interface_mtu != x ]; then | ||||
|    mtu_arg="mtu $new_interface_mtu" | ||||
|  fi | ||||
| +if [ x$IF_METRIC != x ]; then | ||||
| +  metric_arg="metric $IF_METRIC" | ||||
| +fi | ||||
|   | ||||
|  if [ x$reason = xMEDIUM ]; then | ||||
|    eval "ifconfig $interface $medium" | ||||
| @@ -151,7 +154,7 @@ | ||||
|    if [ x$old_ip_address = x ] || [ x$old_ip_address != x$new_ip_address ] || \ | ||||
|       [ x$reason = xBOUND ] || [ x$reason = xREBOOT ]; then | ||||
|      eval "ifconfig $interface inet $new_ip_address $new_netmask_arg \ | ||||
| -					$new_broadcast_arg $mtu_arg $medium" | ||||
| +			$new_broadcast_arg $mtu_arg $metric_arg $medium" | ||||
|      $LOGGER "New IP Address ($interface): $new_ip_address" | ||||
|      $LOGGER "New Subnet Mask ($interface): $new_subnet_mask" | ||||
|      $LOGGER "New Broadcast Address ($interface): $new_broadcast_address" | ||||
| @@ -215,7 +218,7 @@ | ||||
|      route delete $alias_ip_address 127.0.0.1 > /dev/null 2>&1 | ||||
|    fi | ||||
|    eval "ifconfig $interface inet $new_ip_address $new_netmask_arg \ | ||||
| -					$new_broadcast_arg $mtu_arg $medium" | ||||
| +			$new_broadcast_arg $mtu_arg $metric_arg $medium" | ||||
|    $LOGGER "New IP Address ($interface): $new_ip_address" | ||||
|    $LOGGER "New Subnet Mask ($interface): $new_subnet_mask" | ||||
|    $LOGGER "New Broadcast Address ($interface): $new_broadcast_address" | ||||
| --- client/scripts/linux | ||||
| +++ client/scripts/linux | ||||
| @@ -83,11 +83,6 @@ | ||||
|    fi | ||||
|  fi | ||||
|   | ||||
| -release=`uname -r` | ||||
| -release=`expr $release : '\(.*\)\..*'` | ||||
| -relminor=`echo $release |sed -e 's/[0-9]*\.\([0-9][0-9]*\)\(\..*\)*$/\1/'` | ||||
| -relmajor=`echo $release |sed -e 's/\([0-9][0-9]*\)\..*$/\1/'` | ||||
| - | ||||
|  if [ x$new_broadcast_address != x ]; then | ||||
|    new_broadcast_arg="broadcast $new_broadcast_address" | ||||
|  fi | ||||
| @@ -106,6 +101,9 @@ | ||||
|  if [ x$new_interface_mtu != x ]; then | ||||
|    mtu_arg="mtu $new_interface_mtu" | ||||
|  fi | ||||
| +if [ x$IF_METRIC != x ]; then | ||||
| +  metric_arg="metric $IF_METRIC" | ||||
| +fi | ||||
|   | ||||
|  if [ x$reason = xMEDIUM ]; then | ||||
|    # Linux doesn't do mediums (ok, ok, media). | ||||
| @@ -117,15 +115,7 @@ | ||||
|      # Bring down alias interface. Its routes will disappear too. | ||||
|      ifconfig $interface:0- inet 0 | ||||
|    fi | ||||
| -  if [ $relmajor -lt 2 ] || ( [ $relmajor -eq 2 ] && [ $relminor -eq 0 ] ) | ||||
| -   then | ||||
| -    ifconfig $interface inet 0.0.0.0 netmask 0.0.0.0 \ | ||||
| -		broadcast 255.255.255.255 up | ||||
| -    # Add route to make broadcast work. Do not omit netmask. | ||||
| -    route add default dev $interface netmask 0.0.0.0 | ||||
| -  else | ||||
| -    ifconfig $interface 0 up | ||||
| -  fi | ||||
| +  ifconfig $interface 0 up | ||||
|   | ||||
|    # We need to give the kernel some time to get the interface up. | ||||
|    sleep 1 | ||||
| @@ -164,12 +154,14 @@ | ||||
|      ifconfig $interface inet $new_ip_address $new_subnet_arg \ | ||||
|  					$new_broadcast_arg $mtu_arg | ||||
|      # Add a network route to the computed network address. | ||||
| -    if [ $relmajor -lt 2 ] || \ | ||||
| -		( [ $relmajor -eq 2 ] && [ $relminor -eq 0 ] ); then | ||||
| -      route add -net $new_network_number $new_subnet_arg dev $interface | ||||
| +    if [ x$IF_METRIC != x ] && [ x$IF_METRIC != x0 ]; then | ||||
| +      route del -net $new_network_number $new_subnet_arg \ | ||||
| +        dev $interface | ||||
| +      route add -net $new_network_number $new_subnet_arg $metric_arg \ | ||||
| +      	dev $interface | ||||
|      fi | ||||
|      for router in $new_routers; do | ||||
| -      route add default gw $router | ||||
| +      route add default gw $router $metric_arg dev $interface | ||||
|      done | ||||
|    fi | ||||
|    if [ x$new_ip_address != x$alias_ip_address ] && [ x$alias_ip_address != x ]; | ||||
| @@ -213,12 +205,15 @@ | ||||
|        ifconfig $interface:0 inet $alias_ip_address $alias_subnet_arg | ||||
|        route add -host $alias_ip_address dev $interface:0 | ||||
|      fi | ||||
| -    if [ $relmajor -lt 2 ] || \ | ||||
| -		( [ $relmajor -eq 2 ] && [ $relminor -eq 0 ] ); then | ||||
| -      route add -net $new_network_number | ||||
| +    # Add a network route to the computed network address. | ||||
| +    if [ x$IF_METRIC != x ] && [ x$IF_METRIC != x0 ]; then | ||||
| +      route del -net $new_network_number $new_subnet_arg \ | ||||
| +        dev $interface | ||||
| +      route add -net $new_network_number $new_subnet_arg $metric_arg \ | ||||
| +      	dev $interface | ||||
|      fi | ||||
|      for router in $new_routers; do | ||||
| -      route add default gw $router | ||||
| +      route add default gw $router $metric_arg dev $interface | ||||
|      done | ||||
|      make_resolv_conf | ||||
|      exit_with_hooks 0 | ||||
| --- client/scripts/netbsd | ||||
| +++ client/scripts/netbsd | ||||
| @@ -84,6 +84,9 @@ | ||||
|  if [ x$new_interface_mtu != x ]; then | ||||
|    mtu_arg="mtu $new_interface_mtu" | ||||
|  fi | ||||
| +if [ x$IF_METRIC != x ]; then | ||||
| +  metric_arg="metric $IF_METRIC" | ||||
| +fi | ||||
|   | ||||
|  if [ x$reason = xMEDIUM ]; then | ||||
|    eval "ifconfig $interface $medium" | ||||
| @@ -141,7 +144,7 @@ | ||||
|    if [ x$old_ip_address = x ] || [ x$old_ip_address != x$new_ip_address ] || \ | ||||
|       [ x$reason = xBOUND ] || [ x$reason = xREBOOT ]; then | ||||
|      eval "ifconfig $interface inet $new_ip_address $new_netmask_arg \ | ||||
| -					$new_broadcast_arg $mtu_arg $medium" | ||||
| +			$new_broadcast_arg $mtu_arg $metric_arg $medium" | ||||
|      route add $new_ip_address 127.1 >/dev/null 2>&1 | ||||
|      for router in $new_routers; do | ||||
|        route add default $router >/dev/null 2>&1 | ||||
| @@ -198,7 +201,7 @@ | ||||
|      route delete $alias_ip_address 127.0.0.1 > /dev/null 2>&1 | ||||
|    fi | ||||
|    eval "ifconfig $interface inet $new_ip_address $new_netmask_arg \ | ||||
| -					$new_broadcast_arg $mtu_arg $medium" | ||||
| +			$new_broadcast_arg $mtu_arg $metric_arg $medium" | ||||
|    sleep 1 | ||||
|    if [ "$new_routers" != "" ]; then | ||||
|      set $new_routers | ||||
| --- client/scripts/solaris | ||||
| +++ client/scripts/solaris | ||||
| @@ -79,6 +79,9 @@ | ||||
|  if [ x$new_interface_mtu != x ]; then | ||||
|    mtu_arg="mtu $new_interface_mtu" | ||||
|  fi | ||||
| +if [ x$IF_METRIC != x ]; then | ||||
| +  metric_arg="metric $IF_METRIC" | ||||
| +fi | ||||
|   | ||||
|  ifconfig=/sbin/ifconfig | ||||
|   | ||||
| @@ -141,7 +144,7 @@ | ||||
|    if [ x$old_ip_address = x ] || [ x$old_ip_address != x$new_ip_address ] || \ | ||||
|       [ x$reason = xBOUND ] || [ x$reason = xREBOOT ]; then | ||||
|      eval "$ifconfig $interface inet $new_ip_address $new_netmask_arg \ | ||||
| -					$new_broadcast_arg $mtu_arg $medium" | ||||
| +			$new_broadcast_arg $mtu_arg $metric_arg $medium" | ||||
|      route add $new_ip_address 127.1 1 >/dev/null 2>&1 | ||||
|      for router in $new_routers; do | ||||
|        route add default $router 1 >/dev/null 2>&1 | ||||
| @@ -182,7 +185,7 @@ | ||||
|      route delete $alias_ip_address 127.0.0.1 > /dev/null 2>&1 | ||||
|    fi | ||||
|    eval "$ifconfig $interface inet $new_ip_address $new_netmask_arg \ | ||||
| -					$new_broadcast_arg $mtu_arg $medium" | ||||
| +			$new_broadcast_arg $mtu_arg $metric_arg $medium" | ||||
|    sleep 1 | ||||
|    set $new_routers | ||||
|    if ping -s -n -I 1 $1 64 1; then | ||||
							
								
								
									
										180
									
								
								net-misc/dhcp/files/dhcp-3.0.3-dhclient-mtu.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										180
									
								
								net-misc/dhcp/files/dhcp-3.0.3-dhclient-mtu.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,180 @@ | ||||
| --- client/scripts/bsdos | ||||
| +++ client/scripts/bsdos | ||||
| @@ -81,6 +81,9 @@ | ||||
|  if [ x$alias_subnet_mask != x ]; then | ||||
|    alias_subnet_arg="netmask $alias_subnet_mask" | ||||
|  fi | ||||
| +if [ x$new_interface_mtu != x ]; then | ||||
| +  mtu_arg="mtu $new_interface_mtu" | ||||
| +fi | ||||
|   | ||||
|  if [ x$reason = xMEDIUM ]; then | ||||
|    eval "ifconfig $interface $medium" | ||||
| @@ -138,7 +141,7 @@ | ||||
|    if [ x$old_ip_address = x ] || [ x$old_ip_address != x$new_ip_address ] || \ | ||||
|       [ x$reason = xBOUND ] || [ x$reason = xREBOOT ]; then | ||||
|      eval "ifconfig $interface inet $new_ip_address $new_netmask_arg \ | ||||
| -					$new_broadcast_arg $medium" | ||||
| +					$new_broadcast_arg $mtu_arg $medium" | ||||
|      route add $new_ip_address 127.1 >/dev/null 2>&1 | ||||
|      for router in $new_routers; do | ||||
|        route add default $router >/dev/null 2>&1 | ||||
| @@ -195,7 +198,7 @@ | ||||
|      route delete $alias_ip_address 127.0.0.1 > /dev/null 2>&1 | ||||
|    fi | ||||
|    eval "ifconfig $interface inet $new_ip_address $new_netmask_arg \ | ||||
| -					$new_broadcast_arg $medium" | ||||
| +					$new_broadcast_arg $mtu_arg $medium" | ||||
|    sleep 1 | ||||
|    if [ "$new_routers" != "" ]; then | ||||
|      set $new_routers | ||||
| --- client/scripts/freebsd | ||||
| +++ client/scripts/freebsd | ||||
| @@ -91,6 +91,9 @@ | ||||
|  if [ x$alias_subnet_mask != x ]; then | ||||
|    alias_subnet_arg="netmask $alias_subnet_mask" | ||||
|  fi | ||||
| +if [ x$new_interface_mtu != x ]; then | ||||
| +  mtu_arg="mtu $new_interface_mtu" | ||||
| +fi | ||||
|   | ||||
|  if [ x$reason = xMEDIUM ]; then | ||||
|    eval "ifconfig $interface $medium" | ||||
| @@ -148,7 +151,7 @@ | ||||
|    if [ x$old_ip_address = x ] || [ x$old_ip_address != x$new_ip_address ] || \ | ||||
|       [ x$reason = xBOUND ] || [ x$reason = xREBOOT ]; then | ||||
|      eval "ifconfig $interface inet $new_ip_address $new_netmask_arg \ | ||||
| -					$new_broadcast_arg $medium" | ||||
| +					$new_broadcast_arg $mtu_arg $medium" | ||||
|      $LOGGER "New IP Address ($interface): $new_ip_address" | ||||
|      $LOGGER "New Subnet Mask ($interface): $new_subnet_mask" | ||||
|      $LOGGER "New Broadcast Address ($interface): $new_broadcast_address" | ||||
| @@ -212,7 +215,7 @@ | ||||
|      route delete $alias_ip_address 127.0.0.1 > /dev/null 2>&1 | ||||
|    fi | ||||
|    eval "ifconfig $interface inet $new_ip_address $new_netmask_arg \ | ||||
| -					$new_broadcast_arg $medium" | ||||
| +					$new_broadcast_arg $mtu_arg $medium" | ||||
|    $LOGGER "New IP Address ($interface): $new_ip_address" | ||||
|    $LOGGER "New Subnet Mask ($interface): $new_subnet_mask" | ||||
|    $LOGGER "New Broadcast Address ($interface): $new_broadcast_address" | ||||
| --- client/scripts/linux | ||||
| +++ client/scripts/linux | ||||
| @@ -103,6 +103,9 @@ | ||||
|  if [ x$alias_subnet_mask != x ]; then | ||||
|    alias_subnet_arg="netmask $alias_subnet_mask" | ||||
|  fi | ||||
| +if [ x$new_interface_mtu != x ]; then | ||||
| +  mtu_arg="mtu $new_interface_mtu" | ||||
| +fi | ||||
|   | ||||
|  if [ x$reason = xMEDIUM ]; then | ||||
|    # Linux doesn't do mediums (ok, ok, media). | ||||
| @@ -159,7 +162,7 @@ | ||||
|       [ x$reason = xBOUND ] || [ x$reason = xREBOOT ]; then | ||||
|   | ||||
|      ifconfig $interface inet $new_ip_address $new_subnet_arg \ | ||||
| -							$new_broadcast_arg | ||||
| +					$new_broadcast_arg $mtu_arg | ||||
|      # Add a network route to the computed network address. | ||||
|      if [ $relmajor -lt 2 ] || \ | ||||
|  		( [ $relmajor -eq 2 ] && [ $relminor -eq 0 ] ); then | ||||
| @@ -201,7 +204,7 @@ | ||||
|      ifconfig $interface:0- inet 0 | ||||
|    fi | ||||
|    ifconfig $interface inet $new_ip_address $new_subnet_arg \ | ||||
| -					$new_broadcast_arg | ||||
| +					$new_broadcast_arg $mtu_arg | ||||
|    set $new_routers | ||||
|    ############## what is -w in ping? | ||||
|    if ping -q -c 1 $1; then | ||||
| --- client/scripts/netbsd | ||||
| +++ client/scripts/netbsd | ||||
| @@ -81,6 +81,9 @@ | ||||
|  if [ x$alias_subnet_mask != x ]; then | ||||
|    alias_subnet_arg="netmask $alias_subnet_mask" | ||||
|  fi | ||||
| +if [ x$new_interface_mtu != x ]; then | ||||
| +  mtu_arg="mtu $new_interface_mtu" | ||||
| +fi | ||||
|   | ||||
|  if [ x$reason = xMEDIUM ]; then | ||||
|    eval "ifconfig $interface $medium" | ||||
| @@ -138,7 +141,7 @@ | ||||
|    if [ x$old_ip_address = x ] || [ x$old_ip_address != x$new_ip_address ] || \ | ||||
|       [ x$reason = xBOUND ] || [ x$reason = xREBOOT ]; then | ||||
|      eval "ifconfig $interface inet $new_ip_address $new_netmask_arg \ | ||||
| -					$new_broadcast_arg $medium" | ||||
| +					$new_broadcast_arg $mtu_arg $medium" | ||||
|      route add $new_ip_address 127.1 >/dev/null 2>&1 | ||||
|      for router in $new_routers; do | ||||
|        route add default $router >/dev/null 2>&1 | ||||
| @@ -195,7 +198,7 @@ | ||||
|      route delete $alias_ip_address 127.0.0.1 > /dev/null 2>&1 | ||||
|    fi | ||||
|    eval "ifconfig $interface inet $new_ip_address $new_netmask_arg \ | ||||
| -					$new_broadcast_arg $medium" | ||||
| +					$new_broadcast_arg $mtu_arg $medium" | ||||
|    sleep 1 | ||||
|    if [ "$new_routers" != "" ]; then | ||||
|      set $new_routers | ||||
| --- client/scripts/openbsd | ||||
| +++ client/scripts/openbsd | ||||
| @@ -81,6 +81,9 @@ | ||||
|  if [ x$alias_subnet_mask != x ]; then | ||||
|    alias_subnet_arg="netmask $alias_subnet_mask" | ||||
|  fi | ||||
| +if [ x$new_interface_mtu != x ]; then | ||||
| +  mtu_arg="mtu $new_interface_mtu" | ||||
| +fi | ||||
|   | ||||
|  if [ x$reason = xMEDIUM ]; then | ||||
|    eval "ifconfig $interface $medium" | ||||
| @@ -138,7 +141,7 @@ | ||||
|    if [ x$old_ip_address = x ] || [ x$old_ip_address != x$new_ip_address ] || \ | ||||
|       [ x$reason = xBOUND ] || [ x$reason = xREBOOT ]; then | ||||
|      eval "ifconfig $interface inet $new_ip_address $new_netmask_arg \ | ||||
| -					$new_broadcast_arg $medium" | ||||
| +					$new_broadcast_arg $mtu_arg $medium" | ||||
|      route add $new_ip_address 127.1 >/dev/null 2>&1 | ||||
|      for router in $new_routers; do | ||||
|        route add default $router >/dev/null 2>&1 | ||||
| @@ -195,7 +198,7 @@ | ||||
|      route delete $alias_ip_address 127.0.0.1 > /dev/null 2>&1 | ||||
|    fi | ||||
|    eval "ifconfig $interface inet $new_ip_address $new_netmask_arg \ | ||||
| -					$new_broadcast_arg $medium" | ||||
| +					$new_broadcast_arg $mtu_arg $medium" | ||||
|    sleep 1 | ||||
|    if [ "$new_routers" != "" ]; then | ||||
|      set $new_routers | ||||
| --- client/scripts/solaris | ||||
| +++ client/scripts/solaris | ||||
| @@ -76,6 +76,9 @@ | ||||
|  if [ x$alias_subnet_mask != x ]; then | ||||
|    alias_subnet_arg="netmask $alias_subnet_mask" | ||||
|  fi | ||||
| +if [ x$new_interface_mtu != x ]; then | ||||
| +  mtu_arg="mtu $new_interface_mtu" | ||||
| +fi | ||||
|   | ||||
|  ifconfig=/sbin/ifconfig | ||||
|   | ||||
| @@ -138,7 +141,7 @@ | ||||
|    if [ x$old_ip_address = x ] || [ x$old_ip_address != x$new_ip_address ] || \ | ||||
|       [ x$reason = xBOUND ] || [ x$reason = xREBOOT ]; then | ||||
|      eval "$ifconfig $interface inet $new_ip_address $new_netmask_arg \ | ||||
| -					$new_broadcast_arg $medium" | ||||
| +					$new_broadcast_arg $mtu_arg $medium" | ||||
|      route add $new_ip_address 127.1 1 >/dev/null 2>&1 | ||||
|      for router in $new_routers; do | ||||
|        route add default $router 1 >/dev/null 2>&1 | ||||
| @@ -179,7 +182,7 @@ | ||||
|      route delete $alias_ip_address 127.0.0.1 > /dev/null 2>&1 | ||||
|    fi | ||||
|    eval "$ifconfig $interface inet $new_ip_address $new_netmask_arg \ | ||||
| -					$new_broadcast_arg $medium" | ||||
| +					$new_broadcast_arg $mtu_arg $medium" | ||||
|    sleep 1 | ||||
|    set $new_routers | ||||
|    if ping -s -n -I 1 $1 64 1; then | ||||
							
								
								
									
										70
									
								
								net-misc/dhcp/files/dhcp-3.0.3-dhclient-no-down.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										70
									
								
								net-misc/dhcp/files/dhcp-3.0.3-dhclient-no-down.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,70 @@ | ||||
| --- client/scripts/linux | ||||
| +++ client/scripts/linux | ||||
| @@ -118,9 +118,9 @@ | ||||
|  if [ x$reason = xPREINIT ]; then | ||||
|    if [ x$alias_ip_address != x ]; then | ||||
|      # Bring down alias interface. Its routes will disappear too. | ||||
| -    ifconfig $interface:0- inet 0 | ||||
| +    ifconfig $interface:0- inet 0.0.0.0 | ||||
|    fi | ||||
| -  ifconfig $interface 0 up | ||||
| +  ifconfig $interface 0.0.0.0 up | ||||
|   | ||||
|    # We need to give the kernel some time to get the interface up. | ||||
|    sleep 1 | ||||
| @@ -145,12 +145,12 @@ | ||||
|    if [ x$old_ip_address != x ] && [ x$alias_ip_address != x ] && \ | ||||
|  		[ x$alias_ip_address != x$old_ip_address ]; then | ||||
|      # Possible new alias. Remove old alias. | ||||
| -    ifconfig $interface:0- inet 0 | ||||
| +    ifconfig $interface:0- inet 0.0.0.0 | ||||
|    fi | ||||
|    if [ x$old_ip_address != x ] && [ x$old_ip_address != x$new_ip_address ]; then | ||||
|      # IP address changed. Bringing down the interface will delete all routes, | ||||
|      # and clear the ARP cache. | ||||
| -    ifconfig $interface inet 0 down | ||||
| +    ifconfig $interface inet 0.0.0.0 | ||||
|   | ||||
|    fi | ||||
|    if [ x$old_ip_address = x ] || [ x$old_ip_address != x$new_ip_address ] || \ | ||||
| @@ -171,7 +171,7 @@ | ||||
|    fi | ||||
|    if [ x$new_ip_address != x$alias_ip_address ] && [ x$alias_ip_address != x ]; | ||||
|     then | ||||
| -    ifconfig $interface:0- inet 0 | ||||
| +    ifconfig $interface:0- inet 0.0.0.0 | ||||
|      ifconfig $interface:0 inet $alias_ip_address $alias_subnet_arg | ||||
|      route add -host $alias_ip_address $interface:0 | ||||
|    fi | ||||
| @@ -183,11 +183,11 @@ | ||||
|     || [ x$reason = xSTOP ]; then | ||||
|    if [ x$alias_ip_address != x ]; then | ||||
|      # Turn off alias interface. | ||||
| -    ifconfig $interface:0- inet 0 | ||||
| +    ifconfig $interface:0- inet 0.0.0.0 | ||||
|    fi | ||||
|    if [ x$old_ip_address != x ]; then | ||||
|      # Shut down interface, which will delete routes and clear arp cache. | ||||
| -    ifconfig $interface inet 0 down | ||||
| +    ifconfig $interface inet 0.0.0.0 | ||||
|    fi | ||||
|    if [ x$alias_ip_address != x ]; then | ||||
|      ifconfig $interface:0 inet $alias_ip_address $alias_subnet_arg | ||||
| @@ -198,7 +198,7 @@ | ||||
|   | ||||
|  if [ x$reason = xTIMEOUT ]; then | ||||
|    if [ x$alias_ip_address != x ]; then | ||||
| -    ifconfig $interface:0- inet 0 | ||||
| +    ifconfig $interface:0- inet 0.0.0.0 | ||||
|    fi | ||||
|    ifconfig $interface inet $new_ip_address $new_subnet_arg \ | ||||
|  					$new_broadcast_arg $mtu_arg | ||||
| @@ -223,7 +223,7 @@ | ||||
|      make_resolv_conf | ||||
|      exit_with_hooks 0 | ||||
|    fi | ||||
| -  ifconfig $interface inet 0 down | ||||
| +  ifconfig $interface inet 0.0.0.0 | ||||
|    exit_with_hooks 1 | ||||
|  fi | ||||
|   | ||||
							
								
								
									
										186
									
								
								net-misc/dhcp/files/dhcp-3.0.3-dhclient-ntp.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										186
									
								
								net-misc/dhcp/files/dhcp-3.0.3-dhclient-ntp.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,186 @@ | ||||
| --- client/clparse.c | ||||
| +++ client/clparse.c | ||||
| @@ -51,6 +51,7 @@ | ||||
|  	DHO_DOMAIN_NAME, | ||||
|  	DHO_DOMAIN_NAME_SERVERS, | ||||
|  	DHO_HOST_NAME, | ||||
| +	DHO_NTP_SERVERS, | ||||
|  	0 | ||||
|  }; | ||||
|  | ||||
| --- client/scripts/bsdos | ||||
| +++ client/scripts/bsdos | ||||
| @@ -7,6 +7,26 @@ | ||||
|        echo nameserver $nameserver >>/etc/resolv.conf | ||||
|      done | ||||
|    fi | ||||
| +  # If we're making confs, may as well make an ntp.conf too | ||||
| +  make_ntp_conf | ||||
| +} | ||||
| + | ||||
| +make_ntp_conf() { | ||||
| +  if [ x$PEER_NTP = x ] || [ x$PEER_NTP = xyes ]; then | ||||
| +    if [ x$new_ntp_servers != x ]; then | ||||
| +      conf="# Generated by dhclient for interface $interface\n" | ||||
| +      conf="${conf}restrict default noquery notrust nomodify\n" | ||||
| +      conf="${conf}restrict 127.0.0.1\n" | ||||
| +      for ntpserver in $new_ntp_servers; do | ||||
| +        conf="${conf}restrict $ntpserver nomodify notrap noquery\n" | ||||
| +        conf="${conf}server $ntpserver\n" | ||||
| +      done | ||||
| +      conf="${conf}driftfile /var/lib/ntp/ntp.drift\n" | ||||
| +      conf="${conf}logfile /var/log/ntp.log\n" | ||||
| +      printf "${conf}" > /etc/ntp.conf | ||||
| +      chmod 644 /etc/ntp.conf | ||||
| +    fi | ||||
| +  fi | ||||
|  } | ||||
|   | ||||
|  # Must be used on exit.   Invokes the local dhcp client exit hooks, if any. | ||||
| --- client/scripts/freebsd | ||||
| +++ client/scripts/freebsd | ||||
| @@ -32,8 +32,28 @@ | ||||
|        done | ||||
|      fi | ||||
|    fi | ||||
| +  # If we're making confs, may as well make an ntp.conf too | ||||
| +  make_ntp_conf | ||||
|  } | ||||
|   | ||||
| +make_ntp_conf() { | ||||
| +  if [ x$PEER_NTP = x ] || [ x$PEER_NTP = xyes ]; then | ||||
| +    if [ "x$new_ntp_servers" != x ]; then | ||||
| +      conf="# Generated by dhclient for interface $interface\n" | ||||
| +      conf="${conf}restrict default noquery notrust nomodify\n" | ||||
| +      conf="${conf}restrict 127.0.0.1\n" | ||||
| +      for ntpserver in $new_ntp_servers; do | ||||
| +        conf="${conf}restrict $ntpserver nomodify notrap noquery\n" | ||||
| +        conf="${conf}server $ntpserver\n" | ||||
| +      done | ||||
| +      conf="${conf}driftfile /var/lib/ntp/ntp.drift\n" | ||||
| +      conf="${conf}logfile /var/log/ntp.log\n" | ||||
| +      printf "${conf}" > /etc/ntp.conf | ||||
| +      chmod 644 /etc/ntp.conf | ||||
| +    fi | ||||
| +  fi | ||||
| +} | ||||
| + | ||||
|  # Must be used on exit.   Invokes the local dhcp client exit hooks, if any. | ||||
|  exit_with_hooks() { | ||||
|    exit_status=$1 | ||||
| --- client/scripts/linux | ||||
| +++ client/scripts/linux | ||||
| @@ -30,6 +30,26 @@ | ||||
|        echo nameserver $nameserver >>/etc/resolv.conf | ||||
|      done | ||||
|    fi | ||||
| +  # If we're making confs, may as well make an ntp.conf too | ||||
| +  make_ntp_conf | ||||
| +} | ||||
| + | ||||
| +make_ntp_conf() { | ||||
| +  if [ x$PEER_NTP = x ] || [ x$PEER_NTP = xyes ]; then | ||||
| +    if [ "x$new_ntp_servers" != x ]; then | ||||
| +      conf="# Generated by dhclient for interface $interface\n" | ||||
| +      conf="${conf}restrict default noquery notrust nomodify\n" | ||||
| +      conf="${conf}restrict 127.0.0.1\n" | ||||
| +      for ntpserver in $new_ntp_servers; do | ||||
| +        conf="${conf}restrict $ntpserver nomodify notrap noquery\n" | ||||
| +        conf="${conf}server $ntpserver\n" | ||||
| +      done | ||||
| +      conf="${conf}driftfile /var/lib/ntp/ntp.drift\n" | ||||
| +      conf="${conf}logfile /var/log/ntp.log\n" | ||||
| +      printf "${conf}" > /etc/ntp.conf | ||||
| +      chmod 644 /etc/ntp.conf | ||||
| +    fi | ||||
| +  fi | ||||
|  } | ||||
|   | ||||
|  # Must be used on exit.   Invokes the local dhcp client exit hooks, if any. | ||||
| --- client/scripts/netbsd | ||||
| +++ client/scripts/netbsd | ||||
| @@ -7,6 +7,26 @@ | ||||
|        echo nameserver $nameserver >>/etc/resolv.conf | ||||
|      done | ||||
|    fi | ||||
| +  # If we're making confs, may as well make an ntp.conf too | ||||
| +  make_ntp_conf | ||||
| +} | ||||
| + | ||||
| +make_ntp_conf() { | ||||
| +  if [ x$PEER_NTP = x ] || [ x$PEER_NTP = xyes ]; then | ||||
| +    if [ "x$new_ntp_servers" != x ]; then | ||||
| +      conf="# Generated by dhclient for interface $interface\n" | ||||
| +      conf="${conf}restrict default noquery notrust nomodify\n" | ||||
| +      conf="${conf}restrict 127.0.0.1\n" | ||||
| +      for ntpserver in $new_ntp_servers; do | ||||
| +        conf="${conf}restrict $ntpserver nomodify notrap noquery\n" | ||||
| +        conf="${conf}server $ntpserver\n" | ||||
| +      done | ||||
| +      conf="${conf}driftfile /var/lib/ntp/ntp.drift\n" | ||||
| +      conf="${conf}logfile /var/log/ntp.log\n" | ||||
| +      printf "${conf}" > /etc/ntp.conf | ||||
| +      chmod 644 /etc/ntp.conf | ||||
| +    fi | ||||
| +  fi | ||||
|  } | ||||
|   | ||||
|  # Must be used on exit.   Invokes the local dhcp client exit hooks, if any. | ||||
| --- client/scripts/openbsd | ||||
| +++ client/scripts/openbsd | ||||
| @@ -7,6 +7,26 @@ | ||||
|        echo nameserver $nameserver >>/etc/resolv.conf | ||||
|      done | ||||
|    fi | ||||
| +  # If we're making confs, may as well make an ntp.conf too | ||||
| +  make_ntp_conf | ||||
| +} | ||||
| + | ||||
| +make_ntp_conf() { | ||||
| +  if [ x$PEER_NTP = x ] || [ x$PEER_NTP = xyes ]; then | ||||
| +    if [ "x$new_ntp_servers" != x ]; then | ||||
| +      conf="# Generated by dhclient for interface $interface\n" | ||||
| +      conf="${conf}restrict default noquery notrust nomodify\n" | ||||
| +      conf="${conf}restrict 127.0.0.1\n" | ||||
| +      for ntpserver in $new_ntp_servers; do | ||||
| +        conf="${conf}restrict $ntpserver nomodify notrap noquery\n" | ||||
| +        conf="${conf}server $ntpserver\n" | ||||
| +      done | ||||
| +      conf="${conf}driftfile /var/lib/ntp/ntp.drift\n" | ||||
| +      conf="${conf}logfile /var/log/ntp.log\n" | ||||
| +      printf "${conf}" > /etc/ntp.conf | ||||
| +      chmod 644 /etc/ntp.conf | ||||
| +    fi | ||||
| +  fi | ||||
|  } | ||||
|   | ||||
|  # Must be used on exit.   Invokes the local dhcp client exit hooks, if any. | ||||
| --- client/scripts/solaris | ||||
| +++ client/scripts/solaris | ||||
| @@ -7,6 +7,26 @@ | ||||
|        echo nameserver $nameserver >>/etc/resolv.conf | ||||
|      done | ||||
|    fi | ||||
| +  # If we're making confs, may as well make an ntp.conf too | ||||
| +  make_ntp_conf | ||||
| +} | ||||
| + | ||||
| +make_ntp_conf() { | ||||
| +  if [ x$PEER_NTP = x ] || [ x$PEER_NTP = xyes ]; then | ||||
| +    if [ "x$new_ntp_servers" != x ]; then | ||||
| +      conf="# Generated by dhclient for interface $interface\n" | ||||
| +      conf="${conf}restrict default noquery notrust nomodify\n" | ||||
| +      conf="${conf}restrict 127.0.0.1\n" | ||||
| +      for ntpserver in $new_ntp_servers; do | ||||
| +        conf="${conf}restrict $ntpserver nomodify notrap noquery\n" | ||||
| +        conf="${conf}server $ntpserver\n" | ||||
| +      done | ||||
| +      conf="${conf}driftfile /var/lib/ntp/ntp.drift\n" | ||||
| +      conf="${conf}logfile /var/log/ntp.log\n" | ||||
| +      printf "${conf}" > /etc/ntp.conf | ||||
| +      chmod 644 /etc/ntp.conf | ||||
| +    fi | ||||
| +  fi | ||||
|  } | ||||
|   | ||||
|  # Must be used on exit.   Invokes the local dhcp client exit hooks, if any. | ||||
							
								
								
									
										191
									
								
								net-misc/dhcp/files/dhcp-3.0.3-dhclient-resolvconf.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										191
									
								
								net-misc/dhcp/files/dhcp-3.0.3-dhclient-resolvconf.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,191 @@ | ||||
| --- client/scripts/bsdos | ||||
| +++ client/scripts/bsdos | ||||
| @@ -1,11 +1,22 @@ | ||||
|  #!/bin/sh | ||||
|   | ||||
|  make_resolv_conf() { | ||||
| -  if [ "x$new_domain_name" != x ] && [ x"$new_domain_name_servers" != x ]; then | ||||
| -    echo search $new_domain_name >/etc/resolv.conf | ||||
| -    for nameserver in $new_domain_name_servers; do | ||||
| -      echo nameserver $nameserver >>/etc/resolv.conf | ||||
| -    done | ||||
| +  if [ x$PEER_DNS = x ] || [ x$PEER_DNS = xyes ]; then | ||||
| +    if [ "x$new_domain_name" != x ] || [ "x$new_domain_name_servers" != x ]; then | ||||
| +      conf="# Generated by dhclient for interface $interface\n" | ||||
| +      if [ "x$new_domain_name" != x ]; then | ||||
| +        conf="${conf}search $new_domain_name\n" | ||||
| +      fi | ||||
| +      for nameserver in $new_domain_name_servers; do | ||||
| +        conf="${conf}nameserver $nameserver\n" | ||||
| +      done | ||||
| +      if [ -x /sbin/resolvconf ]; then | ||||
| +        printf "$conf" | resolvconf -a "$interface" | ||||
| +      else | ||||
| +        printf "$conf" > /etc/resolv.conf | ||||
| +        chmod 644 /etc/resolv.conf | ||||
| +      fi | ||||
| +    fi | ||||
|    fi | ||||
|    # If we're making confs, may as well make an ntp.conf too | ||||
|    make_ntp_conf | ||||
| --- client/scripts/freebsd | ||||
| +++ client/scripts/freebsd | ||||
| @@ -11,25 +11,21 @@ | ||||
|  fi | ||||
|   | ||||
|  make_resolv_conf() { | ||||
| -  if [ x"$new_domain_name_servers" != x ]; then | ||||
| -    if [ "x$new_domain_name" != x ]; then | ||||
| -      ( echo search $new_domain_name >/etc/resolv.conf ) | ||||
| -      exit_status=$? | ||||
| -    else | ||||
| -      if [ -e /etc/resolv.conf ] ; then | ||||
| -	( rm /etc/resolv.conf ) | ||||
| -	exit_status=$? | ||||
| -      else | ||||
| -	( touch /etc/resolv.conf ) | ||||
| -	exit_status=$? | ||||
| +  if [ x$PEER_DNS = x ] || [ x$PEER_DNS = xyes ]; then | ||||
| +    if [ "x$new_domain_name" != x ] || [ "x$new_domain_name_servers" != x ]; then | ||||
| +      conf="# Generated by dhclient for interface $interface\n" | ||||
| +      if [ "x$new_domain_name" != x ]; then | ||||
| +        conf="${conf}search $new_domain_name\n" | ||||
|        fi | ||||
| -    fi | ||||
| -    if [ $exit_status -ne 0 ]; then | ||||
| -      $LOGGER "WARNING: Unable to update resolv.conf: Error $exit_status" | ||||
| -    else | ||||
|        for nameserver in $new_domain_name_servers; do | ||||
| -	( echo nameserver $nameserver >>/etc/resolv.conf ) | ||||
| +        conf="${conf}nameserver $nameserver\n" | ||||
|        done | ||||
| +      if [ -x /sbin/resolvconf ]; then | ||||
| +        printf "$conf" | resolvconf -a "$interface" | ||||
| +      else | ||||
| +        printf "$conf" > /etc/resolv.conf | ||||
| +        chmod 644 /etc/resolv.conf | ||||
| +      fi | ||||
|      fi | ||||
|    fi | ||||
|    # If we're making confs, may as well make an ntp.conf too | ||||
| --- client/scripts/linux | ||||
| +++ client/scripts/linux | ||||
| @@ -23,12 +23,22 @@ | ||||
|  # of the $1 in its args. | ||||
|   | ||||
|  make_resolv_conf() { | ||||
| -  if [ "x$new_domain_name" != x ] && [ x"$new_domain_name_servers" != x ]; then | ||||
| -    echo search $new_domain_name >/etc/resolv.conf | ||||
| -    chmod 644 /etc/resolv.conf | ||||
| -    for nameserver in $new_domain_name_servers; do | ||||
| -      echo nameserver $nameserver >>/etc/resolv.conf | ||||
| -    done | ||||
| +  if [ x$PEER_DNS = x ] || [ x$PEER_DNS = xyes ]; then | ||||
| +    if [ "x$new_domain_name" != x ] || [ "x$new_domain_name_servers" != x ]; then | ||||
| +      conf="# Generated by dhclient for interface $interface\n" | ||||
| +      if [ "x$new_domain_name" != x ]; then | ||||
| +        conf="${conf}search $new_domain_name\n" | ||||
| +      fi | ||||
| +      for nameserver in $new_domain_name_servers; do | ||||
| +        conf="${conf}nameserver $nameserver\n" | ||||
| +      done | ||||
| +      if [ -x /sbin/resolvconf ]; then | ||||
| +        printf "$conf" | resolvconf -a "$interface" | ||||
| +      else | ||||
| +        printf "$conf" > /etc/resolv.conf | ||||
| +        chmod 644 /etc/resolv.conf | ||||
| +      fi | ||||
| +    fi | ||||
|    fi | ||||
|    # If we're making confs, may as well make an ntp.conf too | ||||
|    make_ntp_conf | ||||
| --- client/scripts/netbsd | ||||
| +++ client/scripts/netbsd | ||||
| @@ -1,11 +1,22 @@ | ||||
|  #!/bin/sh | ||||
|   | ||||
|  make_resolv_conf() { | ||||
| -  if [ "x$new_domain_name" != x ] && [ x"$new_domain_name_servers" != x ]; then | ||||
| -    echo search $new_domain_name >/etc/resolv.conf | ||||
| -    for nameserver in $new_domain_name_servers; do | ||||
| -      echo nameserver $nameserver >>/etc/resolv.conf | ||||
| -    done | ||||
| +  if [ x$PEER_DNS = x ] || [ x$PEER_DNS = xyes ]; then | ||||
| +    if [ "x$new_domain_name" != x ] || [ "x$new_domain_name_servers" != x ]; then | ||||
| +      conf="# Generated by dhclient for interface $interface\n" | ||||
| +      if [ "x$new_domain_name" != x ]; then | ||||
| +        conf="${conf}search $new_domain_name\n" | ||||
| +      fi | ||||
| +      for nameserver in $new_domain_name_servers; do | ||||
| +        conf="${conf}nameserver $nameserver\n" | ||||
| +      done | ||||
| +      if [ -x /sbin/resolvconf ]; then | ||||
| +        printf "$conf" | resolvconf -a "$interface" | ||||
| +      else | ||||
| +        printf "$conf" > /etc/resolv.conf | ||||
| +        chmod 644 /etc/resolv.conf | ||||
| +      fi | ||||
| +    fi | ||||
|    fi | ||||
|    # If we're making confs, may as well make an ntp.conf too | ||||
|    make_ntp_conf | ||||
| --- client/scripts/openbsd | ||||
| +++ client/scripts/openbsd | ||||
| @@ -1,11 +1,22 @@ | ||||
|  #!/bin/sh | ||||
|   | ||||
|  make_resolv_conf() { | ||||
| -  if [ "x$new_domain_name" != x ] && [ x"$new_domain_name_servers" != x ]; then | ||||
| -    echo search $new_domain_name >/etc/resolv.conf | ||||
| -    for nameserver in $new_domain_name_servers; do | ||||
| -      echo nameserver $nameserver >>/etc/resolv.conf | ||||
| -    done | ||||
| +  if [ x$PEER_DNS = x ] || [ x$PEER_DNS = xyes ]; then | ||||
| +    if [ "x$new_domain_name" != x ] || [ "x$new_domain_name_servers" != x ]; then | ||||
| +      conf="# Generated by dhclient for interface $interface\n" | ||||
| +      if [ x$new_domain_name != x ]; then | ||||
| +        conf="${conf}search $new_domain_name\n" | ||||
| +      fi | ||||
| +      for nameserver in $new_domain_name_servers; do | ||||
| +        conf="${conf}nameserver $nameserver\n" | ||||
| +      done | ||||
| +      if [ -x /sbin/resolvconf ]; then | ||||
| +        printf "$conf" | resolvconf -a "$interface" | ||||
| +      else | ||||
| +        printf "$conf" > /etc/resolv.conf | ||||
| +        chmod 644 /etc/resolv.conf | ||||
| +      fi | ||||
| +    fi | ||||
|    fi | ||||
|    # If we're making confs, may as well make an ntp.conf too | ||||
|    make_ntp_conf | ||||
| --- client/scripts/solaris | ||||
| +++ client/scripts/solaris | ||||
| @@ -1,11 +1,22 @@ | ||||
|  #!/bin/sh   | ||||
|   | ||||
|  make_resolv_conf() { | ||||
| -  if [ "x$new_domain_name" != x ] && [ x"$new_domain_name_servers" != x ]; then | ||||
| -    echo search $new_domain_name >/etc/resolv.conf | ||||
| -    for nameserver in $new_domain_name_servers; do | ||||
| -      echo nameserver $nameserver >>/etc/resolv.conf | ||||
| -    done | ||||
| +  if [ x$PEER_DNS = x ] || [ x$PEER_DNS = xyes ]; then | ||||
| +    if [ "x$new_domain_name" != x ] || [ "x$new_domain_name_servers" != x ]; then | ||||
| +      conf="# Generated by dhclient for interface $interface\n" | ||||
| +      if [ "x$new_domain_name" != x ]; then | ||||
| +        conf="${conf}search $new_domain_name\n" | ||||
| +      fi | ||||
| +      for nameserver in $new_domain_name_servers; do | ||||
| +        conf="${conf}nameserver $nameserver\n" | ||||
| +      done | ||||
| +      if [ -x /sbin/resolvconf ]; then | ||||
| +        printf "$conf" | resolvconf -a "$interface" | ||||
| +      else | ||||
| +        printf "$conf" > /etc/resolv.conf | ||||
| +        chmod 644 /etc/resolv.conf | ||||
| +      fi | ||||
| +    fi | ||||
|    fi | ||||
|    # If we're making confs, may as well make an ntp.conf too | ||||
|    make_ntp_conf | ||||
							
								
								
									
										77
									
								
								net-misc/dhcp/files/dhcp-3.0.3-dhclient-stdin-conf.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										77
									
								
								net-misc/dhcp/files/dhcp-3.0.3-dhclient-stdin-conf.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,77 @@ | ||||
| --- client/clparse.c.orig	2006-02-22 09:37:12.000000000 +0000 | ||||
| +++ client/clparse.c	2006-02-22 09:38:26.000000000 +0000 | ||||
| @@ -97,6 +97,11 @@ | ||||
|  	status = read_client_conf_file (path_dhclient_conf, | ||||
|  					(struct interface_info *)0, | ||||
|  					&top_level_config); | ||||
| + | ||||
| +	/* Read any extra configuration from stdin */ | ||||
| +	read_client_conf_stdin ((struct interface_info *)0, | ||||
| +					&top_level_config); | ||||
| +	 | ||||
|  	if (status != ISC_R_SUCCESS) { | ||||
|  		; | ||||
|  #ifdef LATER | ||||
| @@ -148,20 +153,17 @@ | ||||
|  	return status; | ||||
|  } | ||||
|   | ||||
| -int read_client_conf_file (const char *name, struct interface_info *ip, | ||||
| -			   struct client_config *client) | ||||
| +int read_client_conf_actual (int file, const char *name,  | ||||
| +			     struct interface_info *ip, | ||||
| +			     struct client_config *client) | ||||
|  { | ||||
| -	int file; | ||||
|  	struct parse *cfile; | ||||
|  	const char *val; | ||||
|  	int token; | ||||
|  	isc_result_t status; | ||||
|  	 | ||||
| -	if ((file = open (name, O_RDONLY)) < 0) | ||||
| -		return uerr2isc (errno); | ||||
| - | ||||
|  	cfile = (struct parse *)0; | ||||
| -	new_parse (&cfile, file, (char *)0, 0, path_dhclient_conf, 0); | ||||
| +	new_parse (&cfile, file, (char *)0, 0, name , 0); | ||||
|   | ||||
|  	do { | ||||
|  		token = peek_token (&val, (unsigned *)0, cfile); | ||||
| @@ -174,11 +174,36 @@ | ||||
|  	status = (cfile -> warnings_occurred | ||||
|  		  ? ISC_R_BADPARSE | ||||
|  		  : ISC_R_SUCCESS); | ||||
| -	close (file); | ||||
|  	end_parse (&cfile); | ||||
|  	return status; | ||||
|  } | ||||
|   | ||||
| +int read_client_conf_file (const char *name, struct interface_info *ip, | ||||
| +			   struct client_config *client) | ||||
| +{ | ||||
| +	int file; | ||||
| +	isc_result_t status; | ||||
| +	 | ||||
| +	if ((file = open (name, O_RDONLY)) < 0) | ||||
| +		return uerr2isc (errno); | ||||
| + | ||||
| +	status = read_client_conf_actual(file, name, ip, client); | ||||
| + | ||||
| +	return status; | ||||
| +} | ||||
| + | ||||
| + | ||||
| +int read_client_conf_stdin (struct interface_info *ip, | ||||
| +			    struct client_config *client) | ||||
| +{ | ||||
| +	int file = fileno(stdin); | ||||
| +	isc_result_t status; | ||||
| + | ||||
| +	if (isatty(file)) return ISC_R_NOTFOUND; | ||||
| +	status = read_client_conf_actual(file, "stdin", ip, client); | ||||
| + | ||||
| +	return status; | ||||
| +} | ||||
|   | ||||
|  /* lease-file :== client-lease-statements END_OF_FILE | ||||
|     client-lease-statements :== <nil> | ||||
							
								
								
									
										14
									
								
								net-misc/dhcp/files/dhcp-3.0.3-libdst.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								net-misc/dhcp/files/dhcp-3.0.3-libdst.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | ||||
| --- dst/Makefile.dist.old	2004-12-24 13:31:22.986061032 +0000 | ||||
| +++ dst/Makefile.dist	2004-12-24 13:47:19.036913364 +0000 | ||||
| @@ -31,6 +31,10 @@ | ||||
|  all:	libdst.a | ||||
|   | ||||
|  install: | ||||
| +	mkdir -p $(DESTDIR)$(LIBDIR) | ||||
| +	$(INSTALL) libdst.a $(DESTDIR)$(LIBDIR) | ||||
| +	$(CHMOD) 644 $(DESTDIR)$(LIBDIR)/libdst.a | ||||
| + | ||||
|   | ||||
|  libdst.a:	$(OBJ) | ||||
|     rm -f dst.a | ||||
|  | ||||
							
								
								
									
										105
									
								
								net-misc/dhcp/files/dhcp-3.0.3-no_isc_blurb.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										105
									
								
								net-misc/dhcp/files/dhcp-3.0.3-no_isc_blurb.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,105 @@ | ||||
| Patch nobbled from RedHat, and adapted to work with dhclient and dhrelay | ||||
| by Roy Marples <uberlord@gentoo.org> | ||||
|  | ||||
| --- dhcp-3.0.3/omapip/errwarn.c.no_isc_blurb	2004-09-30 16:38:32.000000000 -0400 | ||||
| +++ dhcp-3.0.3/omapip/errwarn.c	2005-04-18 13:45:49.037158000 -0400 | ||||
| @@ -45,6 +45,8 @@ | ||||
|  int log_perror = 1; | ||||
|  #endif | ||||
|  int log_priority; | ||||
| +int log_isc_blurb=1; | ||||
| + | ||||
|  void (*log_cleanup) (void); | ||||
|   | ||||
|  #define CVT_BUF_MAX 1023 | ||||
| @@ -76,7 +78,9 @@ | ||||
|  	  write (STDERR_FILENO, "\n", 1); | ||||
|    } | ||||
|   | ||||
| -#if !defined (NOMINUM) | ||||
| +#if !defined(NOMINUM) | ||||
| +  if ( log_isc_blurb ) | ||||
| +  { | ||||
|    log_error ("%s", ""); | ||||
|    log_error ("If you did not get this software from ftp.isc.org, please"); | ||||
|    log_error ("get the latest from ftp.isc.org and install that before"); | ||||
| @@ -94,7 +98,12 @@ | ||||
|    log_error ("the README file."); | ||||
|    log_error ("%s", ""); | ||||
|    log_error ("exiting."); | ||||
| +  }else | ||||
| +  { | ||||
| +      log_error ("exiting."); | ||||
| +  } | ||||
|  #endif | ||||
| + | ||||
|    if (log_cleanup) | ||||
|  	  (*log_cleanup) (); | ||||
|    exit (1); | ||||
| --- dhcp-3.0.3/client/dhclient.c.no_isc_blurb	2005-04-18 13:21:08.509169000 -0400 | ||||
| +++ dhcp-3.0.3/client/dhclient.c	2005-04-18 13:49:27.574402000 -0400 | ||||
| @@ -34,7 +34,7 @@ | ||||
|  static char ocopyright[] = | ||||
|  "$Id: dhcp-3.0.3-no_isc_blurb.patch,v 1.1 2005/12/09 14:13:30 uberlord Exp $ Copyright (c) 2004 Internet Systems Consortium.  All rights reserved.\n"; | ||||
|  #endif /* not lint */ | ||||
| - | ||||
| +  | ||||
|  #include "dhcpd.h" | ||||
|  #include "version.h" | ||||
|   | ||||
| @@ -81,6 +81,8 @@ | ||||
|   | ||||
|  void do_release(struct client_state *); | ||||
|   | ||||
| +extern int log_isc_blurb; | ||||
| + | ||||
|  int main (argc, argv, envp) | ||||
|  	int argc; | ||||
|  	char **argv, **envp; | ||||
| @@ -176,6 +178,7 @@ | ||||
|  		} else if (!strcmp (argv [i], "-q")) { | ||||
|  			quiet = 1; | ||||
|  			quiet_interface_discovery = 1; | ||||
| +			log_isc_blurb = 0;       | ||||
|  		} else if (!strcmp (argv [i], "-s")) { | ||||
|  			if (++i == argc) | ||||
|  				usage (); | ||||
| --- dhcp-3.0.3/server/dhcpd.c.no_isc_blurb	2005-12-08 10:01:40.000000000 +0000 | ||||
| +++ dhcp-3.0.3/server/dhcpd.c	2005-12-08 10:05:55.000000000 +0000 | ||||
| @@ -62,6 +62,9 @@ | ||||
|  struct iaddr server_identifier; | ||||
|  int server_identifier_matched; | ||||
|   | ||||
| + | ||||
| +extern int log_isc_blurb; | ||||
| + | ||||
|  #if defined (NSUPDATE) | ||||
|   | ||||
|  /* This stuff is always executed to figure the default values for certain | ||||
| @@ -368,6 +371,7 @@ | ||||
|  		} else if (!strcmp (argv [i], "-q")) { | ||||
|  			quiet = 1; | ||||
|  			quiet_interface_discovery = 1; | ||||
| +			log_isc_blurb = 0; | ||||
|  		} else if (!strcmp (argv [i], "--version")) { | ||||
|  			log_info ("isc-dhcpd-%s", DHCP_VERSION); | ||||
|  			exit (0); | ||||
| --- dhcp-3.0.3/relay/dhcrelay.c.no_isc_blurb	2005-12-08 10:21:00.000000000 +0000 | ||||
| +++ dhcp-3.0.3/relay/dhcrelay.c	2005-12-08 10:21:50.000000000 +0000 | ||||
| @@ -102,6 +102,8 @@ | ||||
|  static char message [] = "Internet Systems Consortium DHCP Relay Agent"; | ||||
|  static char url [] = "For info, please visit http://www.isc.org/sw/dhcp/"; | ||||
|   | ||||
| +extern int log_isc_blurb; | ||||
| + | ||||
|  int main (argc, argv, envp) | ||||
|  	int argc; | ||||
|  	char **argv, **envp; | ||||
| @@ -170,6 +172,7 @@ | ||||
|  		} else if (!strcmp (argv [i], "-q")) { | ||||
|  			quiet = 1; | ||||
|  			quiet_interface_discovery = 1; | ||||
| +			log_isc_blurb = 0; | ||||
|  		} else if (!strcmp (argv [i], "-a")) { | ||||
|  			add_agent_options = 1; | ||||
|  		} else if (!strcmp (argv [i], "-c")) { | ||||
							
								
								
									
										12
									
								
								net-misc/dhcp/files/dhcp-3.0.3-tr.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								net-misc/dhcp/files/dhcp-3.0.3-tr.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | ||||
| --- work.linux-2.2/common/tr.c	2005/08/14 11:34:24	1.1 | ||||
| +++ work.linux-2.2/common/tr.c	2005/08/14 11:35:16 | ||||
| @@ -40,6 +40,9 @@ static char copyright[] = | ||||
|  #include "includes/netinet/if_ether.h" | ||||
|  #include "netinet/if_tr.h" | ||||
|  #include <sys/time.h> | ||||
| +#ifdef __linux__ | ||||
| +#include <linux/types.h> | ||||
| +#endif | ||||
|   | ||||
|  /* | ||||
|   * token ring device handling subroutines.  These are required as token-ring | ||||
							
								
								
									
										216
									
								
								net-misc/dhcp/files/dhcp-3.0.3-x-option.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										216
									
								
								net-misc/dhcp/files/dhcp-3.0.3-x-option.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,216 @@ | ||||
| --- dhcp-3.0.2/common/parse.c.extended_option_environment	2005-04-05 17:49:36.513062562 -0400 | ||||
| +++ dhcp-3.0.2/common/parse.c	2005-04-05 17:49:36.580052656 -0400 | ||||
| @@ -1270,6 +1270,10 @@ | ||||
|  	option_hash_add (option -> universe -> hash, | ||||
|  			 (const char *)option -> name, | ||||
|  			 0, option, MDL); | ||||
| +#ifdef EXTENDED_NEW_OPTION_INFO | ||||
| +	if ( new_option_info_tree != 0L ) | ||||
| +		add_new_option_info( option ); | ||||
| +#endif | ||||
|  	return 1; | ||||
|  } | ||||
|   | ||||
| --- dhcp-3.0.2/common/tables.c.extended_option_environment	2004-09-01 13:06:35.000000000 -0400 | ||||
| +++ dhcp-3.0.2/common/tables.c	2005-04-05 18:04:23.915838623 -0400 | ||||
| @@ -1238,3 +1238,40 @@ | ||||
|  			   fqdn_universe.name, 0, | ||||
|  			   &fqdn_universe, MDL); | ||||
|  } | ||||
| + | ||||
| +#ifdef EXTENDED_NEW_OPTION_INFO | ||||
| +#include <search.h> | ||||
| + | ||||
| +void *new_option_info_tree = 0L; | ||||
| + | ||||
| +static int  new_option_info_comparator( const void* p1, const void *p2 ) | ||||
| +{ | ||||
| +	uint32_t ocode1 =  (((const struct option*)p1)->universe->index << 8) | ||||
| +		          |(((const struct option*)p1)->code), | ||||
| +		 ocode2 =  (((const struct option*)p2)->universe->index << 8) | ||||
| +	                  |(((const struct option*)p2)->code); | ||||
| +	return( (ocode1 == ocode2)  | ||||
| +		? 0  | ||||
| +		:( ( ocode1 > ocode2 ) | ||||
| +		   ?  1 | ||||
| +		   : -1 | ||||
| +	         ) | ||||
| +	      ); | ||||
| +} | ||||
| + | ||||
| +void *add_new_option_info( struct option *option ) | ||||
| +{ | ||||
| +	if ( option->universe->index >= fqdn_universe.index ) | ||||
| +		return 0L; | ||||
| +	if ( new_option_info_tree == GENERATE_NEW_OPTION_INFO ) | ||||
| +		new_option_info_tree = (void*)0L; | ||||
| +	return tsearch( option, &(new_option_info_tree), new_option_info_comparator ); | ||||
| +} | ||||
| + | ||||
| +void *lookup_new_option_info( struct option *option ) | ||||
| +{ | ||||
| +	if ( new_option_info_tree == GENERATE_NEW_OPTION_INFO ) | ||||
| +		return 0L; | ||||
| +	return tfind( option, &(new_option_info_tree), new_option_info_comparator ); | ||||
| +} | ||||
| +#endif | ||||
| --- dhcp-3.0.2/includes/dhcpd.h.extended_option_environment	2004-11-24 12:39:16.000000000 -0500 | ||||
| +++ dhcp-3.0.2/includes/dhcpd.h	2005-04-05 17:49:36.613047777 -0400 | ||||
| @@ -1800,6 +1800,13 @@ | ||||
|  void initialize_common_option_spaces PROTO ((void)); | ||||
|  struct universe *config_universe; | ||||
|   | ||||
| +#ifdef EXTENDED_NEW_OPTION_INFO | ||||
| +#define GENERATE_NEW_OPTION_INFO ((void*)1) | ||||
| +extern void   *new_option_info_tree; | ||||
| +extern void   *add_new_option_info( struct option*); | ||||
| +extern void   *lookup_new_option_info( struct option *); | ||||
| +#endif | ||||
| + | ||||
|  /* stables.c */ | ||||
|  #if defined (FAILOVER_PROTOCOL) | ||||
|  extern failover_option_t null_failover_option; | ||||
| --- dhcp-3.0.2/client/dhclient.c.extended_option_environment	2005-04-05 17:49:36.566054726 -0400 | ||||
| +++ dhcp-3.0.2/client/dhclient.c	2005-04-05 17:49:36.617047185 -0400 | ||||
| @@ -74,7 +74,9 @@ | ||||
|  int onetry=0; | ||||
|  int quiet=0; | ||||
|  int nowait=0; | ||||
| - | ||||
| +#ifdef EXTENDED_NEW_OPTION_INFO | ||||
| +int extended_option_environment = 0; | ||||
| +#endif | ||||
|  static void usage PROTO ((void)); | ||||
|   | ||||
|  void do_release(struct client_state *); | ||||
| @@ -204,6 +206,11 @@ | ||||
|  		} else if (!strcmp (argv [i], "--version")) { | ||||
|  			log_info ("isc-dhclient-%s", DHCP_VERSION); | ||||
|  			exit (0); | ||||
| +#ifdef EXTENDED_NEW_OPTION_INFO | ||||
| +		} else if (!strcmp (argv [i], "-x")) { | ||||
| +		    extended_option_environment = 1; | ||||
| +		    new_option_info_tree = GENERATE_NEW_OPTION_INFO; | ||||
| +#endif | ||||
|   		} else if (argv [i][0] == '-') { | ||||
|   		    usage (); | ||||
|  		} else { | ||||
| @@ -572,7 +579,11 @@ | ||||
|  	log_info (arr); | ||||
|  	log_info (url); | ||||
|   | ||||
| +#ifdef EXTENDED_NEW_OPTION_INFO | ||||
| +	log_error ("Usage: dhclient [-1dqr] [-nwx] [-p <port>] %s", | ||||
| +#else | ||||
|  	log_error ("Usage: dhclient [-1dqr] [-nw] [-p <port>] %s", | ||||
| +#endif | ||||
|  		   "[-s server]"); | ||||
|  	log_error ("                [-cf config-file] [-lf lease-file]%s", | ||||
|  		   "[-pf pid-file] [-e VAR=val]"); | ||||
| @@ -2529,8 +2540,28 @@ | ||||
|  struct envadd_state { | ||||
|  	struct client_state *client; | ||||
|  	const char *prefix; | ||||
| +        struct universe *universe; | ||||
|  }; | ||||
|   | ||||
| +#ifdef EXTENDED_NEW_OPTION_INFO			 | ||||
| +static  | ||||
| +void build_universe_info_envvar | ||||
| +(      struct option_cache *oc, | ||||
| +       struct packet *p, struct lease *l, | ||||
| +       struct client_state *client, | ||||
| +       struct option_state *in_o, | ||||
| +       struct option_state *cf_o, | ||||
| +       struct binding_scope **scope, | ||||
| +       struct universe *u, void *es	           | ||||
| +) | ||||
| +{ | ||||
| +    char info_name[512], info_data[512]; | ||||
| +    snprintf(info_name, 512, "%s._universe_.", oc->option->universe->name); | ||||
| +    snprintf(info_data, 512, "%u:%s", oc->option->code,oc->option->format); | ||||
| +    client_envadd( client, info_name, oc->option->name, info_data ); | ||||
| +} | ||||
| +#endif | ||||
| + | ||||
|  void client_option_envadd (struct option_cache *oc, | ||||
|  			   struct packet *packet, struct lease *lease, | ||||
|  			   struct client_state *client_state, | ||||
| @@ -2547,6 +2578,31 @@ | ||||
|  				   in_options, cfg_options, scope, oc, MDL)) { | ||||
|  		if (data.len) { | ||||
|  			char name [256]; | ||||
| +#ifdef EXTENDED_NEW_OPTION_INFO			 | ||||
| +			if (  extended_option_environment ) | ||||
| +			{ | ||||
| +				if(  ( oc->option->universe != &dhcp_universe ) | ||||
| +				   &&( oc->option->universe->index > fqdn_universe.index ) | ||||
| +				   &&( es->universe !=  oc->option->universe ) | ||||
| +			          ) | ||||
| +				{ | ||||
| +					es->universe = oc->option->universe; | ||||
| +					(*(es->universe->foreach)) | ||||
| +					     (  (struct packet *)0, (struct lease *)0,  | ||||
| +						client_state,  | ||||
| +						in_options, cfg_options,  | ||||
| +						scope, es->universe, es,  | ||||
| +						build_universe_info_envvar | ||||
| +					     ); | ||||
| +				}else | ||||
| +				if ( lookup_new_option_info(oc->option) != 0L )			    | ||||
| +					build_universe_info_envvar | ||||
| +					      ( oc, packet, lease, client_state,  | ||||
| +						in_options, cfg_options, scope, | ||||
| +						oc->option->universe, es  | ||||
| +					      ); | ||||
| +			} | ||||
| +#endif | ||||
|  			if (dhcp_option_ev_name (name, sizeof name, | ||||
|  						 oc -> option)) { | ||||
|  				client_envadd (es -> client, es -> prefix, | ||||
| @@ -2575,6 +2631,7 @@ | ||||
|   | ||||
|  	es.client = client; | ||||
|  	es.prefix = prefix; | ||||
| +	es.universe = 0L; | ||||
|   | ||||
|  	client_envadd (client, | ||||
|  		       prefix, "ip_address", "%s", piaddr (lease -> address)); | ||||
| @@ -2788,7 +2845,14 @@ | ||||
|  			s = option -> name; | ||||
|  			if (j + 1 == buflen) | ||||
|  				return 0; | ||||
| +#ifdef EXTENDED_NEW_OPTION_INFO | ||||
| +			if ( ! extended_option_environment ) | ||||
| +			    buf [j++] = '_'; | ||||
| +			else | ||||
| +			    buf [j++] = '.'; | ||||
| +#else | ||||
|  			buf [j++] = '_'; | ||||
| +#endif | ||||
|  		} | ||||
|  		++i; | ||||
|  	} while (i != 2); | ||||
| --- dhcp-3.0.2/client/dhclient.8.extended_option_environment	2004-09-29 19:01:46.000000000 -0400 | ||||
| +++ dhcp-3.0.2/client/dhclient.8	2005-04-05 17:49:36.619046889 -0400 | ||||
| @@ -78,6 +78,9 @@ | ||||
|  .B -w | ||||
|  ] | ||||
|  [ | ||||
| +.B -x | ||||
| +] | ||||
| +[ | ||||
|  .I if0 | ||||
|  [ | ||||
|  .I ...ifN | ||||
| @@ -252,6 +255,10 @@ | ||||
|  supplying the | ||||
|  .B -nw | ||||
|  flag. | ||||
| +.PP | ||||
| +The -x argument enables eXtended option information to be created in the | ||||
| +-s dhclient-script environment, which would allow applications running  | ||||
| +in that environment to handle options they do not know about in advance. | ||||
|  .SH CONFIGURATION | ||||
|  The syntax of the dhclient.conf(5) file is discussed separately. | ||||
|  .SH OMAPI | ||||
							
								
								
									
										83
									
								
								net-misc/dhcp/files/dhcp-3.0.4-dhclient-stdin-conf.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										83
									
								
								net-misc/dhcp/files/dhcp-3.0.4-dhclient-stdin-conf.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,83 @@ | ||||
| --- common/conflex.c.orig	2006-02-21 16:21:45.000000000 +0000 | ||||
| +++ common/conflex.c	2006-02-21 16:23:06.000000000 +0000 | ||||
| @@ -90,7 +90,7 @@ | ||||
|  	struct parse **cfile; | ||||
|  { | ||||
|  	/* "Memory" config files have no file. */ | ||||
| -	if ((*cfile)->file != -1) | ||||
| +	if ((*cfile)->file != -1 && (*cfile)->file != fileno(stdin)) | ||||
|  		close((*cfile)->file); | ||||
|   | ||||
|  	if ((*cfile)->bufsiz) | ||||
| --- client/clparse.c.orig	2006-02-22 09:37:12.000000000 +0000 | ||||
| +++ client/clparse.c	2006-02-22 09:38:26.000000000 +0000 | ||||
| @@ -97,6 +97,11 @@ | ||||
|  	status = read_client_conf_file (path_dhclient_conf, | ||||
|  					(struct interface_info *)0, | ||||
|  					&top_level_config); | ||||
| + | ||||
| +	/* Read any extra configuration from stdin */ | ||||
| +	read_client_conf_stdin ((struct interface_info *)0, | ||||
| +					&top_level_config); | ||||
| +	 | ||||
|  	if (status != ISC_R_SUCCESS) { | ||||
|  		; | ||||
|  #ifdef LATER | ||||
| @@ -148,20 +153,17 @@ | ||||
|  	return status; | ||||
|  } | ||||
|   | ||||
| -int read_client_conf_file (const char *name, struct interface_info *ip, | ||||
| -			   struct client_config *client) | ||||
| +int read_client_conf_actual (int file, const char *name,  | ||||
| +			     struct interface_info *ip, | ||||
| +			     struct client_config *client) | ||||
|  { | ||||
| -	int file; | ||||
|  	struct parse *cfile; | ||||
|  	const char *val; | ||||
|  	int token; | ||||
|  	isc_result_t status; | ||||
|  	 | ||||
| -	if ((file = open (name, O_RDONLY)) < 0) | ||||
| -		return uerr2isc (errno); | ||||
| - | ||||
|  	cfile = (struct parse *)0; | ||||
| -	new_parse (&cfile, file, (char *)0, 0, path_dhclient_conf, 0); | ||||
| +	new_parse (&cfile, file, (char *)0, 0, name , 0); | ||||
|   | ||||
|  	do { | ||||
|  		token = peek_token (&val, (unsigned *)0, cfile); | ||||
| @@ -177,6 +179,32 @@ | ||||
|  	return status; | ||||
|  } | ||||
|   | ||||
| +int read_client_conf_file (const char *name, struct interface_info *ip, | ||||
| +			   struct client_config *client) | ||||
| +{ | ||||
| +	int file; | ||||
| +	isc_result_t status; | ||||
| +	 | ||||
| +	if ((file = open (name, O_RDONLY)) < 0) | ||||
| +		return uerr2isc (errno); | ||||
| + | ||||
| +	status = read_client_conf_actual(file, name, ip, client); | ||||
| + | ||||
| +	return status; | ||||
| +} | ||||
| + | ||||
| + | ||||
| +int read_client_conf_stdin (struct interface_info *ip, | ||||
| +			    struct client_config *client) | ||||
| +{ | ||||
| +	int file = fileno(stdin); | ||||
| +	isc_result_t status; | ||||
| + | ||||
| +	if (isatty(file)) return ISC_R_NOTFOUND; | ||||
| +	status = read_client_conf_actual(file, "stdin", ip, client); | ||||
| + | ||||
| +	return status; | ||||
| +} | ||||
|   | ||||
|  /* lease-file :== client-lease-statements END_OF_FILE | ||||
|     client-lease-statements :== <nil> | ||||
							
								
								
									
										44
									
								
								net-misc/dhcp/files/dhcp-3.0.5-bpf-nofallback.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										44
									
								
								net-misc/dhcp/files/dhcp-3.0.5-bpf-nofallback.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,44 @@ | ||||
| diff -ur common.orig/bpf.c common/bpf.c | ||||
| --- common.orig/bpf.c	2006-09-20 12:52:47 +0100 | ||||
| +++ common/bpf.c	2006-09-20 12:53:22 +0100 | ||||
| @@ -354,10 +354,6 @@ | ||||
|  	int result; | ||||
|  	int fudge; | ||||
|   | ||||
| -	if (!strcmp (interface -> name, "fallback")) | ||||
| -		return send_fallback (interface, packet, raw, | ||||
| -				      len, from, to, hto); | ||||
| - | ||||
|  	/* Assemble the headers... */ | ||||
|  	assemble_hw_header (interface, (unsigned char *)hw, &hbufp, hto); | ||||
|  	assemble_udp_ip_header (interface, | ||||
| @@ -531,17 +527,5 @@ | ||||
|   | ||||
|  void maybe_setup_fallback () | ||||
|  { | ||||
| -	isc_result_t status; | ||||
| -	struct interface_info *fbi = (struct interface_info *)0; | ||||
| -	if (setup_fallback (&fbi, MDL)) { | ||||
| -		if_register_fallback (fbi); | ||||
| -		status = omapi_register_io_object ((omapi_object_t *)fbi, | ||||
| -						   if_readsocket, 0, | ||||
| -						   fallback_discard, 0, 0); | ||||
| -		if (status != ISC_R_SUCCESS) | ||||
| -			log_fatal ("Can't register I/O handle for %s: %s", | ||||
| -				   fbi -> name, isc_result_totext (status)); | ||||
| -		interface_dereference (&fbi, MDL); | ||||
| -	} | ||||
|  } | ||||
|  #endif | ||||
| diff -ur includes.orig/osdep.h includes/osdep.h | ||||
| --- includes.orig/osdep.h	2006-09-20 12:54:52 +0100 | ||||
| +++ includes/osdep.h	2006-09-20 12:56:40 +0100 | ||||
| @@ -190,7 +190,7 @@ | ||||
|     Currently, all low-level packet interfaces use BSD sockets as a | ||||
|     fallback. */ | ||||
|   | ||||
| -#if defined (USE_BPF_SEND) || defined (USE_NIT_SEND) || \ | ||||
| +#if defined (USE_NIT_SEND) || \ | ||||
|      defined (USE_DLPI_SEND) || defined (USE_UPF_SEND) || \ | ||||
|      defined (USE_LPF_SEND) || \ | ||||
|      (defined (USE_SOCKET_SEND) && defined (HAVE_SO_BINDTODEVICE)) | ||||
							
								
								
									
										5514
									
								
								net-misc/dhcp/files/dhcp-3.1.0-ldap.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5514
									
								
								net-misc/dhcp/files/dhcp-3.1.0-ldap.patch
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										254
									
								
								net-misc/dhcp/files/dhcp-3.1.0a1-dhclient-resolvconf.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										254
									
								
								net-misc/dhcp/files/dhcp-3.1.0a1-dhclient-resolvconf.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,254 @@ | ||||
| diff -ur client.orig/scripts/bsdos client/scripts/bsdos | ||||
| --- client.orig/scripts/bsdos	2006-09-07 18:53:10.476329752 +0100 | ||||
| +++ client/scripts/bsdos	2006-09-07 19:19:53.000000000 +0100 | ||||
| @@ -1,21 +1,22 @@ | ||||
|  #!/bin/sh | ||||
|   | ||||
|  make_resolv_conf() { | ||||
| -  if [ x"$new_domain_name_servers" != x ]; then | ||||
| -    cat /dev/null > /etc/resolv.conf.dhclient | ||||
| -    if [ "x$new_domain_search" != x ]; then | ||||
| -      echo search $new_domain_search >> /etc/resolv.conf.dhclient | ||||
| -    elif [ "x$new_domain_name" != x ]; then | ||||
| -      # Note that the DHCP 'Domain Name Option' is really just a domain | ||||
| -      # name, and that this practice of using the domain name option as | ||||
| -      # a search path is both nonstandard and deprecated. | ||||
| -      echo search $new_domain_name >> /etc/resolv.conf.dhclient | ||||
| +  if [ x$PEER_DNS = x ] || [ x$PEER_DNS = xyes ]; then | ||||
| +    if [ "x$new_domain_name" != x ] || [ "x$new_domain_name_servers" != x ]; then | ||||
| +      conf="# Generated by dhclient for interface $interface\n" | ||||
| +      if [ "x$new_domain_name" != x ]; then | ||||
| +        conf="${conf}search $new_domain_name\n" | ||||
| +      fi | ||||
| +      for nameserver in $new_domain_name_servers; do | ||||
| +        conf="${conf}nameserver $nameserver\n" | ||||
| +      done | ||||
| +      if [ -x /sbin/resolvconf ]; then | ||||
| +        printf "$conf" | resolvconf -a "$interface" | ||||
| +      else | ||||
| +        printf "$conf" > /etc/resolv.conf | ||||
| +        chmod 644 /etc/resolv.conf | ||||
| +      fi | ||||
|      fi | ||||
| -    for nameserver in $new_domain_name_servers; do | ||||
| -      echo nameserver $nameserver >> /etc/resolv.conf.dhclient | ||||
| -    done | ||||
| - | ||||
| -    mv /etc/resolv.conf.dhclient /etc/resolv.conf | ||||
|    fi | ||||
|    # If we're making confs, may as well make an ntp.conf too | ||||
|    make_ntp_conf | ||||
| diff -ur client.orig/scripts/freebsd client/scripts/freebsd | ||||
| --- client.orig/scripts/freebsd	2006-09-07 18:53:10.476329752 +0100 | ||||
| +++ client/scripts/freebsd	2006-09-07 19:19:32.000000000 +0100 | ||||
| @@ -11,38 +11,20 @@ | ||||
|  fi | ||||
|   | ||||
|  make_resolv_conf() { | ||||
| -  if [ x"$new_domain_name_servers" != x ]; then | ||||
| -    ( cat /dev/null > /etc/resolv.conf.dhclient ) | ||||
| -    exit_status=$? | ||||
| -    if [ $exit_status -ne 0 ]; then | ||||
| -      $LOGGER "Unable to create /etc/resolv.conf.dhclient: Error $exit_status" | ||||
| -    else | ||||
| -      if [ "x$new_domain_search" != x ]; then | ||||
| -	( echo search $new_domain_search >> /etc/resolv.conf.dhclient ) | ||||
| -	exit_status=$? | ||||
| -      elif [ "x$new_domain_name" != x ]; then | ||||
| -	# Note that the DHCP 'Domain Name Option' is really just a domain | ||||
| -	# name, and that this practice of using the domain name option as | ||||
| -	# a search path is both nonstandard and deprecated. | ||||
| -	( echo search $new_domain_name >> /etc/resolv.conf.dhclient ) | ||||
| -	exit_status=$? | ||||
| +  if [ x$PEER_DNS = x ] || [ x$PEER_DNS = xyes ]; then | ||||
| +    if [ "x$new_domain_name" != x ] || [ "x$new_domain_name_servers" != x ]; then | ||||
| +      conf="# Generated by dhclient for interface $interface\n" | ||||
| +      if [ "x$new_domain_name" != x ]; then | ||||
| +        conf="${conf}search $new_domain_name\n" | ||||
|        fi | ||||
|        for nameserver in $new_domain_name_servers; do | ||||
| -	if [ $exit_status -ne 0 ]; then | ||||
| -	  break | ||||
| -	fi | ||||
| -	( echo nameserver $nameserver >>/etc/resolv.conf.dhclient ) | ||||
| -	exit_status=$? | ||||
| +        conf="${conf}nameserver $nameserver\n" | ||||
|        done | ||||
| - | ||||
| -      # If there were no errors, attempt to mv the new file into place. | ||||
| -      if [ $exit_status -eq 0 ]; then | ||||
| -	( mv /etc/resolv.conf.dhclient /etc/resolv.conf ) | ||||
| -	exit_status = $? | ||||
| -      fi | ||||
| - | ||||
| -      if [ $exit_status -ne 0 ]; then | ||||
| -	$LOGGER "Error while writing new /etc/resolv.conf." | ||||
| +      if [ -x /sbin/resolvconf ]; then | ||||
| +        printf "$conf" | resolvconf -a "$interface" | ||||
| +      else | ||||
| +        printf "$conf" > /etc/resolv.conf | ||||
| +        chmod 644 /etc/resolv.conf | ||||
|        fi | ||||
|      fi | ||||
|    fi | ||||
| diff -ur client.orig/scripts/linux client/scripts/linux | ||||
| --- client.orig/scripts/linux	2006-09-07 18:53:10.476329752 +0100 | ||||
| +++ client/scripts/linux	2006-09-07 19:18:57.000000000 +0100 | ||||
| @@ -23,22 +23,22 @@ | ||||
|  # of the $1 in its args. | ||||
|   | ||||
|  make_resolv_conf() { | ||||
| -  if [ x"$new_domain_name_servers" != x ]; then | ||||
| -    cat /dev/null > /etc/resolv.conf.dhclient | ||||
| -    chmod 644 /etc/resolv.conf.dhclient | ||||
| -    if [ x"$new_domain_search" != x ]; then | ||||
| -      echo search $new_domain_search >> /etc/resolv.conf.dhclient | ||||
| -    elif [ x"$new_domain_name" != x ]; then | ||||
| -      # Note that the DHCP 'Domain Name Option' is really just a domain | ||||
| -      # name, and that this practice of using the domain name option as | ||||
| -      # a search path is both nonstandard and deprecated. | ||||
| -      echo search $new_domain_name >> /etc/resolv.conf.dhclient | ||||
| +  if [ x$PEER_DNS = x ] || [ x$PEER_DNS = xyes ]; then | ||||
| +    if [ "x$new_domain_name" != x ] || [ "x$new_domain_name_servers" != x ]; then | ||||
| +      conf="# Generated by dhclient for interface $interface\n" | ||||
| +      if [ "x$new_domain_name" != x ]; then | ||||
| +        conf="${conf}search $new_domain_name\n" | ||||
| +      fi | ||||
| +      for nameserver in $new_domain_name_servers; do | ||||
| +        conf="${conf}nameserver $nameserver\n" | ||||
| +      done | ||||
| +      if [ -x /sbin/resolvconf ]; then | ||||
| +        printf "$conf" | resolvconf -a "$interface" | ||||
| +      else | ||||
| +        printf "$conf" > /etc/resolv.conf | ||||
| +        chmod 644 /etc/resolv.conf | ||||
| +      fi | ||||
|      fi | ||||
| -    for nameserver in $new_domain_name_servers; do | ||||
| -      echo nameserver $nameserver >>/etc/resolv.conf.dhclient | ||||
| -    done | ||||
| - | ||||
| -    mv /etc/resolv.conf.dhclient /etc/resolv.conf | ||||
|    fi | ||||
|    # If we're making confs, may as well make an ntp.conf too | ||||
|    make_ntp_conf | ||||
| diff -ur client.orig/scripts/netbsd client/scripts/netbsd | ||||
| --- client.orig/scripts/netbsd	2006-09-07 18:53:10.476329752 +0100 | ||||
| +++ client/scripts/netbsd	2006-09-07 19:20:10.000000000 +0100 | ||||
| @@ -1,21 +1,22 @@ | ||||
|  #!/bin/sh | ||||
|   | ||||
|  make_resolv_conf() { | ||||
| -  if [ "x$new_domain_name" != x ] && [ x"$new_domain_name_servers" != x ]; then | ||||
| -    cat /dev/null > /etc/resolv.conf.dhclient | ||||
| -    if [ "x$new_domain_search != x ]; then | ||||
| -      echo search $new_domain_search >> /etc/resolv.conf.dhclient | ||||
| -    elif [ "x$new_domain_name != x ]; then | ||||
| -      # Note that the DHCP 'Domain Name Option' is really just a domain | ||||
| -      # name, and that this practice of using the domain name option as | ||||
| -      # a search path is both nonstandard and deprecated. | ||||
| -      echo search $new_domain_name >> /etc/resolv.conf.dhclient | ||||
| +  if [ x$PEER_DNS = x ] || [ x$PEER_DNS = xyes ]; then | ||||
| +    if [ "x$new_domain_name" != x ] || [ "x$new_domain_name_servers" != x ]; then | ||||
| +      conf="# Generated by dhclient for interface $interface\n" | ||||
| +      if [ "x$new_domain_name" != x ]; then | ||||
| +        conf="${conf}search $new_domain_name\n" | ||||
| +      fi | ||||
| +      for nameserver in $new_domain_name_servers; do | ||||
| +        conf="${conf}nameserver $nameserver\n" | ||||
| +      done | ||||
| +      if [ -x /sbin/resolvconf ]; then | ||||
| +        printf "$conf" | resolvconf -a "$interface" | ||||
| +      else | ||||
| +        printf "$conf" > /etc/resolv.conf | ||||
| +        chmod 644 /etc/resolv.conf | ||||
| +      fi | ||||
|      fi | ||||
| -    for nameserver in $new_domain_name_servers; do | ||||
| -      echo nameserver $nameserver >>/etc/resolv.conf.dhclient | ||||
| -    done | ||||
| - | ||||
| -    mv /etc/resolv.conf.dhclient /etc/resolv.conf | ||||
|    fi | ||||
|    # If we're making confs, may as well make an ntp.conf too | ||||
|    make_ntp_conf | ||||
| diff -ur client.orig/scripts/openbsd client/scripts/openbsd | ||||
| --- client.orig/scripts/openbsd	2006-09-07 18:53:10.476329752 +0100 | ||||
| +++ client/scripts/openbsd	2006-09-07 19:20:38.000000000 +0100 | ||||
| @@ -1,21 +1,22 @@ | ||||
|  #!/bin/sh | ||||
|   | ||||
|  make_resolv_conf() { | ||||
| -  if x"$new_domain_name_servers" != x ]; then | ||||
| -    cat /dev/null > /etc/resolv.conf.dhclient | ||||
| -    if [ x"$new_domain_search" != x ]; then | ||||
| -      echo search $new_domain_search >> /etc/resolv.conf.dhclient | ||||
| -    elif [ x"$new_domain_name" != x ]; then | ||||
| -      # Note that the DHCP 'Domain Name Option' is really just a domain | ||||
| -      # name, and that this practice of using the domain name option as | ||||
| -      # a search path is both nonstandard and deprecated. | ||||
| -      echo search $new_domain_name >> /etc/resolv.conf.dhclient | ||||
| +  if [ x$PEER_DNS = x ] || [ x$PEER_DNS = xyes ]; then | ||||
| +    if [ "x$new_domain_name" != x ] || [ "x$new_domain_name_servers" != x ]; then | ||||
| +      conf="# Generated by dhclient for interface $interface\n" | ||||
| +      if [ "x$new_domain_name" != x ]; then | ||||
| +        conf="${conf}search $new_domain_name\n" | ||||
| +      fi | ||||
| +      for nameserver in $new_domain_name_servers; do | ||||
| +        conf="${conf}nameserver $nameserver\n" | ||||
| +      done | ||||
| +      if [ -x /sbin/resolvconf ]; then | ||||
| +        printf "$conf" | resolvconf -a "$interface" | ||||
| +      else | ||||
| +        printf "$conf" > /etc/resolv.conf | ||||
| +        chmod 644 /etc/resolv.conf | ||||
| +      fi | ||||
|      fi | ||||
| -    for nameserver in $new_domain_name_servers; do | ||||
| -      echo nameserver $nameserver >>/etc/resolv.conf.dhclient | ||||
| -    done | ||||
| - | ||||
| -    mv /etc/ersolv.conf.dhclient /etc/resolv.conf | ||||
|    fi | ||||
|    # If we're making confs, may as well make an ntp.conf too | ||||
|    make_ntp_conf | ||||
| diff -ur client.orig/scripts/solaris client/scripts/solaris | ||||
| --- client.orig/scripts/solaris	2006-09-07 18:53:10.476329752 +0100 | ||||
| +++ client/scripts/solaris	2006-09-07 19:21:12.000000000 +0100 | ||||
| @@ -1,21 +1,22 @@ | ||||
|  #!/bin/sh   | ||||
|   | ||||
|  make_resolv_conf() { | ||||
| -  if [ x"$new_domain_name_servers" != x ]; then | ||||
| -    cat /dev/null > /etc/resolv.conf.dhclient | ||||
| -    if [ x"$new_domain_search" != x ]; then | ||||
| -      echo search $new_domain_search >> /etc/resolv.conf.dhclient | ||||
| -    elif [ x"$new_domain_name" != x ]; then | ||||
| -      # Note that the DHCP 'Domain Name Option' is really just a domain | ||||
| -      # name, and that this practice of using the domain name option as | ||||
| -      # a search path is both nonstandard and deprecated. | ||||
| -      echo search $new_domain_name >> /etc/resolv.conf.dhclient | ||||
| +  if [ x$PEER_DNS = x ] || [ x$PEER_DNS = xyes ]; then | ||||
| +    if [ "x$new_domain_name" != x ] || [ "x$new_domain_name_servers" != x ]; then | ||||
| +      conf="# Generated by dhclient for interface $interface\n" | ||||
| +      if [ "x$new_domain_name" != x ]; then | ||||
| +        conf="${conf}search $new_domain_name\n" | ||||
| +      fi | ||||
| +      for nameserver in $new_domain_name_servers; do | ||||
| +        conf="${conf}nameserver $nameserver\n" | ||||
| +      done | ||||
| +      if [ -x /sbin/resolvconf ]; then | ||||
| +        printf "$conf" | resolvconf -a "$interface" | ||||
| +      else | ||||
| +        printf "$conf" > /etc/resolv.conf | ||||
| +        chmod 644 /etc/resolv.conf | ||||
| +      fi | ||||
|      fi | ||||
| -    for nameserver in $new_domain_name_servers; do | ||||
| -      echo nameserver $nameserver >>/etc/resolv.conf.dhclient | ||||
| -    done | ||||
| - | ||||
| -    mv /etc/resolv.conf.dhclient /etc/resolv.conf | ||||
|    fi | ||||
|    # If we're making confs, may as well make an ntp.conf too | ||||
|    make_ntp_conf | ||||
							
								
								
									
										29
									
								
								net-misc/dhcp/files/dhcpd.conf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								net-misc/dhcp/files/dhcpd.conf
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,29 @@ | ||||
| # /etc/conf.d/dhcpd: config file for /etc/init.d/dhcpd | ||||
|  | ||||
| # If you require more than one instance of dhcpd you can create symbolic | ||||
| # links to dhcpd service like so | ||||
| #   cd /etc/init.d | ||||
| #   ln -s dhcpd dhcpd.foo | ||||
| #   cd ../conf.d | ||||
| #   cp dhcpd dhcpd.foo | ||||
| # Now you can edit dhcpd.foo and specify a different configuration file. | ||||
| # You'll also need to specify a pidfile in that dhcpd.conf file. | ||||
| # See the pid-file-name option in the dhcpd.conf man page for details. | ||||
|  | ||||
| # If you wish to run dhcpd in a chroot, uncomment the following line | ||||
| # DHCPD_CHROOT="/chroot/dhcp" | ||||
|  | ||||
| # Then run emerge dhcp --config | ||||
| # All file paths below are relative to the chroot. | ||||
| # You can specify a different chroot directory but MAKE SURE it's empty. | ||||
|  | ||||
| # Specify a configuration file - the default is /etc/dhcp/dhcpd.conf | ||||
| # DHCPD_CONF="/etc/dhcp/dhcpd.conf" | ||||
|  | ||||
| # Configure which interface or interfaces to for dhcpd to listen on. | ||||
| # List all interfaces space separated. If this is not specified then | ||||
| # we listen on all interfaces. | ||||
| # DHCPD_IFACE="" | ||||
|  | ||||
| # Insert any other dhcpd options - see the man page for a full list. | ||||
| # DHCPD_OPTS="" | ||||
							
								
								
									
										71
									
								
								net-misc/dhcp/files/dhcpd.init
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										71
									
								
								net-misc/dhcp/files/dhcpd.init
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,71 @@ | ||||
| #!/sbin/runscript | ||||
| # Copyright 1999-2006 Gentoo Foundation | ||||
| # Distributed under the terms of the GNU General Public License v2 | ||||
| # $Header: /var/cvsroot/gentoo-x86/net-misc/dhcp/files/dhcpd.init,v 1.5 2007/04/02 12:34:01 uberlord Exp $ | ||||
|  | ||||
| DHCPD_CONF=${DHCPD_CONF:-/etc/dhcp/dhcpd.conf} | ||||
|  | ||||
| depend() { | ||||
| 	need net | ||||
| 	use logger dns | ||||
| } | ||||
|  | ||||
| get_var() { | ||||
| 	sed -n 's/^[[:blank:]]\?'"$1"' "*\([^#";]\+\).*/\1/p' \ | ||||
| 		"${DHCPD_CHROOT}/${DHCPD_CONF}" | ||||
| } | ||||
|  | ||||
| start() { | ||||
| 	# Work out our cffile if it's on our DHCPD_OPTS | ||||
| 	case " ${DHCPD_OPTS} " in | ||||
| 		*" -cf "*)  | ||||
| 			DHCPD_CONF=" ${DHCPD_OPTS} " | ||||
| 			DHCPD_CONF="${DHCPD_CONF##* -cf }" | ||||
| 			DHCPD_CONF="${DHCPD_CONF%% *}" | ||||
| 			;; | ||||
| 		*)	DHCPD_OPTS="${DHCPD_OPTS} -cf ${DHCPD_CONF}" | ||||
| 			;; | ||||
| 	esac | ||||
|  | ||||
| 	if [ ! -f "${DHCPD_CHROOT}/${DHCPD_CONF}" ] ; then | ||||
| 		eerror "${DHCPD_CHROOT}/${DHCPD_CONF} does not exist" | ||||
| 		return 1 | ||||
| 	fi | ||||
|  | ||||
| 	local leasefile="$(get_var lease-file-name)" | ||||
| 	leasefile="${DHCPD_CHROOT}/${leasefile:-/var/lib/dhcp/dhcpd.leases}" | ||||
| 	if [ ! -f "${leasefile}" ] ; then | ||||
| 		ebegin "Creating ${leasefile}" | ||||
| 		touch "${leasefile}" | ||||
| 		chown dhcp:dhcp "${leasefile}" | ||||
| 		eend $? || return 1 | ||||
| 	fi | ||||
|  | ||||
| 	# Setup LD_PRELOAD so name resolution works in our chroot. | ||||
| 	if [ -n "${DHCPD_CHROOT}" ] ; then | ||||
| 	    LD_PRELOAD="${LD_PRELOAD} /usr/lib/libresolv.so" | ||||
| 	    export LD_PRELOAD="${LD_PRELOAD} /usr/lib/libnss_dns.so" | ||||
| 	fi | ||||
|  | ||||
| 	local pidfile="$(get_var pid-file-name)" | ||||
| 	pidfile="${pidfile:-/var/run/dhcp/dhcpd.pid}" | ||||
|  | ||||
| 	ebegin "Starting ${DHCPD_CHROOT:+chrooted }${SVCNAME}" | ||||
| 	start-stop-daemon --start --exec /usr/sbin/dhcpd \ | ||||
| 		--pidfile "${DHCPD_CHROOT}/${pidfile}" \ | ||||
| 		-- ${DHCPD_OPTS} -q -pf "${pidfile}" \ | ||||
| 		-user dhcp -group dhcp \ | ||||
| 		${DHCPD_CHROOT:+-chroot} ${DHCPD_CHROOT} ${DHCPD_IFACE} | ||||
| 	eend $? \ | ||||
| 	    && save_options chroot "${DHCPD_CHROOT}" \ | ||||
| 	    && save_options pidfile "${pidfile}" | ||||
| } | ||||
|  | ||||
| stop() { | ||||
| 	local chroot="$(get_options chroot)" | ||||
|  | ||||
| 	ebegin "Stopping ${chroot:+chrooted }${SVCNAME}" | ||||
| 	start-stop-daemon --stop --exec /usr/sbin/dhcpd \ | ||||
| 	    --pidfile "${chroot}/$(get_options pidfile)" | ||||
| 	eend $? | ||||
| } | ||||
							
								
								
									
										13
									
								
								net-misc/dhcp/files/dhcrelay.conf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								net-misc/dhcp/files/dhcrelay.conf
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,13 @@ | ||||
| # /etc/conf.d/dhcrelay: config file for /etc/init.d/dhcrelay | ||||
|  | ||||
| # Configure which interface or interfaces to for dhcrelay to listen on | ||||
| # and send to. | ||||
| # List all interfaces space separated. If this is not specified then | ||||
| # we use all interfaces. | ||||
| #IFACE="" | ||||
|  | ||||
| # Insert any other options needed.  See dhcrelay(8) for details. | ||||
| #DHCRELAY_OPTS="" | ||||
|  | ||||
| # Space separated list of IPs to forward BOOTP/DHCP packets to. | ||||
| DHCRELAY_SERVERS="" | ||||
							
								
								
									
										32
									
								
								net-misc/dhcp/files/dhcrelay.init
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										32
									
								
								net-misc/dhcp/files/dhcrelay.init
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,32 @@ | ||||
| #!/sbin/runscript | ||||
| # Copyright 1999-2004 Gentoo Foundation | ||||
| # Distributed under the terms of the GNU General Public License v2 | ||||
| # $Header: /var/cvsroot/gentoo-x86/net-misc/dhcp/files/dhcrelay.init,v 1.2 2007/03/22 15:36:59 uberlord Exp $ | ||||
|  | ||||
| depend() { | ||||
| 	need net | ||||
| 	use logger | ||||
| } | ||||
|  | ||||
| start() { | ||||
| 	if [ -z "${DHCRELAY_SERVERS}" ]; then | ||||
| 		eerror "No DHCRELAY_SERVERS specified in /etc/conf.d/dhcrelay" | ||||
| 		return 1 | ||||
| 	fi | ||||
|  | ||||
| 	local IFACES= i= | ||||
| 	for i in ${IFACE} ; do | ||||
| 		IFACES="${IFACES} -i ${i}" | ||||
| 	done | ||||
|  | ||||
| 	ebegin "Starting dhcrelay" | ||||
| 	start-stop-daemon --start --exec /usr/sbin/dhcrelay \ | ||||
| 		-- -q ${IFACES} ${DHCRELAY_OPTS} ${DHCRELAY_SERVERS} | ||||
| 	eend $? | ||||
| } | ||||
|  | ||||
| stop() { | ||||
| 	ebegin "Stopping dhcrelay" | ||||
| 	start-stop-daemon --stop --pidfile /var/run/dhcrelay.pid | ||||
| 	eend $? | ||||
| } | ||||
		Reference in New Issue
	
	Block a user