mirror of
				https://git.proxmox.com/git/mirror_frr
				synced 2025-10-26 10:20:36 +00:00 
			
		
		
		
	Merge pull request #926 from opensourcerouting/tcp-zebra
remove `--enable-tcp-zebra`
This commit is contained in:
		
						commit
						3cc2066899
					
				| @ -322,8 +322,6 @@ AC_ARG_ENABLE(snmp, | |||||||
|   AS_HELP_STRING([--enable-snmp=ARG], [enable SNMP support (smux or agentx)])) |   AS_HELP_STRING([--enable-snmp=ARG], [enable SNMP support (smux or agentx)])) | ||||||
| AC_ARG_WITH(libpam, | AC_ARG_WITH(libpam, | ||||||
|   AS_HELP_STRING([--with-libpam], [use libpam for PAM support in vtysh])) |   AS_HELP_STRING([--with-libpam], [use libpam for PAM support in vtysh])) | ||||||
| AC_ARG_ENABLE(tcp-zebra, |  | ||||||
|   AS_HELP_STRING([--enable-tcp-zebra], [enable TCP/IP socket connection between zebra and protocol daemon])) |  | ||||||
| AC_ARG_ENABLE(ospfapi, | AC_ARG_ENABLE(ospfapi, | ||||||
|   AS_HELP_STRING([--disable-ospfapi], [do not build OSPFAPI to access the OSPF LSA Database])) |   AS_HELP_STRING([--disable-ospfapi], [do not build OSPFAPI to access the OSPF LSA Database])) | ||||||
| AC_ARG_ENABLE(ospfclient, | AC_ARG_ENABLE(ospfclient, | ||||||
| @ -560,10 +558,6 @@ AM_CONDITIONAL([HAVE_PROTOBUF], [test "x$have_protobuf" = "xyes"]) | |||||||
| # End of logic for protobuf support. | # End of logic for protobuf support. | ||||||
| # | # | ||||||
| 
 | 
 | ||||||
| if test "${enable_tcp_zebra}" = "yes"; then |  | ||||||
|   AC_DEFINE(HAVE_TCP_ZEBRA,,Use TCP for zebra communication) |  | ||||||
| fi |  | ||||||
| 
 |  | ||||||
| if test "${enable_linux24_tcp_md5}" = "yes"; then | if test "${enable_linux24_tcp_md5}" = "yes"; then | ||||||
|   AC_DEFINE(HAVE_TCP_MD5_LINUX24,,Old Linux 2.4 TCP MD5 Signature Patch) |   AC_DEFINE(HAVE_TCP_MD5_LINUX24,,Old Linux 2.4 TCP MD5 Signature Patch) | ||||||
| fi | fi | ||||||
|  | |||||||
| @ -109,7 +109,6 @@ an example.) | |||||||
|         --enable-rtadv \ |         --enable-rtadv \ | ||||||
|         --disable-exampledir \ |         --disable-exampledir \ | ||||||
|         --enable-watchfrr \ |         --enable-watchfrr \ | ||||||
|         --enable-tcp-zebra \ |  | ||||||
|         --disable-ldpd \ |         --disable-ldpd \ | ||||||
|         --enable-fpm \ |         --enable-fpm \ | ||||||
|         --enable-nhrpd \ |         --enable-nhrpd \ | ||||||
|  | |||||||
| @ -61,7 +61,6 @@ an example.) | |||||||
|         --enable-rtadv \ |         --enable-rtadv \ | ||||||
|         --disable-exampledir \ |         --disable-exampledir \ | ||||||
|         --enable-watchfrr \ |         --enable-watchfrr \ | ||||||
|         --enable-tcp-zebra \ |  | ||||||
|         --disable-ldpd \ |         --disable-ldpd \ | ||||||
|         --enable-fpm \ |         --enable-fpm \ | ||||||
|         --enable-nhrpd \ |         --enable-nhrpd \ | ||||||
|  | |||||||
| @ -60,7 +60,6 @@ an example.) | |||||||
|         --enable-configfile-mask=0640 \ |         --enable-configfile-mask=0640 \ | ||||||
|         --enable-logfile-mask=0640 \ |         --enable-logfile-mask=0640 \ | ||||||
|         --enable-rtadv \ |         --enable-rtadv \ | ||||||
|         --enable-tcp-zebra \ |  | ||||||
|         --enable-fpm \ |         --enable-fpm \ | ||||||
|         --enable-ldpd \ |         --enable-ldpd \ | ||||||
|         --with-pkg-git-version \ |         --with-pkg-git-version \ | ||||||
|  | |||||||
| @ -54,7 +54,6 @@ an example.) | |||||||
|         --enable-rtadv \ |         --enable-rtadv \ | ||||||
|         --disable-exampledir \ |         --disable-exampledir \ | ||||||
|         --enable-watchfrr \ |         --enable-watchfrr \ | ||||||
|         --enable-tcp-zebra \ |  | ||||||
|         --enable-ldpd \ |         --enable-ldpd \ | ||||||
|         --enable-fpm \ |         --enable-fpm \ | ||||||
|         --enable-nhrpd \ |         --enable-nhrpd \ | ||||||
|  | |||||||
| @ -61,7 +61,6 @@ an example) | |||||||
|         --enable-configfile-mask=0640 \ |         --enable-configfile-mask=0640 \ | ||||||
|         --enable-logfile-mask=0640 \ |         --enable-logfile-mask=0640 \ | ||||||
|         --enable-rtadv \ |         --enable-rtadv \ | ||||||
|         --enable-tcp-zebra \ |  | ||||||
|         --enable-fpm \ |         --enable-fpm \ | ||||||
|         --with-pkg-git-version \ |         --with-pkg-git-version \ | ||||||
|         --with-pkg-extra-version=-MyOwnFRRVersion    |         --with-pkg-extra-version=-MyOwnFRRVersion    | ||||||
|  | |||||||
| @ -61,7 +61,6 @@ an example) | |||||||
|         --enable-configfile-mask=0640 \ |         --enable-configfile-mask=0640 \ | ||||||
|         --enable-logfile-mask=0640 \ |         --enable-logfile-mask=0640 \ | ||||||
|         --enable-rtadv \ |         --enable-rtadv \ | ||||||
|         --enable-tcp-zebra \ |  | ||||||
|         --enable-fpm \ |         --enable-fpm \ | ||||||
|         --with-pkg-git-version \ |         --with-pkg-git-version \ | ||||||
|         --with-pkg-extra-version=-MyOwnFRRVersion    |         --with-pkg-extra-version=-MyOwnFRRVersion    | ||||||
|  | |||||||
| @ -69,7 +69,6 @@ an example) | |||||||
|         --enable-configfile-mask=0640 \ |         --enable-configfile-mask=0640 \ | ||||||
|         --enable-logfile-mask=0640 \ |         --enable-logfile-mask=0640 \ | ||||||
|         --enable-rtadv \ |         --enable-rtadv \ | ||||||
|         --enable-tcp-zebra \ |  | ||||||
|         --enable-fpm \ |         --enable-fpm \ | ||||||
|         --with-pkg-git-version \ |         --with-pkg-git-version \ | ||||||
|         --with-pkg-extra-version=-MyOwnFRRVersion    |         --with-pkg-extra-version=-MyOwnFRRVersion    | ||||||
|  | |||||||
| @ -65,7 +65,6 @@ an example) | |||||||
|         --enable-configfile-mask=0640 \ |         --enable-configfile-mask=0640 \ | ||||||
|         --enable-logfile-mask=0640 \ |         --enable-logfile-mask=0640 \ | ||||||
|         --enable-rtadv \ |         --enable-rtadv \ | ||||||
|         --enable-tcp-zebra \ |  | ||||||
|         --enable-fpm \ |         --enable-fpm \ | ||||||
|         --with-pkg-git-version \ |         --with-pkg-git-version \ | ||||||
|         --with-pkg-extra-version=-MyOwnFRRVersion    |         --with-pkg-extra-version=-MyOwnFRRVersion    | ||||||
|  | |||||||
| @ -59,7 +59,6 @@ an example) | |||||||
|         --enable-configfile-mask=0640 \ |         --enable-configfile-mask=0640 \ | ||||||
|         --enable-logfile-mask=0640 \ |         --enable-logfile-mask=0640 \ | ||||||
|         --enable-rtadv \ |         --enable-rtadv \ | ||||||
|         --enable-tcp-zebra \ |  | ||||||
|         --enable-fpm \ |         --enable-fpm \ | ||||||
|         --with-pkg-git-version \ |         --with-pkg-git-version \ | ||||||
|         --with-pkg-extra-version=-MyOwnFRRVersion    |         --with-pkg-extra-version=-MyOwnFRRVersion    | ||||||
|  | |||||||
| @ -104,7 +104,6 @@ an example) | |||||||
|         --enable-configfile-mask=0640 \ |         --enable-configfile-mask=0640 \ | ||||||
|         --enable-logfile-mask=0640 \ |         --enable-logfile-mask=0640 \ | ||||||
|         --enable-rtadv \ |         --enable-rtadv \ | ||||||
|         --enable-tcp-zebra \ |  | ||||||
|         --enable-fpm \ |         --enable-fpm \ | ||||||
|         --with-pkg-git-version \ |         --with-pkg-git-version \ | ||||||
|         --with-pkg-extra-version=-MyOwnFRRVersion    |         --with-pkg-extra-version=-MyOwnFRRVersion    | ||||||
|  | |||||||
| @ -54,7 +54,6 @@ an example) | |||||||
|         --enable-configfile-mask=0640 \ |         --enable-configfile-mask=0640 \ | ||||||
|         --enable-logfile-mask=0640 \ |         --enable-logfile-mask=0640 \ | ||||||
|         --enable-rtadv \ |         --enable-rtadv \ | ||||||
|         --enable-tcp-zebra \ |  | ||||||
|         --enable-fpm \ |         --enable-fpm \ | ||||||
|         --with-pkg-git-version \ |         --with-pkg-git-version \ | ||||||
|         --with-pkg-extra-version=-MyOwnFRRVersion    |         --with-pkg-extra-version=-MyOwnFRRVersion    | ||||||
|  | |||||||
| @ -93,7 +93,6 @@ an example.) | |||||||
|         --enable-configfile-mask=0640 \ |         --enable-configfile-mask=0640 \ | ||||||
|         --enable-logfile-mask=0640 \ |         --enable-logfile-mask=0640 \ | ||||||
|         --enable-rtadv \ |         --enable-rtadv \ | ||||||
|         --enable-tcp-zebra \ |  | ||||||
|         --enable-fpm \ |         --enable-fpm \ | ||||||
|         --with-pkg-git-version \ |         --with-pkg-git-version \ | ||||||
|         --with-pkg-extra-version=-MyOwnFRRVersion    |         --with-pkg-extra-version=-MyOwnFRRVersion    | ||||||
|  | |||||||
| @ -53,7 +53,6 @@ an example.) | |||||||
|         --enable-configfile-mask=0640 \ |         --enable-configfile-mask=0640 \ | ||||||
|         --enable-logfile-mask=0640 \ |         --enable-logfile-mask=0640 \ | ||||||
|         --enable-rtadv \ |         --enable-rtadv \ | ||||||
|         --enable-tcp-zebra \ |  | ||||||
|         --enable-fpm \ |         --enable-fpm \ | ||||||
|         --enable-ldpd \ |         --enable-ldpd \ | ||||||
|         --with-pkg-git-version \ |         --with-pkg-git-version \ | ||||||
|  | |||||||
| @ -54,7 +54,6 @@ an example.) | |||||||
|         --enable-configfile-mask=0640 \ |         --enable-configfile-mask=0640 \ | ||||||
|         --enable-logfile-mask=0640 \ |         --enable-logfile-mask=0640 \ | ||||||
|         --enable-rtadv \ |         --enable-rtadv \ | ||||||
|         --enable-tcp-zebra \ |  | ||||||
|         --enable-fpm \ |         --enable-fpm \ | ||||||
| 	--enable-systemd=yes \ | 	--enable-systemd=yes \ | ||||||
|         --with-pkg-git-version \ |         --with-pkg-git-version \ | ||||||
|  | |||||||
| @ -60,7 +60,9 @@ restart pimd.  The default is \fB\fI@CFG_STATE@/pimd.pid\fR. | |||||||
| .TP | .TP | ||||||
| \fB\-z\fR, \fB\-\-socket \fR\fIpath\fR | \fB\-z\fR, \fB\-\-socket \fR\fIpath\fR | ||||||
| Specify the socket path for contacting the zebra daemon. | Specify the socket path for contacting the zebra daemon. | ||||||
| The default is \fB\fI@CFG_STATE@/zserv.api\fR. | The default is \fB\fI@CFG_STATE@/zserv.api\fR.  The value of this option | ||||||
|  | must be the same as the one given when starting zebra.  Refer to the \fBzebra | ||||||
|  | (8)\fR man page for more information. | ||||||
| .TP | .TP | ||||||
| \fB\-P\fR, \fB\-\-vty_port \fR\fIport-number\fR  | \fB\-P\fR, \fB\-\-vty_port \fR\fIport-number\fR  | ||||||
| Specify the port that the pimd VTY will listen on. This defaults to | Specify the port that the pimd VTY will listen on. This defaults to | ||||||
|  | |||||||
| @ -26,6 +26,9 @@ zebra \- a routing manager for use with associated @PACKAGE_FULLNAME@ components | |||||||
| ] [ | ] [ | ||||||
| .B \-M | .B \-M | ||||||
| .I module:options | .I module:options | ||||||
|  | ] [ | ||||||
|  | .B \-z | ||||||
|  | .I socketpath | ||||||
| ] | ] | ||||||
| .SH DESCRIPTION | .SH DESCRIPTION | ||||||
| .B zebra  | .B zebra  | ||||||
| @ -97,6 +100,11 @@ respectively.  The \fBfpm\fR module takes an additional colon-separated | |||||||
| argument specifying the encapsulation, either \fBnetlink\fR or \fBprotobuf\fR. | argument specifying the encapsulation, either \fBnetlink\fR or \fBprotobuf\fR. | ||||||
| It should thus be loaded with \fB-M fpm:netlink\fR or \fB-M fpm:protobuf\fR. | It should thus be loaded with \fB-M fpm:netlink\fR or \fB-M fpm:protobuf\fR. | ||||||
| .TP | .TP | ||||||
|  | \fB\-z\fR, \fB\-\-socket \fR\fIsocketpath\fR | ||||||
|  | Use the specified path to open the zebra API socket on. | ||||||
|  | The default is \fB\fI@CFG_STATE@/zserv.api\fR.  This option must be given with | ||||||
|  | the same value to all FRR protocol daemons. | ||||||
|  | .TP | ||||||
| \fB\-v\fR, \fB\-\-version\fR | \fB\-v\fR, \fB\-\-version\fR | ||||||
| Print the version and exit. | Print the version and exit. | ||||||
| .SH FILES | .SH FILES | ||||||
|  | |||||||
| @ -37,6 +37,7 @@ | |||||||
| #include "zclient.h" | #include "zclient.h" | ||||||
| #include "stream.h" | #include "stream.h" | ||||||
| #include "network.h" | #include "network.h" | ||||||
|  | #include "libfrr.h" | ||||||
| 
 | 
 | ||||||
