Merge pull request #2823 from opensourcerouting/snap-staticd

Updates to snap package to support staticd
This commit is contained in:
Donald Sharp 2018-08-14 07:48:15 -04:00 committed by GitHub
commit 4354a8052c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 32 additions and 1 deletions

View File

@ -234,6 +234,7 @@ EXTRA_DIST = frr-sphinx.mk \
user/vnc.rst \
user/vtysh.rst \
user/zebra.rst \
user/flowspec.rst \
mpls/ChangeLog.opaque.txt \
mpls/ospfd.conf \
mpls/cli_summary.txt \

View File

View File

@ -15,6 +15,7 @@ install:
install -D -m 0755 babeld-service $(DESTDIR)/bin/
install -D -m 0755 eigrpd-service $(DESTDIR)/bin/
install -D -m 0755 pbrd-service $(DESTDIR)/bin/
install -D -m 0755 staticd-service $(DESTDIR)/bin/
install -D -m 0755 set-options $(DESTDIR)/bin/
install -D -m 0755 show_version $(DESTDIR)/bin/

View File

@ -0,0 +1,20 @@
#!/bin/sh
set -e -x
if ! [ -e $SNAP_DATA/staticd.conf ]; then
if [ -e $SNAP_DATA/zebra.conf ]; then
# if we have a zebra.conf, but no staticd conf, then we use
# this file as the default config for staticd
cp $SNAP_DATA/zebra.conf $SNAP_DATA/staticd.conf
else
# new config, start with template
cp $SNAP/etc/frr/staticd.conf $SNAP_DATA/staticd.conf
fi
fi
exec $SNAP/sbin/staticd \
-f $SNAP_DATA/staticd.conf \
--pid_file $SNAP_DATA/staticd.pid \
--socket $SNAP_DATA/zsock \
--vty_socket $SNAP_DATA

View File

@ -113,6 +113,13 @@ apps:
- network
- network-bind
- network-control
staticd:
command: bin/staticd-service
daemon: simple
plugs:
- network
- network-bind
- network-control
set:
command: bin/set-options
zebra-debug:
@ -193,6 +200,8 @@ apps:
- network
- network-bind
- network-control
staticd-debug:
command: sbin/staticd -f $SNAP_DATA/staticd.conf --pid_file $SNAP_DATA/staticd.pid --socket $SNAP_DATA/zsock --vty_socket $SNAP_DATA
parts:
frr:

View File

@ -356,7 +356,7 @@ int main(int argc, char **argv, char **env)
break;
case OPTION_CONFDIR:
ditch_suid = 1; /* option disables SUID */
strlcpy(sysconfdir, optarg, sizeof(sysconfdir));
snprintf(sysconfdir, sizeof(sysconfdir), "%s/", optarg);
break;
case 'N':
if (strchr(optarg, '/') || strchr(optarg, '.')) {