#!/bin/sh /etc/rc.common # Copyright (C) 2019 Ycarus (Yannick Chabanois) for OpenMPTCProuter project START=90 STOP=10 USE_PROCD=1 PROG_NAME=dsvpn PROG=/usr/sbin/${PROG_NAME} _log() { logger -p daemon.info -t ${PROG_NAME} "$@" } _err() { logger -p daemon.err -t ${PROG_NAME} "$@" } validate_section() { uci_validate_section dsvpn dsvpn "${1}" \ 'enable:bool:0' \ 'key:string' \ 'host:host' \ 'port:port' \ 'dev:string' \ 'localip:host' \ 'remoteip:host' } start_instance() { local enable key host port dev validate_section "${1}" || { _err "validation failed" return 1 } [ "${enable}" = "1" ] || return 1 [ -n "${key}" ] || return 1 [ "${key}" != "secretkey" ] || return 1 [ -n "${port}" ] || return 1 [ -n "${dev}" ] || return 1 echo "${key}" > /tmp/${PROG_NAME}-${1}.key key="" if [ "$(uci -q get network.omrvpn)" != "" ] && [ "$(uci -q get network.omrvpn)" != "$dev" ]; then uci -q set network.omrvpn.ifname=$dev uci -q commit fi ip addr flush $dev sleep 2 _log "starting ${PROG_NAME} ${1} instance $*" procd_open_instance procd_set_param command ${PROG} client \ /tmp/${PROG_NAME}-${1}.key \ $host \ $port \ $dev \ ${localip:+$localip} \ ${remoteip:+$remoteip} \ $(ip r get $host | awk '{print $3}' | tr -d "\n") procd_set_param respawn 0 30 5 procd_set_param file /tmp/${PROG_NAME}-${1}.key procd_set_param stdout 1 procd_set_param stderr 1 procd_close_instance } start_service() { config_load dsvpn config_foreach start_instance dsvpn } service_triggers() { procd_add_reload_trigger dsvpn network }