| static void		 lde_shutdown(void); | static void		 lde_shutdown(void); | ||||||
| static int		 lde_dispatch_imsg(struct thread *); | static int		 lde_dispatch_imsg(struct thread *); | ||||||
| @ -171,7 +172,8 @@ lde_init(struct ldpd_init *init) | |||||||
| 	lde_gc_start_timer(); | 	lde_gc_start_timer(); | ||||||
| 
 | 
 | ||||||
| 	/* Init synchronous zclient and label list */ | 	/* Init synchronous zclient and label list */ | ||||||
| 	zclient_serv_path_set(init->zclient_serv_path); | 	frr_zclient_addr(&zclient_addr, &zclient_addr_len, | ||||||
|  | 			 init->zclient_serv_path); | ||||||
| 	zclient_sync_init(init->instance); | 	zclient_sync_init(init->instance); | ||||||
| 	lde_label_list_init(); | 	lde_label_list_init(); | ||||||
| } | } | ||||||
|  | |||||||
| @ -256,7 +256,7 @@ main(int argc, char *argv[]) | |||||||
| 	strlcpy(init.user, ldpd_privs.user, sizeof(init.user)); | 	strlcpy(init.user, ldpd_privs.user, sizeof(init.user)); | ||||||
| 	strlcpy(init.group, ldpd_privs.group, sizeof(init.group)); | 	strlcpy(init.group, ldpd_privs.group, sizeof(init.group)); | ||||||
| 	strlcpy(init.ctl_sock_path, ctl_sock_path, sizeof(init.ctl_sock_path)); | 	strlcpy(init.ctl_sock_path, ctl_sock_path, sizeof(init.ctl_sock_path)); | ||||||
| 	strlcpy(init.zclient_serv_path, zclient_serv_path_get(), | 	strlcpy(init.zclient_serv_path, frr_zclientpath, | ||||||
| 	    sizeof(init.zclient_serv_path)); | 	    sizeof(init.zclient_serv_path)); | ||||||
| 
 | 
 | ||||||
