#!/bin/sh /etc/rc.common # vim: set noexpandtab tabstop=4 shiftwidth=4 softtabstop=4 : # Copyright (C) 2015 ovh.com # Copyright (C) 2017 Ycarus (Yannick Chabanois) START=90 STOP=10 USE_PROCD=1 PROG_NAME=glorytun-udp 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 glorytun glorytun "${1}" \ 'enable:bool:0' \ 'key:string' \ 'host:host' \ 'port:port' \ 'proto:string' \ 'bind:string:0.0.0.0' \ 'bindport:port' \ 'mtu:uinteger:1450' \ 'mtuauto:bool:0' \ 'chacha20:bool:0' \ 'dev:string' } start_instance() { local enable key host port listener proto bind bindport mtu mtuauto chacha20 dev validate_section "${1}" || { _err "validation failed" return 1 } [ "${enable}" = "1" ] || return 1 [ "${proto}" = "udp" ] || 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)" != "" ]; then uci -q set network.omrvpn.ifname=$dev uci -q commit fi _log "starting ${PROG_NAME} ${1} instance $*" procd_open_instance procd_set_param command ${PROG} \ ${bind:+bind "$bind"} \ ${bindport:+ "$bindport"} \ ${host:+to "$host"} \ ${port:+ "$port"} \ ${dev:+dev "$dev"} \ keyfile /tmp/${PROG_NAME}-${1}.key \ persist [ "${chacha20}" = "1" ] && procd_append_param command chacha procd_set_param respawn 0 30 0 procd_set_param file /tmp/${PROG_NAME}-${1}.key procd_set_param stdout 1 procd_set_param stderr 1 procd_close_instance #config_load network #config_foreach add_glorytun_path interface } add_glorytun_path() { case "$1" in loopback|lan|if0|*tun*|ifb*) return ;; esac local multipath network_get_ipaddr ipaddr "$1" config_get multipath "$1" multipath "off" case "$multipath" in master|on) glorytun-udp path "$ipaddr" dev $dev up ;; backup) glorytun-udp path "$ipaddr" dev $dev backup ;; *) glorytun-udp path "$ipaddr" dev $dev down ;; esac } start_service() { local dev config_load glorytun config_foreach start_instance glorytun } reload_service() { stop start } service_triggers() { procd_add_reload_trigger glorytun-udp network }