nfd: Add systemd startup scripts
refs #2810
Change-Id: Ib710edddcd94d78104247d8ed70d536263a5c40a
diff --git a/nfd/debian/control b/nfd/debian/control
index ababa42..3e59b84 100644
--- a/nfd/debian/control
+++ b/nfd/debian/control
@@ -2,6 +2,7 @@
Priority: extra
Maintainer: Alexander Afanasyev <alexander.afanasyev@ucla.edu>
Build-Depends: debhelper (>= 8.0.0),
+ dh-systemd (>= 1.5),
python (>= 2.7.0),
pkg-config (>= 0.26),
ndn-cxx-dev (>= 0.3.0~rc0.2),
diff --git a/nfd/debian/control.trusty b/nfd/debian/control.trusty
new file mode 100644
index 0000000..ababa42
--- /dev/null
+++ b/nfd/debian/control.trusty
@@ -0,0 +1,42 @@
+Source: nfd
+Priority: extra
+Maintainer: Alexander Afanasyev <alexander.afanasyev@ucla.edu>
+Build-Depends: debhelper (>= 8.0.0),
+ python (>= 2.7.0),
+ pkg-config (>= 0.26),
+ ndn-cxx-dev (>= 0.3.0~rc0.2),
+ python-sphinx,
+ libpcap-dev,
+ libboost-all-dev (>= 1.48.0)
+Standards-Version: 3.9.2
+Section: net
+Homepage: http://named-data.net/doc/NFD/
+Vcs-Git: git://github.com/named-data/NFD.git
+Vcs-Browser: http://github.com/named-data/NFD
+
+Package: nfd
+Architecture: i386 amd64
+Depends: ${shlibs:Depends}, ${misc:Depends}, ndn-cxx, sudo, procps
+Description: NFD - Named Data Networking Forwarding Daemon
+ NFD is a network forwarder that implements and evolves together with the Named Data
+ Networking (NDN) protocol.
+
+Package: nfd-status-http-server
+Architecture: i386 amd64
+Depends: nfd (= ${binary:Version}), ${misc:Depends}, python2.7-minimal
+Description: NFD HTTP status server
+
+Package: nfd-autoreg
+Architecture: i386 amd64
+Depends: nfd (= ${binary:Version}), ${misc:Depends}
+Description: NFD autoreg server
+
+Package: ndn-autoconfig-server
+Architecture: i386 amd64
+Depends: nfd (= ${binary:Version}), ${misc:Depends}
+Description: NDN autoconfig server
+
+Package: nfd-all
+Architecture: any
+Depends: ${misc:Depends}, nfd, nfd-status-http-server, nfd-autoreg, ndn-autoconfig-server
+Description: NFD and all related daemons
diff --git a/nfd/debian/ndn-autoconfig-server.service b/nfd/debian/ndn-autoconfig-server.service
new file mode 100644
index 0000000..53e2de4
--- /dev/null
+++ b/nfd/debian/ndn-autoconfig-server.service
@@ -0,0 +1,44 @@
+# Copyright (c) 2015, Regents of the University of California,
+# Arizona Board of Regents,
+# Colorado State University,
+# University Pierre & Marie Curie, Sorbonne University,
+# Washington University in St. Louis,
+# Beijing Institute of Technology,
+# The University of Memphis.
+#
+# This file is part of NFD (Named Data Networking Forwarding Daemon).
+# See AUTHORS.md for complete list of NFD authors and contributors.
+#
+# NFD is free software: you can redistribute it and/or modify it under the terms
+# of the GNU General Public License as published by the Free Software Foundation,
+# either version 3 of the License, or (at your option) any later version.
+#
+# NFD is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
+# without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
+# PURPOSE. See the GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License along with
+# NFD, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
+#
+# Author: Eric Newberry <enewberry@email.arizona.edu>
+
+[Unit]
+Description=NDN Autoconfig Server
+Documentation=man:nfd-autoreg
+Requires=nfd.service
+After=nfd.service
+
+[Service]
+Environment=HOME=/var/lib/ndn/ndn-autoconfig-server
+EnvironmentFile=-/etc/default/ndn-autoconfig-server
+User=ndn
+Group=ndn
+ExecStart=/bin/sh -ec 'if [ "$FACE_URI" != "" ]; then exec /usr/bin/ndn-autoconfig-server $ROUTABLE_PREFIXES $FACE_URI; fi'
+Restart=on-failure
+ProtectSystem=full
+PrivateTmp=yes
+PrivateDevices=yes
+ProtectHome=yes
+
+[Install]
+WantedBy=multi-user.target
diff --git a/nfd/debian/nfd-autoreg.default b/nfd/debian/nfd-autoreg.default
index 218e2d3..8666a95 100644
--- a/nfd/debian/nfd-autoreg.default
+++ b/nfd/debian/nfd-autoreg.default
@@ -1,15 +1,19 @@
# nfd-autoreg defaults
# Blacklisted networks
-BLACKLIST="10.0.0.0/8"
+# Format: "-b NET1 -b NET2 ..."
+BLACKLIST="-b 10.0.0.0/8"
# Whitelisted networks
+# Format: "-w NET1 -w NET2 ..."
WHITELIST=""
# Prefixes to register on All faces:
-ALL_FACES_PREFIXES="/ndn/broadcast"
+# Format: "--all-faces-prefix /prefix/1 --all-faces-prefix /prefix/2 ..."
+ALL_FACES_PREFIXES="--all-faces-prefix /ndn/broadcast"
# Prefixes to register just on on-demand faces:
+# Format: "--prefix /prefix/1 --prefix /prefix/2 ..."
ON_DEMAND_FACES_PREFIXES=""
# Flags
diff --git a/nfd/debian/nfd-autoreg.service b/nfd/debian/nfd-autoreg.service
new file mode 100644
index 0000000..552b5c5
--- /dev/null
+++ b/nfd/debian/nfd-autoreg.service
@@ -0,0 +1,44 @@
+# Copyright (c) 2015, Regents of the University of California,
+# Arizona Board of Regents,
+# Colorado State University,
+# University Pierre & Marie Curie, Sorbonne University,
+# Washington University in St. Louis,
+# Beijing Institute of Technology,
+# The University of Memphis.
+#
+# This file is part of NFD (Named Data Networking Forwarding Daemon).
+# See AUTHORS.md for complete list of NFD authors and contributors.
+#
+# NFD is free software: you can redistribute it and/or modify it under the terms
+# of the GNU General Public License as published by the Free Software Foundation,
+# either version 3 of the License, or (at your option) any later version.
+#
+# NFD is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
+# without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
+# PURPOSE. See the GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License along with
+# NFD, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
+#
+# Author: Eric Newberry <enewberry@email.arizona.edu>
+
+[Unit]
+Description=NDN Autoreg Server
+Documentation=man:nfd-autoreg
+Wants=nfd.service
+After=nfd.service
+
+[Service]
+User=ndn
+Group=ndn
+Environment=HOME=/var/lib/ndn/nfd-autoreg
+EnvironmentFile=-/etc/default/nfd-autoreg
+ExecStart=/usr/bin/nfd-autoreg $BLACKLIST $WHITELIST $ON_DEMAND_FACES_PREFIXES $ALL_FACES_PREFIXES $FLAGS
+Restart=on-failure
+ProtectSystem=full
+PrivateTmp=yes
+PrivateDevices=yes
+ProtectHome=yes
+
+[Install]
+WantedBy=multi-user.target
\ No newline at end of file
diff --git a/nfd/debian/nfd-autoreg.upstart b/nfd/debian/nfd-autoreg.upstart
index dc0bd7f..379e8ec 100644
--- a/nfd/debian/nfd-autoreg.upstart
+++ b/nfd/debian/nfd-autoreg.upstart
@@ -20,26 +20,6 @@
. /etc/default/nfd-autoreg
fi
- blacklist=""
- if [ "$BLACKLIST" != "" ]; then
- blacklist=`for i in $BLACKLIST; do echo -n "-b $i "; done`
- fi
-
- whitelist=""
- if [ "$WHITELIST" != "" ]; then
- whitelist=`for i in $WHITELIST; do echo -n "-w $i "; done`
- fi
-
- all_prefixes=""
- if [ "$ALL_FACES_PREFIXES" != "" ]; then
- all_prefixes=`for i in $ALL_FACES_PREFIXES; do echo -n "--all-faces-prefix $i "; done`
- fi
-
- on_demand_prefixes=""
- if [ "$ON_DEMAND_FACES_PREFIXES" != "" ]; then
- on_demand_prefixes=`for i in $ON_DEMAND_FACES_PREFIXES; do echo -n "--prefix $i "; done`
- fi
-
export HOME=/var/lib/ndn/nfd-autoreg
- exec /usr/bin/nfd-autoreg $blacklist $whitelist $on_demand_prefixes $all_prefixes $FLAGS
+ exec /usr/bin/nfd-autoreg $BLACKLIST $WHITELIST $ON_DEMAND_FACES_PREFIXES $ALL_FACES_PREFIXES $FLAGS
end script
diff --git a/nfd/debian/nfd-start b/nfd/debian/nfd-start
index 0edfea9..d350776 100755
--- a/nfd/debian/nfd-start
+++ b/nfd/debian/nfd-start
@@ -1,3 +1,3 @@
#!/bin/sh
-sudo start nfd
+sudo systemctl start nfd
diff --git a/nfd/debian/nfd-start.precise b/nfd/debian/nfd-start.precise
new file mode 100755
index 0000000..0edfea9
--- /dev/null
+++ b/nfd/debian/nfd-start.precise
@@ -0,0 +1,3 @@
+#!/bin/sh
+
+sudo start nfd
diff --git a/nfd/debian/nfd-start.trusty b/nfd/debian/nfd-start.trusty
new file mode 100755
index 0000000..0edfea9
--- /dev/null
+++ b/nfd/debian/nfd-start.trusty
@@ -0,0 +1,3 @@
+#!/bin/sh
+
+sudo start nfd
diff --git a/nfd/debian/nfd-status-http-server.service b/nfd/debian/nfd-status-http-server.service
new file mode 100644
index 0000000..3088a83
--- /dev/null
+++ b/nfd/debian/nfd-status-http-server.service
@@ -0,0 +1,40 @@
+# Copyright (c) 2015, Regents of the University of California,
+# Arizona Board of Regents,
+# Colorado State University,
+# University Pierre & Marie Curie, Sorbonne University,
+# Washington University in St. Louis,
+# Beijing Institute of Technology,
+# The University of Memphis.
+#
+# This file is part of NFD (Named Data Networking Forwarding Daemon).
+# See AUTHORS.md for complete list of NFD authors and contributors.
+#
+# NFD is free software: you can redistribute it and/or modify it under the terms
+# of the GNU General Public License as published by the Free Software Foundation,
+# either version 3 of the License, or (at your option) any later version.
+#
+# NFD is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
+# without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
+# PURPOSE. See the GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License along with
+# NFD, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
+#
+# Author: Eric Newberry <enewberry@email.arizona.edu>
+
+[Unit]
+Description=NFD HTTP Status Server
+Documentation=man:nfd-status-http-server
+After=nfd.service
+
+[Service]
+EnvironmentFile=-/etc/default/nfd-status-http-server
+ExecStart=/usr/bin/nfd-status-http-server $FLAGS
+Restart=on-failure
+ProtectSystem=full
+PrivateTmp=yes
+PrivateDevices=yes
+ProtectHome=yes
+
+[Install]
+WantedBy=multi-user.target
\ No newline at end of file
diff --git a/nfd/debian/nfd-status-http-server.upstart b/nfd/debian/nfd-status-http-server.upstart
index 21740ea..df28359 100644
--- a/nfd/debian/nfd-status-http-server.upstart
+++ b/nfd/debian/nfd-status-http-server.upstart
@@ -1,4 +1,4 @@
-description "NDN HTTP Status Server"
+description "NFD HTTP Status Server"
author "Alexander Afanasyev <alexander.afanasyev@ucla.edu>"
start on started nfd
diff --git a/nfd/debian/nfd-stop b/nfd/debian/nfd-stop
index 2069e9c..301cf15 100755
--- a/nfd/debian/nfd-stop
+++ b/nfd/debian/nfd-stop
@@ -1,3 +1,3 @@
#!/bin/sh
-sudo stop nfd
+sudo systemctl stop nfd
diff --git a/nfd/debian/nfd-stop.precise b/nfd/debian/nfd-stop.precise
new file mode 100755
index 0000000..2069e9c
--- /dev/null
+++ b/nfd/debian/nfd-stop.precise
@@ -0,0 +1,3 @@
+#!/bin/sh
+
+sudo stop nfd
diff --git a/nfd/debian/nfd-stop.trusty b/nfd/debian/nfd-stop.trusty
new file mode 100755
index 0000000..2069e9c
--- /dev/null
+++ b/nfd/debian/nfd-stop.trusty
@@ -0,0 +1,3 @@
+#!/bin/sh
+
+sudo stop nfd
diff --git a/nfd/debian/nfd.service b/nfd/debian/nfd.service
new file mode 100644
index 0000000..873cf42
--- /dev/null
+++ b/nfd/debian/nfd.service
@@ -0,0 +1,42 @@
+# Copyright (c) 2015, Regents of the University of California,
+# Arizona Board of Regents,
+# Colorado State University,
+# University Pierre & Marie Curie, Sorbonne University,
+# Washington University in St. Louis,
+# Beijing Institute of Technology,
+# The University of Memphis.
+#
+# This file is part of NFD (Named Data Networking Forwarding Daemon).
+# See AUTHORS.md for complete list of NFD authors and contributors.
+#
+# NFD is free software: you can redistribute it and/or modify it under the terms
+# of the GNU General Public License as published by the Free Software Foundation,
+# either version 3 of the License, or (at your option) any later version.
+#
+# NFD is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
+# without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
+# PURPOSE. See the GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License along with
+# NFD, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
+#
+# Author: Eric Newberry <enewberry@email.arizona.edu>
+
+[Unit]
+Description=NDN Forwarding Daemon
+Documentation=man:nfd man:nfdc man:nfd-status
+Wants=network-online.target
+After=network-online.target
+
+[Service]
+Environment=HOME=/var/lib/ndn/nfd
+ExecStart=/usr/bin/nfd --config /etc/ndn/nfd.conf
+ExecStartPost=/bin/sh -ec 'sleep 2; if [ -f /etc/ndn/nfd-init.sh ]; then . /etc/ndn/nfd-init.sh; fi'
+Restart=on-failure
+ProtectSystem=full
+PrivateTmp=yes
+PrivateDevices=yes
+ProtectHome=yes
+
+[Install]
+WantedBy=multi-user.target
diff --git a/nfd/debian/rules b/nfd/debian/rules
index b4d146e..cde2d83 100755
--- a/nfd/debian/rules
+++ b/nfd/debian/rules
@@ -14,7 +14,7 @@
CXXFLAGS += -std=c++11
%:
- dh $@ --parallel
+ dh $@ --parallel --with=systemd
override_dh_auto_configure:
CXXFLAGS="$(CXXFLAGS)" ./waf configure --prefix=/usr --sysconfdir=/etc --localstatedir=/var
@@ -37,7 +37,14 @@
override_dh_auto_test:
-override_dh_installinit:
- dh_installinit
- dh_installinit --name=nrd
- dh_installinit --name=nfd-restart
+override_dh_systemd_enable:
+ dh_systemd_enable -pnfd
+ dh_systemd_enable -pnfd-status-http-server
+ dh_systemd_enable -pndn-autoconfig-server --no-enable
+ dh_systemd_enable -pnfd-autoreg --no-enable
+
+override_dh_systemd_start:
+ dh_systemd_start -pnfd
+ dh_systemd_start -pnfd-status-http-server
+ dh_systemd_start -pndn-autoconfig-server --no-start
+ dh_systemd_start -pnfd-autoreg --no-start
diff --git a/nfd/debian/rules.precise b/nfd/debian/rules.precise
index 07f0c82..437c89b 100755
--- a/nfd/debian/rules.precise
+++ b/nfd/debian/rules.precise
@@ -36,8 +36,3 @@
rm -f docs/*.pyc
override_dh_auto_test:
-
-override_dh_installinit:
- dh_installinit
- dh_installinit --name=nrd
- dh_installinit --name=nfd-restart
diff --git a/nfd/debian/rules.trusty b/nfd/debian/rules.trusty
new file mode 100755
index 0000000..5318c7e
--- /dev/null
+++ b/nfd/debian/rules.trusty
@@ -0,0 +1,38 @@
+#!/usr/bin/make -f
+# -*- makefile -*-
+# Sample debian/rules that uses debhelper.
+# This file was originally written by Joey Hess and Craig Small.
+# As a special exception, when this file is copied by dh-make into a
+# dh-make output file, you may use that output file without restriction.
+# This special exception was added by Craig Small in version 0.37 of dh-make.
+
+# Uncomment this to turn on verbose mode.
+# export DH_VERBOSE=1
+
+LDFLAGS := $(shell dpkg-buildflags --get LDFLAGS)
+CXXFLAGS := $(shell dpkg-buildflags --get CXXFLAGS)
+CXXFLAGS += -std=c++11
+
+%:
+ dh $@ --parallel
+
+override_dh_auto_configure:
+ CXXFLAGS="$(CXXFLAGS)" ./waf configure --prefix=/usr --sysconfdir=/etc --localstatedir=/var
+
+override_dh_auto_build:
+ ./waf build
+
+override_dh_auto_install:
+ ./waf install --destdir=debian/tmp
+
+override_dh_auto_clean:
+ ./waf distclean
+
+override_dh_clean:
+ dh_clean
+ ./waf distclean
+ rm -rf .waf-1*
+ rm -f .waf-tools/*.pyc
+ rm -f docs/*.pyc
+
+override_dh_auto_test:
diff --git a/packaging.mk b/packaging.mk
index 925db1d..6d34f9f 100644
--- a/packaging.mk
+++ b/packaging.mk
@@ -30,7 +30,7 @@
$(MAKE) _build DEBUILD="debuild -S -sa"
build:
- $(MAKE) _build DEBUILD=debuild DISTROS=trusty
+ $(MAKE) _build DEBUILD=debuild
install: build
sudo dpkg -i work/*.deb