diff options
Diffstat (limited to 'buildtools/debian-skeleton')
-rw-r--r-- | buildtools/debian-skeleton/control | 2 | ||||
-rw-r--r-- | buildtools/debian-skeleton/rpki-ca.default | 10 | ||||
-rw-r--r-- | buildtools/debian-skeleton/rpki-ca.init.d | 199 | ||||
-rw-r--r-- | buildtools/debian-skeleton/rpki-ca.upstart | 51 |
4 files changed, 210 insertions, 52 deletions
diff --git a/buildtools/debian-skeleton/control b/buildtools/debian-skeleton/control index 9f0d350b..993de8c3 100644 --- a/buildtools/debian-skeleton/control +++ b/buildtools/debian-skeleton/control @@ -30,7 +30,7 @@ Replaces: rpki-ca (<= 0.5767) Package: rpki-ca Architecture: any -Depends: ${shlibs:Depends}, ${misc:Depends}, python (>= 2.7), apache2, ssl-cert, python-lxml, postgresql, postgresql-client, python-psycopg2, python-django (>= 1.8.0), python-tornado, libapache2-mod-wsgi, python-vobject, python-yaml, python-netifaces, rpki-rp (= ${binary:Version}) +Depends: ${shlibs:Depends}, ${misc:Depends}, python (>= 2.7), apache2, ssl-cert, python-lxml, postgresql, postgresql-client, python-psycopg2, python-django (>= 1.8.0), python-tornado, libapache2-mod-wsgi, python-vobject, python-yaml, python-netifaces, rpki-rp (= ${binary:Version}), lsb-base (>= 3.2-14) Description: rpki.net certification authority tools "Certification authority" tools for issuing RPKI certificates and related objects using the rpki.net toolkit. diff --git a/buildtools/debian-skeleton/rpki-ca.default b/buildtools/debian-skeleton/rpki-ca.default new file mode 100644 index 00000000..503d5fc6 --- /dev/null +++ b/buildtools/debian-skeleton/rpki-ca.default @@ -0,0 +1,10 @@ +# Defaults for rpki-ca initscript +# sourced by /etc/init.d/rpki-ca +# installed at /etc/default/rpki-ca by the maintainer scripts + +# +# This is a POSIX shell fragment +# + +# Additional options that are passed to rpki-start-servers. +STARTER_OPTS="--log-level warning --log-directory /var/log/rpki --log-rotating-file-hours 3 --log-backup-count 56" diff --git a/buildtools/debian-skeleton/rpki-ca.init.d b/buildtools/debian-skeleton/rpki-ca.init.d new file mode 100644 index 00000000..437de18b --- /dev/null +++ b/buildtools/debian-skeleton/rpki-ca.init.d @@ -0,0 +1,199 @@ +#!/bin/sh +### BEGIN INIT INFO +# Provides: rpki-ca +# Required-Start: $local_fs $network $remote_fs $syslog postgresql +# Required-Stop: $local_fs $network $remote_fs $syslog postgresql +# Default-Start: 2 3 4 5 +# Default-Stop: 0 1 6 +# Short-Description: RPKI CA Servers +### END INIT INFO + +# Author: Rob Austein <sra@hactrn.net> + +# PATH should only include /usr/* if it runs after the mountnfs.sh script +PATH=/sbin:/usr/sbin:/bin:/usr/bin +DESC="rpki-ca" +NAME=rpki-ca +STARTER=/usr/sbin/rpki-start-servers +STARTER_OPTS="--log-level warning --log-directory /var/log/rpki --log-rotating-file-hours 3 --log-backup-count 56" +PIDDIR=/var/run/rpki +SCRIPTNAME=/etc/init.d/$NAME + +# Exit if the package is not installed +test -x "$STARTER" || exit 0 + +# Read configuration variable file if it is present +test -r /etc/default/$NAME && . /etc/default/$NAME + +# Load the VERBOSE setting and other rcS variables +. /lib/init/vars.sh + +# Define LSB log_* functions. +# Depend on lsb-base (>= 3.2-14) to ensure that this file is present +# and status_of_proc is working. +. /lib/lsb/init-functions + +# +# Extract list of enabled RPKI daemons from config file. +# + +enabled_daemons() +{ + python -c 'if True: + import rpki.config + cfg = rpki.config.parser(section = "myrpki") + enabled = [name for name in ("rpkid", "irdbd", "pubd", "rootd") + if cfg.getboolean("run_{}".format("rpkid" if name == "irdbd" else name))] + for name in sorted(enabled): + print name + ' +} + +# +# Figure out which daemons are actually running at the moment. +# + +running_daemons() +{ + for pidfile in $PIDDIR/*.pid + do + test -f "$pidfile" || continue + cmdline=/proc/$(cat $pidfile)/cmdline + name=${pidfile##*/} + test -f $cmdline && + awk -v name=${name%.pid} 'BEGIN {FS="\0"} $2 ~ ("/" name "$") {print name}' $cmdline + done +} + +# +# Function that starts the daemon/service +# +do_start() +{ + # Return + # 0 if daemon has been started + # 1 if daemon was already running + # 2 if daemon could not be started + + test -f /etc/rpki.conf || return 2 + + enabled="$(enabled_daemons)" + running="$(running_daemons)" + + test "X$enabled" = "X" && return 0 + test "X$enabled" = "X$running" && return 1 + + test -d $PIDDIR || install -d -u rpki -g rpki $PIDDIR || return 2 + + test -f /usr/share/rpki/bpki/ca.cer || return 2 + test -f /usr/share/rpki/bpki/irbe.cer || return 2 + + case $enabled in + *rpkid*) + test -f /usr/share/rpki/bpki/irdbd.cer || return 2 + test -f /usr/share/rpki/bpki/rpkid.cer || return 2 + test -f /usr/share/rpki/bpki/rpkid.key || return 2 + esac + + case $enabled in + *pubd*) + test -f /usr/share/rpki/bpki/pubd.cer || return 2 + test -f /usr/share/rpki/bpki/pubd.key || return 2 + + for dir in /usr/share/rpki/publication /usr/share/rpki/rrdp-publication + do + test -d $dir || install -d -u rpki -g rpki $dir || return 2 + done + esac + + case $enabled in + *rootd*) + test -f /usr/share/rpki/bpki/rootd.cer || return 2 + test -f /usr/share/rpki/bpki/rootd.key || return 2 + test -f /usr/share/rpki/root.cer || return 2 + test -f /usr/share/rpki/root.key || return 2 + esac + + $STARTER $STARTER_OPTS || return 2 +} + +# +# Function that stops the daemon/service +# +do_stop() +{ + # Return + # 0 if daemon has been stopped + # 1 if daemon was already stopped + # 2 if daemon could not be stopped + # other if a failure occurred + + running="$(running_daemons)" + + test "X$running" = "X" && return 1 + + for name in $running + do + kill $(cat $PIDDIR/$name.pid) + done + return 0 +} + +case "$1" in + start) + test "$VERBOSE" != no && log_daemon_msg "Starting $DESC" "$NAME" + do_start + case "$?" in + 0|1) test "$VERBOSE" != no && log_end_msg 0 ;; + 2) test "$VERBOSE" != no && log_end_msg 1 ;; + esac + ;; + stop) + test "$VERBOSE" != no && log_daemon_msg "Stopping $DESC" "$NAME" + do_stop + case "$?" in + 0|1) test "$VERBOSE" != no && log_end_msg 0 ;; + 2) test "$VERBOSE" != no && log_end_msg 1 ;; + esac + ;; + status) + enabled="$(enabled_daemons)" + running="$(running_daemons)" + if test "X$running" = "X" + then + log_success_msg "rpki-ca is not running" + exit 3 + elif test "X$running" = "X$enabled" + then + log_success_msg "rpki-ca is running" + exit 0 + else + log_success_msg "some rpki-ca daemons are running" + exit 4 + fi + ;; + restart|force-reload) + log_daemon_msg "Restarting $DESC" "$NAME" + do_stop + case "$?" in + 0|1) + do_start + case "$?" in + 0) log_end_msg 0 ;; + 1) log_end_msg 1 ;; # Old process is still running + *) log_end_msg 1 ;; # Failed to start + esac + ;; + *) + # Failed to stop + log_end_msg 1 + ;; + esac + ;; + *) + echo "Usage: $SCRIPTNAME {start|stop|status|restart|force-reload}" >&2 + exit 3 + ;; +esac + +: diff --git a/buildtools/debian-skeleton/rpki-ca.upstart b/buildtools/debian-skeleton/rpki-ca.upstart deleted file mode 100644 index 63a49fa9..00000000 --- a/buildtools/debian-skeleton/rpki-ca.upstart +++ /dev/null @@ -1,51 +0,0 @@ -# RPKI CA Service - -description "RPKI CA Servers" -author "Rob Austein <sra@hactrn.net>" - -# This is almost certainly wrong. Suggestions on how to improve this -# welcome, but please first read the Python code to understand what it -# is doing. - -# Our only real dependencies are on our SQL engine and our config file. -# -# Unfortunately, the switch to postgresql means we can't use a straightforward -# upstart dependency here, because postgresql uses an old-style init.d script. -# But everybody is moving to systemd, so we're going to have to rewrite this -# in any case. - -# FWIW, "/etc/init.d/postgres status" returns a status line ending in "online" -# when the server is up, "down" when the server is down, and perhaps other values -# under stranger circumstances. - -#start on started mysql -#stop on stopping mysql - -start on runlevel [2345] -stop on runlevel [!2345] - -pre-start script - if test -f /etc/rpki.conf && - test -f /usr/share/rpki/bpki/ca.cer && - test -f /usr/share/rpki/bpki/irbe.cer && - test -f /usr/share/rpki/bpki/irdbd.cer && - test -f /usr/share/rpki/bpki/rpkid.cer && - test -f /usr/share/rpki/bpki/rpkid.key - then - install -m 755 -o rpki -g rpki -d /var/run/rpki /usr/share/rpki/publication /usr/share/rpki/rrdp-publication - rpki-start-servers - else - stop - exit 0 - fi -end script - -post-stop script - for i in rpkid pubd irdbd rootd - do - if test -f /var/run/rpki/$i.pid - then - kill `cat /var/run/rpki/$i.pid` - fi - done -end script |