|
|
- #!/bin/sh /etc/rc.common
- # Copyright (C) 2017 OpenWrt.org
-
- USE_PROCD=1
-
- START=90
- STOP=10
-
- # default params
- PROG=/usr/sbin/i2pd
- USER="i2pd"
- GROUP="i2pd"
- PIDFILE=/var/run/i2pd.pid
- #DATADIR=/var/lib/i2pd
- CONFFILE=/etc/i2pd/i2pd.conf
-
- . /lib/functions.sh
-
-
-
- i2pd_start() {
- local cfg="$1"
- local data_dir
- local addressbook_dir
-
- config_get data_dir "$cfg" data_dir
- config_get addressbook_dir "$cfg" addressbook_dir
-
- ## Setting up data dir
- if [ ! -d "$data_dir" ]; then
- mkdir -p "$data_dir"
- ln -s /usr/share/i2pd/certificates "$data_dir/certificates"
- ln -s /etc/i2pd/tunnels.conf "$data_dir/tunnels.conf"
- if [ -n "$addressbook_dir" ]; then
- if [ ! -d "$addressbook_dir" ]; then
- mkdir -p "$addressbook_dir"
- fi
- ln -s "$addressbook_dir" "$data_dir/addressbook"
- fi
- fi
-
- ## We need permissions
- chown "$USER:$GROUP" "$data_dir"
- chown "$USER:$GROUP" "$addressbook_dir"
- touch "$PIDFILE"
- chown "$USER:adm" "$PIDFILE"
-
- procd_open_instance
- procd_set_param command "$PROG" --service --conf="$CONFFILE" --pidfile "$PIDFILE"
- ## Don't know about i2pd user's HOME
- procd_set_param env "HOME=$DATADIR"
- procd_set_param limits nofile=4096
- procd_set_param stdout 1
- procd_set_param stderr 1
- procd_set_param user "$USER"
- procd_set_param pidfile "$PIDFILE"
- procd_close_instance
- }
-
-
- start_service() {
- local instance="$1"
- local instance_found=0
-
- config_cb() {
- local type="$1"
- local name="$2"
- if [ "$type" = "i2pd" ]; then
- if [ -n "$instance" ] && [ "$instance" = "$name" ]; then
- instance_found=1
- fi
- fi
- }
-
- config_load i2pd
-
- if [ -n "$instance" ]; then
- [ "$instance_found" -gt 0 ] || return
- i2pd_start "$instance"
- else
- config_foreach i2pd_start i2pd
- fi
- }
|