| 	argc -= optind; | 	argc -= optind; | ||||||
|  | |||||||
							
								
								
									
										123
									
								
								lib/libfrr.c
									
									
									
									
									
								
							
							
						
						
									
										123
									
								
								lib/libfrr.c
									
									
									
									
									
								
							| @ -19,6 +19,7 @@ | |||||||
|  */ |  */ | ||||||
| 
 | 
 | ||||||
| #include <zebra.h> | #include <zebra.h> | ||||||
|  | #include <sys/un.h> | ||||||
| 
 | 
 | ||||||
| #include <sys/types.h> | #include <sys/types.h> | ||||||
| #include <sys/wait.h> | #include <sys/wait.h> | ||||||
| @ -45,6 +46,7 @@ char frr_protoname[256] = "NONE"; | |||||||
| char frr_protonameinst[256] = "NONE"; | char frr_protonameinst[256] = "NONE"; | ||||||
| 
 | 
 | ||||||
| char config_default[256]; | char config_default[256]; | ||||||
|  | char frr_zclientpath[256]; | ||||||
| static char pidfile_default[256]; | static char pidfile_default[256]; | ||||||
| static char vtypath_default[256]; | static char vtypath_default[256]; | ||||||
| 
 | 
 | ||||||
| @ -135,6 +137,116 @@ static const struct optspec os_user = {"u:g:", | |||||||
| 				       lo_user}; | 				       lo_user}; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | bool frr_zclient_addr(struct sockaddr_storage *sa, socklen_t *sa_len, | ||||||
|  | 		      const char *path) | ||||||
|  | { | ||||||
|  | 	memset(sa, 0, sizeof(*sa)); | ||||||
|  | 
 | ||||||
|  | 	if (!path) | ||||||
|  | 		path = ZEBRA_SERV_PATH; | ||||||
|  | 
 | ||||||
|  | 	if (!strncmp(path, ZAPI_TCP_PATHNAME, strlen(ZAPI_TCP_PATHNAME))) { | ||||||
|  | 		/* note: this functionality is disabled at bottom */ | ||||||
|  | 		int af; | ||||||
|  | 		int port = ZEBRA_PORT; | ||||||
|  | 		char *err = NULL; | ||||||
|  | 		struct sockaddr_in *sin = NULL; | ||||||
|  | 		struct sockaddr_in6 *sin6 = NULL; | ||||||
|  | 
 | ||||||
|  | 		path += strlen(ZAPI_TCP_PATHNAME); | ||||||
|  | 
 | ||||||
|  | 		switch (path[0]) { | ||||||
|  | 		case '4': | ||||||
|  | 			path++; | ||||||
|  | 			af = AF_INET; | ||||||
|  | 			break; | ||||||
|  | 		case '6': | ||||||
|  | 			path++; | ||||||
|  | 			/* fallthrough */ | ||||||
|  | 		default: | ||||||
|  | 			af = AF_INET6; | ||||||
|  | 			break; | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		switch (path[0]) { | ||||||
|  | 		case '\0': | ||||||
|  | 			break; | ||||||
|  | 		case ':': | ||||||
|  | 			path++; | ||||||
|  | 			port = strtoul(path, &err, 10); | ||||||
|  | 			if (*err || !*path) | ||||||
|  | 				return false; | ||||||
|  | 			break; | ||||||
|  | 		default: | ||||||
|  | 			return false; | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		sa->ss_family = af; | ||||||
|  | 		switch (af) { | ||||||
|  | 		case AF_INET: | ||||||
|  | 			sin = (struct sockaddr_in *)sa; | ||||||
|  | 			sin->sin_port = htons(port); | ||||||
|  | 			sin->sin_addr.s_addr = htonl(INADDR_LOOPBACK); | ||||||
|  | 			*sa_len = sizeof(struct sockaddr_in); | ||||||
|  | #ifdef HAVE_STRUCT_SOCKADDR_IN_SIN_LEN | ||||||
|  | 			sin->sin_len = *sa_len; | ||||||
|  | #endif | ||||||
|  | 			break; | ||||||
|  | 		case AF_INET6: | ||||||
|  | 			sin6 = (struct sockaddr_in6 *)sa; | ||||||
|  | 			sin6->sin6_port = htons(port); | ||||||
|  | 			inet_pton(AF_INET6, "::1", &sin6->sin6_addr); | ||||||
|  | 			*sa_len = sizeof(struct sockaddr_in6); | ||||||
|  | #ifdef SIN6_LEN | ||||||
|  | 			sin6->sin6_len = *sa_len; | ||||||
|  | #endif | ||||||
|  | 			break; | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | #if 1 | ||||||
|  | 		/* force-disable this path, because tcp-zebra is a
 | ||||||
|  | 		 * SECURITY ISSUE.  there are no checks at all against | ||||||
|  | 		 * untrusted users on the local system connecting on TCP | ||||||
|  | 		 * and injecting bogus routing data into the entire routing | ||||||
|  | 		 * domain. | ||||||
|  | 		 * | ||||||
|  | 		 * The functionality is only left here because it may be | ||||||
|  | 		 * useful during development, in order to be able to get | ||||||
|  | 		 * tcpdump or wireshark watching ZAPI as TCP.  If you want | ||||||
|  | 		 * to do that, flip the #if 1 above to #if 0. */ | ||||||
|  | 		memset(sa, 0, sizeof(*sa)); | ||||||
|  | 		return false; | ||||||
|  | #endif | ||||||
|  | 	} else { | ||||||
|  | 		/* "sun" is a #define on solaris */ | ||||||
|  | 		struct sockaddr_un *suna = (struct sockaddr_un *)sa; | ||||||
|  | 
 | ||||||
|  | 		suna->sun_family = AF_UNIX; | ||||||
|  | 		strlcpy(suna->sun_path, path, sizeof(suna->sun_path)); | ||||||
|  | #ifdef HAVE_STRUCT_SOCKADDR_UN_SUN_LEN | ||||||
|  | 		*sa_len = suna->sun_len = SUN_LEN(suna); | ||||||
|  | #else | ||||||
|  | 		*sa_len = sizeof(suna->sun_family) + strlen(suna->sun_path); | ||||||
|  | #endif /* HAVE_STRUCT_SOCKADDR_UN_SUN_LEN */ | ||||||
|  | #if 0 | ||||||
|  | 		/* this is left here for future reference;  Linux abstract
 | ||||||
|  | 		 * socket namespace support can be enabled by replacing | ||||||
|  | 		 * above #if 0 with #ifdef GNU_LINUX. | ||||||
|  | 		 * | ||||||
|  | 		 * THIS IS A SECURITY ISSUE, the abstract socket namespace | ||||||
|  | 		 * does not have user/group permission control on sockets. | ||||||
|  | 		 * we'd need to implement SCM_CREDENTIALS support first to | ||||||
|  | 		 * check that only proper users can connect to abstract | ||||||
|  | 		 * sockets. (same problem as tcp-zebra, except there is a | ||||||
|  | 		 * fix with SCM_CREDENTIALS.  tcp-zebra has no such fix.) | ||||||
|  | 		 */ | ||||||
|  | 		if (suna->sun_path[0] == '@') | ||||||
|  | 			suna->sun_path[0] = '\0'; | ||||||
|  | #endif | ||||||
|  | 	} | ||||||
|  | 	return true; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| static struct frr_daemon_info *di = NULL; | static struct frr_daemon_info *di = NULL; | ||||||
| 
 | 
 | ||||||
| void frr_preinit(struct frr_daemon_info *daemon, int argc, char **argv) | void frr_preinit(struct frr_daemon_info *daemon, int argc, char **argv) | ||||||
| @ -164,6 +276,8 @@ void frr_preinit(struct frr_daemon_info *daemon, int argc, char **argv) | |||||||
| 
 | 
 | ||||||
| 	strlcpy(frr_protoname, di->logname, sizeof(frr_protoname)); | 	strlcpy(frr_protoname, di->logname, sizeof(frr_protoname)); | ||||||
| 	strlcpy(frr_protonameinst, di->logname, sizeof(frr_protonameinst)); | 	strlcpy(frr_protonameinst, di->logname, sizeof(frr_protonameinst)); | ||||||
|  | 
 | ||||||
|  | 	strlcpy(frr_zclientpath, ZEBRA_SERV_PATH, sizeof(frr_zclientpath)); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void frr_opt_add(const char *optstr, const struct option *longopts, | void frr_opt_add(const char *optstr, const struct option *longopts, | ||||||
| @ -246,7 +360,7 @@ static int frr_opt(int opt) | |||||||
| 	case 'z': | 	case 'z': | ||||||
| 		if (di->flags & FRR_NO_ZCLIENT) | 		if (di->flags & FRR_NO_ZCLIENT) | ||||||
| 			return 1; | 			return 1; | ||||||
| 		zclient_serv_path_set(optarg); | 		strlcpy(frr_zclientpath, optarg, sizeof(frr_zclientpath)); | ||||||
| 		break; | 		break; | ||||||
| 	case 'A': | 	case 'A': | ||||||
| 		if (di->flags & FRR_NO_TCPVTY) | 		if (di->flags & FRR_NO_TCPVTY) | ||||||
| @ -399,6 +513,13 @@ struct thread_master *frr_init(void) | |||||||
| 	zlog_set_level(ZLOG_DEST_SYSLOG, zlog_default->default_lvl); | 	zlog_set_level(ZLOG_DEST_SYSLOG, zlog_default->default_lvl); | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
|  | 	if (!frr_zclient_addr(&zclient_addr, &zclient_addr_len, | ||||||
|  | 			      frr_zclientpath)) { | ||||||
|  | 		fprintf(stderr, "Invalid zserv socket path: %s\n", | ||||||
|  | 			frr_zclientpath); | ||||||
|  | 		exit(1); | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
| 	/* don't mkdir these as root... */ | 	/* don't mkdir these as root... */ | ||||||
| 	if (!(di->flags & FRR_NO_PRIVSEP)) { | 	if (!(di->flags & FRR_NO_PRIVSEP)) { | ||||||
| 		if (!di->pid_file || !di->vty_path) | 		if (!di->pid_file || !di->vty_path) | ||||||
|  | |||||||
| @ -101,7 +101,11 @@ extern void frr_vty_serv(void); | |||||||
| /* note: contains call to frr_vty_serv() */ | /* note: contains call to frr_vty_serv() */ | ||||||
| extern void frr_run(struct thread_master *master); | extern void frr_run(struct thread_master *master); | ||||||
| 
 | 
 | ||||||
|  | extern bool frr_zclient_addr(struct sockaddr_storage *sa, socklen_t *sa_len, | ||||||
|  | 			     const char *path); | ||||||
|  | 
 | ||||||
| extern char config_default[256]; | extern char config_default[256]; | ||||||
|  | extern char frr_zclientpath[256]; | ||||||
| extern const char frr_sysconfdir[]; | extern const char frr_sysconfdir[]; | ||||||
| extern const char frr_vtydir[]; | extern const char frr_vtydir[]; | ||||||
| extern const char frr_moduledir[]; | extern const char frr_moduledir[]; | ||||||
|  | |||||||
							
								
								
									
										136
									
								
								lib/zclient.c
									
									
									
									
									
								
							
							
						
						
									
										136
									
								
								lib/zclient.c
									
									
									
									
									
								
							| @ -45,7 +45,8 @@ enum event { ZCLIENT_SCHEDULE, ZCLIENT_READ, ZCLIENT_CONNECT }; | |||||||
| /* Prototype for event manager. */ | /* Prototype for event manager. */ | ||||||
| static void zclient_event(enum event, struct zclient *); | static void zclient_event(enum event, struct zclient *); | ||||||
| 
 | 
 | ||||||
| const char *zclient_serv_path = NULL; | struct sockaddr_storage zclient_addr; | ||||||
|  | socklen_t zclient_addr_len; | ||||||
| 
 | 
 | ||||||
| /* This file local debug flag. */ | /* This file local debug flag. */ | ||||||
| int zclient_debug = 0; | int zclient_debug = 0; | ||||||
| @ -183,81 +184,6 @@ void zclient_reset(struct zclient *zclient) | |||||||
| 	zclient_init(zclient, zclient->redist_default, zclient->instance); | 	zclient_init(zclient, zclient->redist_default, zclient->instance); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| #ifdef HAVE_TCP_ZEBRA |  | ||||||
| 
 |  | ||||||
| /* Make socket to zebra daemon. Return zebra socket. */ |  | ||||||
| static int zclient_socket(void) |  | ||||||
| { |  | ||||||
| 	int sock; |  | ||||||
| 	int ret; |  | ||||||
| 	struct sockaddr_in serv; |  | ||||||
| 
 |  | ||||||
| 	/* We should think about IPv6 connection. */ |  | ||||||
| 	sock = socket(AF_INET, SOCK_STREAM, 0); |  | ||||||
| 	if (sock < 0) |  | ||||||
| 		return -1; |  | ||||||
| 
 |  | ||||||
| 	/* Make server socket. */ |  | ||||||
| 	memset(&serv, 0, sizeof(struct sockaddr_in)); |  | ||||||
| 	serv.sin_family = AF_INET; |  | ||||||
| 	serv.sin_port = htons(ZEBRA_PORT); |  | ||||||
| #ifdef HAVE_STRUCT_SOCKADDR_IN_SIN_LEN |  | ||||||
| 	serv.sin_len = sizeof(struct sockaddr_in); |  | ||||||
| #endif /* HAVE_STRUCT_SOCKADDR_IN_SIN_LEN */ |  | ||||||
| 	serv.sin_addr.s_addr = htonl(INADDR_LOOPBACK); |  | ||||||
| 
 |  | ||||||
| 	/* Connect to zebra. */ |  | ||||||
| 	ret = connect(sock, (struct sockaddr *)&serv, sizeof(serv)); |  | ||||||
| 	if (ret < 0) { |  | ||||||
| 		if (zclient_debug) |  | ||||||
| 			zlog_warn("%s connect failure: %d(%s)", |  | ||||||
| 				  __PRETTY_FUNCTION__, errno, |  | ||||||
| 				  safe_strerror(errno)); |  | ||||||
| 		close(sock); |  | ||||||
| 		return -1; |  | ||||||
| 	} |  | ||||||
| 	return sock; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| #else |  | ||||||
| 
 |  | ||||||
| /* For sockaddr_un. */ |  | ||||||
| #include <sys/un.h> |  | ||||||
| 
 |  | ||||||
| static int zclient_socket_un(const char *path) |  | ||||||
| { |  | ||||||
| 	int ret; |  | ||||||
| 	int sock, len; |  | ||||||
| 	struct sockaddr_un addr; |  | ||||||
| 
 |  | ||||||
| 	sock = socket(AF_UNIX, SOCK_STREAM, 0); |  | ||||||
| 	if (sock < 0) |  | ||||||
| 		return -1; |  | ||||||
| 
 |  | ||||||
| 	/* Make server socket. */ |  | ||||||
| 	memset(&addr, 0, sizeof(struct sockaddr_un)); |  | ||||||
| 	addr.sun_family = AF_UNIX; |  | ||||||
| 	strncpy(addr.sun_path, path, strlen(path)); |  | ||||||
| #ifdef HAVE_STRUCT_SOCKADDR_UN_SUN_LEN |  | ||||||
| 	len = addr.sun_len = SUN_LEN(&addr); |  | ||||||
| #else |  | ||||||
| 	len = sizeof(addr.sun_family) + strlen(addr.sun_path); |  | ||||||
| #endif /* HAVE_STRUCT_SOCKADDR_UN_SUN_LEN */ |  | ||||||
| 
 |  | ||||||
| 	ret = connect(sock, (struct sockaddr *)&addr, len); |  | ||||||
| 	if (ret < 0) { |  | ||||||
| 		if (zclient_debug) |  | ||||||
| 			zlog_warn("%s connect failure: %d(%s)", |  | ||||||
| 				  __PRETTY_FUNCTION__, errno, |  | ||||||
| 				  safe_strerror(errno)); |  | ||||||
| 		close(sock); |  | ||||||
| 		return -1; |  | ||||||
| 	} |  | ||||||
| 	return sock; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| #endif /* HAVE_TCP_ZEBRA */ |  | ||||||
| 
 |  | ||||||
| /**
 | /**
 | ||||||
|  * Connect to zebra daemon. |  * Connect to zebra daemon. | ||||||
|  * @param zclient a pointer to zclient structure |  * @param zclient a pointer to zclient structure | ||||||
| @ -267,12 +193,30 @@ static int zclient_socket_un(const char *path) | |||||||
|  */ |  */ | ||||||
| int zclient_socket_connect(struct zclient *zclient) | int zclient_socket_connect(struct zclient *zclient) | ||||||
| { | { | ||||||
| #ifdef HAVE_TCP_ZEBRA | 	int sock; | ||||||
| 	zclient->sock = zclient_socket(); | 	int ret; | ||||||
| #else | 
 | ||||||
| 	zclient->sock = zclient_socket_un(zclient_serv_path_get()); | 	/* We should think about IPv6 connection. */ | ||||||
| #endif | 	sock = socket(zclient_addr.ss_family, SOCK_STREAM, 0); | ||||||
| 	return zclient->sock; | 	if (sock < 0) | ||||||
|  | 		return -1; | ||||||
|  | 
 | ||||||
|  | 	set_cloexec(sock); | ||||||
|  | 
 | ||||||
|  | 	/* Connect to zebra. */ | ||||||
|  | 	ret = connect(sock, (struct sockaddr *)&zclient_addr, | ||||||
|  | 			zclient_addr_len); | ||||||
|  | 	if (ret < 0) { | ||||||
|  | 		if (zclient_debug) | ||||||
|  | 			zlog_warn("%s connect failure: %d(%s)", | ||||||
|  | 				  __PRETTY_FUNCTION__, errno, | ||||||
|  | 				  safe_strerror(errno)); | ||||||
|  | 		close(sock); | ||||||
|  | 		return -1; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	zclient->sock = sock; | ||||||
|  | 	return sock; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static int zclient_failed(struct zclient *zclient) | static int zclient_failed(struct zclient *zclient) | ||||||
| @ -2225,34 +2169,6 @@ static void zclient_event(enum event event, struct zclient *zclient) | |||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| const char *zclient_serv_path_get() |  | ||||||
| { |  | ||||||
| 	return zclient_serv_path ? zclient_serv_path : ZEBRA_SERV_PATH; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void zclient_serv_path_set(char *path) |  | ||||||
| { |  | ||||||
| 	struct stat sb; |  | ||||||
| 
 |  | ||||||
| 	/* reset */ |  | ||||||
| 	zclient_serv_path = NULL; |  | ||||||
| 
 |  | ||||||
| 	/* test if `path' is socket. don't set it otherwise. */ |  | ||||||
| 	if (stat(path, &sb) == -1) { |  | ||||||
| 		zlog_warn("%s: zebra socket `%s' does not exist", __func__, |  | ||||||
| 			  path); |  | ||||||
| 		return; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	if ((sb.st_mode & S_IFMT) != S_IFSOCK) { |  | ||||||
| 		zlog_warn("%s: `%s' is not unix socket, sir", __func__, path); |  | ||||||
| 		return; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	/* it seems that path is unix socket */ |  | ||||||
| 	zclient_serv_path = path; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void zclient_interface_set_master(struct zclient *client, | void zclient_interface_set_master(struct zclient *client, | ||||||
| 				  struct interface *master, | 				  struct interface *master, | ||||||
| 				  struct interface *slave) | 				  struct interface *slave) | ||||||
|  | |||||||
| @ -42,6 +42,14 @@ | |||||||
| /* Zebra header size. */ | /* Zebra header size. */ | ||||||
| #define ZEBRA_HEADER_SIZE             8 | #define ZEBRA_HEADER_SIZE             8 | ||||||
| 
 | 
 | ||||||
|  | /* special socket path name to use TCP
 | ||||||
|  |  * @ is used as first character because that's abstract socket names on Linux | ||||||
|  |  */ | ||||||
|  | #define ZAPI_TCP_PATHNAME             "@tcp" | ||||||
|  | 
 | ||||||
|  | extern struct sockaddr_storage zclient_addr; | ||||||
|  | extern socklen_t zclient_addr_len; | ||||||
|  | 
 | ||||||
| /* Zebra message types. */ | /* Zebra message types. */ | ||||||
| typedef enum { | typedef enum { | ||||||
| 	ZEBRA_INTERFACE_ADD, | 	ZEBRA_INTERFACE_ADD, | ||||||
| @ -306,8 +314,6 @@ extern void zclient_reset(struct zclient *); | |||||||
| extern void zclient_free(struct zclient *); | extern void zclient_free(struct zclient *); | ||||||
| 
 | 
 | ||||||
| extern int zclient_socket_connect(struct zclient *); | extern int zclient_socket_connect(struct zclient *); | ||||||
| extern void zclient_serv_path_set(char *path); |  | ||||||
| extern const char *zclient_serv_path_get(void); |  | ||||||
| 
 | 
 | ||||||
| extern u_short *redist_check_instance(struct redist_proto *, u_short); | extern u_short *redist_check_instance(struct redist_proto *, u_short); | ||||||
| extern void redist_add_instance(struct redist_proto *, u_short); | extern void redist_add_instance(struct redist_proto *, u_short); | ||||||
|  | |||||||
| @ -52,7 +52,6 @@ Building your own FRRouting RPM | |||||||
|      |      | ||||||
|         ############### FRRouting (FRR) configure options ################# |         ############### FRRouting (FRR) configure options ################# | ||||||
|         # with-feature options |         # with-feature options | ||||||
|         %{!?with_tcp_zebra:     %global  with_tcp_zebra     0 } |  | ||||||
|         %{!?with_pam:           %global  with_pam           0 } |         %{!?with_pam:           %global  with_pam           0 } | ||||||
|         %{!?with_ospfclient:    %global  with_ospfclient    1 } |         %{!?with_ospfclient:    %global  with_ospfclient    1 } | ||||||
|         %{!?with_ospfapi:       %global  with_ospfapi       1 } |         %{!?with_ospfapi:       %global  with_ospfapi       1 } | ||||||
|  | |||||||
| @ -10,7 +10,6 @@ | |||||||
| 
 | 
 | ||||||
| #################### FRRouting (FRR) configure options ##################### | #################### FRRouting (FRR) configure options ##################### | ||||||
| # with-feature options | # with-feature options | ||||||
| %{!?with_tcp_zebra:     %global  with_tcp_zebra     0 } |  | ||||||
| %{!?with_pam:           %global  with_pam           0 } | %{!?with_pam:           %global  with_pam           0 } | ||||||
| %{!?with_ospfclient:    %global  with_ospfclient    1 } | %{!?with_ospfclient:    %global  with_ospfclient    1 } | ||||||
| %{!?with_ospfapi:       %global  with_ospfapi       1 } | %{!?with_ospfapi:       %global  with_ospfapi       1 } | ||||||
| @ -75,12 +74,6 @@ | |||||||
|     %global  with_pimd  0 |     %global  with_pimd  0 | ||||||
| %endif | %endif | ||||||
| 
 | 
 | ||||||
| # if FPM is enabled, then enable tcp_zebra as well  |  | ||||||
| # |  | ||||||
| %if %{with_fpm} |  | ||||||
|     %global with_tcp_zebra  1 |  | ||||||
| %endif |  | ||||||
| 
 |  | ||||||
| # misc internal defines | # misc internal defines | ||||||
| %{!?frr_uid:            %global  frr_uid            92 } | %{!?frr_uid:            %global  frr_uid            92 } | ||||||
| %{!?frr_gid:            %global  frr_gid            92 } | %{!?frr_gid:            %global  frr_gid            92 } | ||||||
| @ -233,9 +226,6 @@ developing OSPF-API and frr applications. | |||||||
| %endif | %endif | ||||||
| %if %{with_multipath} | %if %{with_multipath} | ||||||
|     --enable-multipath=%{with_multipath} \ |     --enable-multipath=%{with_multipath} \ | ||||||
| %endif |  | ||||||
| %if %{with_tcp_zebra} |  | ||||||
|     --enable-tcp-zebra \ |  | ||||||
| %endif | %endif | ||||||
|     --enable-vtysh \ |     --enable-vtysh \ | ||||||
| %if %{with_ospfclient} | %if %{with_ospfclient} | ||||||
|  | |||||||
| @ -113,8 +113,7 @@ static int zebra_send_release_label_chunk(uint32_t start, uint32_t end) | |||||||
| 
 | 
 | ||||||
| void init_zclient(struct thread_master *master, char *lm_zserv_path) | void init_zclient(struct thread_master *master, char *lm_zserv_path) | ||||||
| { | { | ||||||
| 	if (lm_zserv_path) | 	frr_zclient_addr(&zclient_addr, &zclient_addr_len, lm_zserv_path); | ||||||
| 		zclient_serv_path_set(lm_zserv_path); |  | ||||||
| 
 | 
 | ||||||
| 	zclient = zclient_new(master); | 	zclient = zclient_new(master); | ||||||
| 	/* zclient_init(zclient, ZEBRA_LABEL_MANAGER, 0); */ | 	/* zclient_init(zclient, ZEBRA_LABEL_MANAGER, 0); */ | ||||||
|  | |||||||
| @ -186,11 +186,7 @@ int main(int argc, char **argv) | |||||||
| 	/* Establish connection to zebra. */ | 	/* Establish connection to zebra. */ | ||||||
| 	zclient = zclient_new(master); | 	zclient = zclient_new(master); | ||||||
| 	zclient->enable = 1; | 	zclient->enable = 1; | ||||||
| #ifdef HAVE_TCP_ZEBRA | 	zclient_socket_connect(zclient); | ||||||
| 	zclient->sock = zclient_socket(); |  | ||||||
| #else |  | ||||||
| 	zclient->sock = zclient_socket_un(ZEBRA_SERV_PATH); |  | ||||||
| #endif /* HAVE_TCP_ZEBRA */ |  | ||||||
| 
 | 
 | ||||||
| 	/* Open simulation file. */ | 	/* Open simulation file. */ | ||||||
| 	fp = fopen(argv[1], "r"); | 	fp = fopen(argv[1], "r"); | ||||||
|  | |||||||
| @ -33,6 +33,7 @@ | |||||||
| #include "lib/network.h" | #include "lib/network.h" | ||||||
| #include "lib/stream.h" | #include "lib/stream.h" | ||||||
| #include "lib/zclient.h" | #include "lib/zclient.h" | ||||||
|  | #include "lib/libfrr.h" | ||||||
| 
 | 
 | ||||||
| #include "label_manager.h" | #include "label_manager.h" | ||||||
| 
 | 
 | ||||||
| @ -216,7 +217,8 @@ static int lm_zclient_connect(struct thread *t) | |||||||
| static void lm_zclient_init(char *lm_zserv_path) | static void lm_zclient_init(char *lm_zserv_path) | ||||||
| { | { | ||||||
| 	if (lm_zserv_path) | 	if (lm_zserv_path) | ||||||
| 		zclient_serv_path_set(lm_zserv_path); | 		frr_zclient_addr(&zclient_addr, &zclient_addr_len, | ||||||
|  | 				 lm_zserv_path); | ||||||
| 
 | 
 | ||||||
| 	/* Set default values. */ | 	/* Set default values. */ | ||||||
| 	zclient = zclient_new(zebrad.master); | 	zclient = zclient_new(zebrad.master); | ||||||
|  | |||||||
| @ -204,6 +204,8 @@ int main(int argc, char **argv) | |||||||
| 	char *zserv_path = NULL; | 	char *zserv_path = NULL; | ||||||
| 	/* Socket to external label manager */ | 	/* Socket to external label manager */ | ||||||
| 	char *lblmgr_path = NULL; | 	char *lblmgr_path = NULL; | ||||||
|  | 	struct sockaddr_storage dummy; | ||||||
|  | 	socklen_t dummylen; | ||||||
| 
 | 
 | ||||||
| 	frr_preinit(&zebra_di, argc, argv); | 	frr_preinit(&zebra_di, argc, argv); | ||||||
| 
 | 
 | ||||||
| @ -256,6 +258,12 @@ int main(int argc, char **argv) | |||||||
| 			break; | 			break; | ||||||
| 		case 'z': | 		case 'z': | ||||||
| 			zserv_path = optarg; | 			zserv_path = optarg; | ||||||
|  | 			if (!frr_zclient_addr(&dummy, &dummylen, optarg)) { | ||||||
|  | 				fprintf(stderr, | ||||||
|  | 					"Invalid zserv socket path: %s\n", | ||||||
|  | 					optarg); | ||||||
|  | 				exit(1); | ||||||
|  | 			} | ||||||
| 			break; | 			break; | ||||||
| 		case 'l': | 		case 'l': | ||||||
| 			lblmgr_path = optarg; | 			lblmgr_path = optarg; | ||||||
|  | |||||||
							
								
								
									
										122
									
								
								zebra/zserv.c
									
									
									
									
									
								
							
							
						
						
									
										122
									
								
								zebra/zserv.c
									
									
									
									
									
								
							| @ -19,6 +19,7 @@ | |||||||
|  */ |  */ | ||||||
| 
 | 
 | ||||||
| #include <zebra.h> | #include <zebra.h> | ||||||
|  | #include <sys/un.h> | ||||||
| 
 | 
 | ||||||
| #include "prefix.h" | #include "prefix.h" | ||||||
| #include "command.h" | #include "command.h" | ||||||
| @ -38,6 +39,7 @@ | |||||||
| #include "buffer.h" | #include "buffer.h" | ||||||
| #include "nexthop.h" | #include "nexthop.h" | ||||||
| #include "vrf.h" | #include "vrf.h" | ||||||
|  | #include "libfrr.h" | ||||||
| 
 | 
 | ||||||
| #include "zebra/zserv.h" | #include "zebra/zserv.h" | ||||||
| #include "zebra/zebra_ns.h" | #include "zebra/zebra_ns.h" | ||||||
| @ -2605,116 +2607,59 @@ static int zebra_accept(struct thread *thread) | |||||||
| 	return 0; | 	return 0; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| #ifdef HAVE_TCP_ZEBRA | /* Make zebra server socket, wiping any existing one (see bug #403). */ | ||||||
| /* Make zebra's server socket. */ | void zebra_zserv_socket_init(char *path) | ||||||
| static void zebra_serv() |  | ||||||
| { | { | ||||||
| 	int ret; | 	int ret; | ||||||
| 	int accept_sock; | 	int sock; | ||||||
| 	struct sockaddr_in addr; |  | ||||||
| 
 |  | ||||||
| 	accept_sock = socket(AF_INET, SOCK_STREAM, 0); |  | ||||||
| 
 |  | ||||||
| 	if (accept_sock < 0) { |  | ||||||
| 		zlog_warn("Can't create zserv stream socket: %s", |  | ||||||
| 			  safe_strerror(errno)); |  | ||||||
| 		zlog_warn( |  | ||||||
| 			"zebra can't provice full functionality due to above error"); |  | ||||||
| 		return; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	memset(&addr, 0, sizeof(struct sockaddr_in)); |  | ||||||
| 	addr.sin_family = AF_INET; |  | ||||||
| 	addr.sin_port = htons(ZEBRA_PORT); |  | ||||||
| #ifdef HAVE_STRUCT_SOCKADDR_IN_SIN_LEN |  | ||||||
| 	addr.sin_len = sizeof(struct sockaddr_in); |  | ||||||
| #endif /* HAVE_STRUCT_SOCKADDR_IN_SIN_LEN */ |  | ||||||
| 	addr.sin_addr.s_addr = htonl(INADDR_LOOPBACK); |  | ||||||
| 
 |  | ||||||
| 	sockopt_reuseaddr(accept_sock); |  | ||||||
| 	sockopt_reuseport(accept_sock); |  | ||||||
| 
 |  | ||||||
| 	if (zserv_privs.change(ZPRIVS_RAISE)) |  | ||||||
| 		zlog_err("Can't raise privileges"); |  | ||||||
| 
 |  | ||||||
| 	ret = bind(accept_sock, (struct sockaddr *)&addr, |  | ||||||
| 		   sizeof(struct sockaddr_in)); |  | ||||||
| 	if (ret < 0) { |  | ||||||
| 		zlog_warn("Can't bind to stream socket: %s", |  | ||||||
| 			  safe_strerror(errno)); |  | ||||||
| 		zlog_warn( |  | ||||||
| 			"zebra can't provice full functionality due to above error"); |  | ||||||
| 		close(accept_sock); /* Avoid sd leak. */ |  | ||||||
| 		return; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	if (zserv_privs.change(ZPRIVS_LOWER)) |  | ||||||
| 		zlog_err("Can't lower privileges"); |  | ||||||
| 
 |  | ||||||
| 	ret = listen(accept_sock, 1); |  | ||||||
| 	if (ret < 0) { |  | ||||||
| 		zlog_warn("Can't listen to stream socket: %s", |  | ||||||
| 			  safe_strerror(errno)); |  | ||||||
| 		zlog_warn( |  | ||||||
| 			"zebra can't provice full functionality due to above error"); |  | ||||||
| 		close(accept_sock); /* Avoid sd leak. */ |  | ||||||
| 		return; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	zebra_event(ZEBRA_SERV, accept_sock, NULL); |  | ||||||
| } |  | ||||||
| #else /* HAVE_TCP_ZEBRA */ |  | ||||||
| 
 |  | ||||||
| /* For sockaddr_un. */ |  | ||||||
| #include <sys/un.h> |  | ||||||
| 
 |  | ||||||
| /* zebra server UNIX domain socket. */ |  | ||||||
| static void zebra_serv_un(const char *path) |  | ||||||
| { |  | ||||||
| 	int ret; |  | ||||||
| 	int sock, len; |  | ||||||
| 	struct sockaddr_un serv; |  | ||||||
| 	mode_t old_mask; | 	mode_t old_mask; | ||||||
|  | 	struct sockaddr_storage sa; | ||||||
|  | 	socklen_t sa_len; | ||||||
| 
 | 
 | ||||||
| 	/* First of all, unlink existing socket */ | 	if (!frr_zclient_addr(&sa, &sa_len, path)) | ||||||
| 	unlink(path); | 		/* should be caught in zebra main() */ | ||||||
|  | 		return; | ||||||
| 
 | 
 | ||||||
| 	/* Set umask */ | 	/* Set umask */ | ||||||
| 	old_mask = umask(0077); | 	old_mask = umask(0077); | ||||||
| 
 | 
 | ||||||
| 	/* Make UNIX domain socket. */ | 	/* Make UNIX domain socket. */ | ||||||
| 	sock = socket(AF_UNIX, SOCK_STREAM, 0); | 	sock = socket(sa.ss_family, SOCK_STREAM, 0); | ||||||
| 	if (sock < 0) { | 	if (sock < 0) { | ||||||
| 		zlog_warn("Can't create zserv unix socket: %s", | 		zlog_warn("Can't create zserv socket: %s", | ||||||
| 			  safe_strerror(errno)); | 			  safe_strerror(errno)); | ||||||
| 		zlog_warn( | 		zlog_warn( | ||||||
| 			"zebra can't provide full functionality due to above error"); | 			"zebra can't provide full functionality due to above error"); | ||||||
| 		return; | 		return; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	/* Make server socket. */ | 	if (sa.ss_family != AF_UNIX) { | ||||||
| 	memset(&serv, 0, sizeof(struct sockaddr_un)); | 		sockopt_reuseaddr(sock); | ||||||
| 	serv.sun_family = AF_UNIX; | 		sockopt_reuseport(sock); | ||||||
| 	strncpy(serv.sun_path, path, strlen(path)); | 	} else { | ||||||
| #ifdef HAVE_STRUCT_SOCKADDR_UN_SUN_LEN | 		struct sockaddr_un *suna = (struct sockaddr_un *)&sa; | ||||||
| 	len = serv.sun_len = SUN_LEN(&serv); | 		if (suna->sun_path[0]) | ||||||
| #else | 			unlink(suna->sun_path); | ||||||
| 	len = sizeof(serv.sun_family) + strlen(serv.sun_path); | 	} | ||||||
| #endif /* HAVE_STRUCT_SOCKADDR_UN_SUN_LEN */ |  | ||||||
| 
 | 
 | ||||||
| 	ret = bind(sock, (struct sockaddr *)&serv, len); | 	if (zserv_privs.change(ZPRIVS_RAISE)) | ||||||
|  | 		zlog_err("Can't raise privileges"); | ||||||
|  | 
 | ||||||
|  | 	ret = bind(sock, (struct sockaddr *)&sa, sa_len); | ||||||
| 	if (ret < 0) { | 	if (ret < 0) { | ||||||
| 		zlog_warn("Can't bind to unix socket %s: %s", path, | 		zlog_warn("Can't bind zserv socket on %s: %s", path, | ||||||
| 			  safe_strerror(errno)); | 			  safe_strerror(errno)); | ||||||
| 		zlog_warn( | 		zlog_warn( | ||||||
| 			"zebra can't provide full functionality due to above error"); | 			"zebra can't provide full functionality due to above error"); | ||||||
| 		close(sock); | 		close(sock); | ||||||
| 		return; | 		return; | ||||||
| 	} | 	} | ||||||
|  | 	if (zserv_privs.change(ZPRIVS_LOWER)) | ||||||
|  | 		zlog_err("Can't lower privileges"); | ||||||
| 
 | 
 | ||||||
| 	ret = listen(sock, 5); | 	ret = listen(sock, 5); | ||||||
| 	if (ret < 0) { | 	if (ret < 0) { | ||||||
| 		zlog_warn("Can't listen to unix socket %s: %s", path, | 		zlog_warn("Can't listen to zserv socket %s: %s", path, | ||||||
| 			  safe_strerror(errno)); | 			  safe_strerror(errno)); | ||||||
| 		zlog_warn( | 		zlog_warn( | ||||||
| 			"zebra can't provide full functionality due to above error"); | 			"zebra can't provide full functionality due to above error"); | ||||||
| @ -2726,7 +2671,6 @@ static void zebra_serv_un(const char *path) | |||||||
| 
 | 
 | ||||||
| 	zebra_event(ZEBRA_SERV, sock, NULL); | 	zebra_event(ZEBRA_SERV, sock, NULL); | ||||||
| } | } | ||||||
| #endif /* HAVE_TCP_ZEBRA */ |  | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| static void zebra_event(enum event event, int sock, struct zserv *client) | static void zebra_event(enum event event, int sock, struct zserv *client) | ||||||
| @ -3165,13 +3109,3 @@ void zebra_init(void) | |||||||
| 	/* Route-map */ | 	/* Route-map */ | ||||||
| 	zebra_route_map_init(); | 	zebra_route_map_init(); | ||||||
| } | } | ||||||
| 
 |  | ||||||
| /* Make zebra server socket, wiping any existing one (see bug #403). */ |  | ||||||
| void zebra_zserv_socket_init(char *path) |  | ||||||
| { |  | ||||||
| #ifdef HAVE_TCP_ZEBRA |  | ||||||
| 	zebra_serv(); |  | ||||||
| #else |  | ||||||
| 	zebra_serv_un(path ? path : ZEBRA_SERV_PATH); |  | ||||||
| #endif /* HAVE_TCP_ZEBRA */ |  | ||||||
| } |  | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Donald Sharp
						Donald Sharp