summaryrefslogtreecommitdiffstats
path: root/ldpd/ldpd.c
diff options
context:
space:
mode:
authorMartin Winter <mwinter@opensourcerouting.org>2017-01-24 18:19:25 +0100
committerMartin Winter <mwinter@opensourcerouting.org>2017-01-25 18:41:56 +0100
commit66f7d8303ce844da0a5170a5f639294ca7e6b2cb (patch)
treef2865b54663c79912bd1d4d67441255f638d3254 /ldpd/ldpd.c
parentpimd: Add vty_socket cli option to override the compiled-in location for the ... (diff)
downloadfrr-66f7d8303ce844da0a5170a5f639294ca7e6b2cb.tar.xz
frr-66f7d8303ce844da0a5170a5f639294ca7e6b2cb.zip
ldpd: Add vty_socket cli option to override the compiled-in location for the VTY Socket
Signed-off-by: Martin Winter <mwinter@opensourcerouting.org>
Diffstat (limited to 'ldpd/ldpd.c')
-rw-r--r--ldpd/ldpd.c12
1 files changed, 11 insertions, 1 deletions
diff --git a/ldpd/ldpd.c b/ldpd/ldpd.c
index 8a9847bdf..5d0e79aec 100644
--- a/ldpd/ldpd.c
+++ b/ldpd/ldpd.c
@@ -115,7 +115,11 @@ struct zebra_privs_t ldpd_privs =
.cap_num_i = 0
};
+/* VTY Socket prefix */
+char vty_sock_path[MAXPATHLEN] = LDP_VTYSH_PATH;
+
/* LDPd options. */
+#define OPTION_VTYSOCK 1000
static struct option longopts[] =
{
{ "daemon", no_argument, NULL, 'd'},
@@ -126,6 +130,7 @@ static struct option longopts[] =
{ "help", no_argument, NULL, 'h'},
{ "vty_addr", required_argument, NULL, 'A'},
{ "vty_port", required_argument, NULL, 'P'},
+ { "vty_socket", required_argument, NULL, OPTION_VTYSOCK},
{ "user", required_argument, NULL, 'u'},
{ "group", required_argument, NULL, 'g'},
{ "version", no_argument, NULL, 'v'},
@@ -148,6 +153,7 @@ Daemon which manages LDP.\n\n\
-z, --socket Set path of zebra socket\n\
-A, --vty_addr Set vty's bind address\n\
-P, --vty_port Set vty's port number\n\
+ --vty_socket Override vty socket path\n\
-u, --user User to run as\n\
-g, --group Group to run as\n\
-v, --version Print program version\n\
@@ -212,6 +218,7 @@ main(int argc, char *argv[])
char *p;
char *vty_addr = NULL;
int vty_port = LDP_VTY_PORT;
+ char *vty_sock_name;
int daemon_mode = 0;
const char *user = NULL;
const char *group = NULL;
@@ -272,6 +279,9 @@ main(int argc, char *argv[])
if (vty_port <= 0 || vty_port > 0xffff)
vty_port = LDP_VTY_PORT;
break;
+ case OPTION_VTYSOCK:
+ set_socket_path(vty_sock_path, LDP_VTYSH_PATH, optarg, sizeof (vty_sock_path));
+ break;
case 'u':
user = optarg;
break;
@@ -410,7 +420,7 @@ main(int argc, char *argv[])
pid_output(pid_file);
/* Create VTY socket */
- vty_serv_sock(vty_addr, vty_port, LDP_VTYSH_PATH);
+ vty_serv_sock(vty_addr, vty_port, vty_sock_path);
/* Print banner. */
log_notice("LDPd %s starting: vty@%d", FRR_VERSION, vty_port);