mirror of
				https://github.com/Ysurac/openmptcprouter-feeds.git
				synced 2025-03-09 15:40:03 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			86 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable file
		
	
	
	
	
			
		
		
	
	
			86 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable file
		
	
	
	
	
| #!/bin/sh /etc/rc.common
 | |
| # Copyright (C) 2019 Ycarus (Yannick Chabanois) <ycarus@zugaina.org> 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
 | |
| 
 | |
| 	_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}
 | |
| 
 | |
| 
 | |
| 	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
 | |
| 
 | |
| 
 | |
| }
 | |
| 
 | |
| start_service() {
 | |
| 	config_load dsvpn
 | |
| 	config_foreach start_instance dsvpn
 | |
| }
 | |
| 
 | |
| service_triggers() {
 | |
| 	procd_add_reload_trigger dsvpn network
 | |
| }
 |