#!/bin/sh /etc/rc.common
|
|
# Copyright (C) 2015 OpenWrt.org
|
|
|
|
START=90
|
|
|
|
USE_PROCD=1
|
|
PROG=/usr/lib/gnunet/libexec/gnunet-service-arm
|
|
|
|
GNUNET_HOME=/var/run/gnunet
|
|
# LOGFILE=$GNUNET_HOME/gnunet.log
|
|
CONFIGFILE=$GNUNET_HOME/gnunet.conf
|
|
SUID_ROOT_HELPERS="exit nat-server nat-client transport-bluetooth transport-wlan vpn"
|
|
EXTRA_COMMANDS="restart_transport"
|
|
|
|
chmodown_execbin() {
|
|
execname=/usr/lib/gnunet/libexec/gnunet-$1
|
|
if [ -x $execname ]; then
|
|
if [ "$3" ]; then
|
|
chown $3 $execname 2>/dev/null && chmod $2 $execname
|
|
else
|
|
chmod $2 $execname
|
|
fi
|
|
fi
|
|
}
|
|
|
|
fix_libexec_permissions() {
|
|
[ -e /usr/share/gnunet/.permfix ] && return
|
|
for helper in $SUID_ROOT_HELPERS; do
|
|
chmodown_execbin helper-$helper u+s
|
|
done
|
|
chmodown_execbin helper-dns 4750 root:gnunetdns
|
|
chmodown_execbin service-dns 2750 gnunet:gnunetdns
|
|
|
|
touch /usr/share/gnunet/.permfix
|
|
}
|
|
|
|
prepare_config() {
|
|
local had_exit_service=0;
|
|
|
|
if [ ! -e "$GNUNET_HOME" ]; then
|
|
mkdir -p $GNUNET_HOME
|
|
chown gnunet:gnunet $GNUNET_HOME
|
|
chmod 0750 $GNUNET_HOME
|
|
fi
|
|
touch $CONFIGFILE
|
|
chown gnunet:gnunet $CONFIGFILE
|
|
chmod 0640 $CONFIGFILE
|
|
gnunet-config -c $CONFIGFILE -w -s PATHS -o GNUNET_HOME -V $GNUNET_HOME
|
|
|
|
# minimal persistency in /etc/gnunet
|
|
[ ! -d /etc/gnunet ] && {
|
|
mkdir -p /etc/gnunet
|
|
chown gnunet:gnunet /etc/gnunet
|
|
}
|
|
|
|
# defaults paths for persistent files
|
|
gnunet-config -c $CONFIGFILE -w -s PATHS -o GNUNET_CONFIG_HOME -V /etc/gnunet
|
|
gnunet-config -c $CONFIGFILE -w -s PEER -o PRIVATE_KEY -V /etc/gnunet/private_key.ecc
|
|
gnunet-config -c $CONFIGFILE -w -s identity -o EGODIR -V /etc/gnunet/identity/egos
|
|
gnunet-config -c $CONFIGFILE -w -s revocation -o DATABASE -V /etc/gnunet/revocation.dat
|
|
gnunet-config -c $CONFIGFILE -w -s nse -o PROOFFILE -V /etc/gnunet/proof.dat
|
|
|
|
# enable all installed transport plugins
|
|
transport_plugins=$(gnunet-config -c $CONFIGFILE -s transport -o PLUGINS)
|
|
for transplug in /usr/lib/gnunet/libgnunet_plugin_transport_*.so; do
|
|
transplug=$( echo $transplug |
|
|
sed -ne 's!^.*_transport_\(.*\)\.so$!\1!p' )
|
|
[ -n "$( echo $transport_plugins | grep $transplug )" ] ||
|
|
transport_plugins="$transport_plugins $transplug"
|
|
done
|
|
gnunet-config -c $CONFIGFILE -w -s transport -o PLUGINS -V "$transport_plugins"
|
|
|
|
# do not touch sysctl, iptables and routing
|
|
gnunet-config -c $CONFIGFILE -w -s dns -o SKIP_ROUTING_SETUP -V YES
|
|
gnunet-config -c $CONFIGFILE -w -s exit -o EXIT_IFNAME -V ''
|
|
|
|
# apply config from UCI
|
|
_gnunet_section=""
|
|
config_cb()
|
|
{
|
|
# $1 "Type"
|
|
# $2 "Name"
|
|
local __TYPE="$1"
|
|
local __NAME="${2/_/-}"
|
|
[ "${__TYPE}" = "gnunet-config" ] && _gnunet_section="${__NAME}"
|
|
[ "${__TYPE}" = "gnunet-exit-service" ] && {
|
|
had_exit_service=1
|
|
_gnunet_section="${__NAME}.gnunet."
|
|
}
|
|
}
|
|
option_cb() {
|
|
# $1 name of variable
|
|
# $2 value
|
|
local __OPT="$1"
|
|
local __VAL="$2"
|
|
gnunet-config -c $CONFIGFILE -w -s ${_gnunet_section} -o ${__OPT} -V "${__VAL}"
|
|
}
|
|
|
|
config_load gnunet
|
|
|
|
[ "$had_exit_service" -eq 1 ] && gnunet-config -c $CONFIGFILE -w -s exit -o FORCESTART -V YES
|
|
|
|
return 0
|
|
}
|
|
|
|
restart_transport() {
|
|
gnunet-arm -c $CONFIGFILE -k transport
|
|
gnunet-arm -c $CONFIGFILE -i transport
|
|
}
|
|
|
|
start_service() {
|
|
fix_libexec_permissions
|
|
prepare_config
|
|
|
|
procd_open_instance
|
|
procd_set_param user gnunet
|
|
# procd_set_param env GNUNET_LOG="dht;;;;info"
|
|
procd_set_param stderr 1
|
|
procd_set_param command $PROG -c $CONFIGFILE
|
|
[ "$LOGFILE" ] && procd_append_param command -l $LOGFILE
|
|
procd_set_param respawn
|
|
procd_close_instance
|
|
}
|
|
|
|
service_triggers()
|
|
{
|
|
procd_add_reload_trigger "gnunet"
|
|
procd_add_raw_trigger "interface.*.up" 3000 /etc/init.d/gnunet restart_transport
|
|
}
|