#!/bin/sh /etc/rc.common
|
|
|
|
START=99
|
|
STOP=50
|
|
USE_PROCD=1
|
|
|
|
NAME=ttyd
|
|
PROG=/usr/bin/$NAME
|
|
|
|
validate_section_ttyd()
|
|
{
|
|
uci_load_validate ttyd ttyd "$1" "$2" \
|
|
'enable:bool:1' \
|
|
'port:port' \
|
|
'interface:string' \
|
|
'credential:string' \
|
|
'uid:uinteger' \
|
|
'gid:uinteger' \
|
|
'signal:uinteger' \
|
|
'url_arg:bool' \
|
|
'readonly:bool' \
|
|
'client_option:list(string)' \
|
|
'terminal_type:string' \
|
|
'check_origin:bool' \
|
|
'max_clients:uinteger' \
|
|
'once:bool' \
|
|
'index:string' \
|
|
'ipv6:bool' \
|
|
'ssl:bool' \
|
|
'ssl_cert:file' \
|
|
'ssl_key:file' \
|
|
'ssl_ca:file' \
|
|
'debug:uinteger' \
|
|
'command:string'
|
|
}
|
|
|
|
ttyd_instance()
|
|
{
|
|
[ "$2" = 0 ] || {
|
|
echo "validation failed"
|
|
return 1
|
|
}
|
|
|
|
[ "$enable" = 0 ] && return 1
|
|
[ -z "$command" ] && return 1
|
|
|
|
[ "${interface::1}" = @ ] && {
|
|
interface=$(
|
|
. /lib/functions/network.sh
|
|
network_get_device device "${interface:1}"
|
|
echo -n "$device"
|
|
)
|
|
}
|
|
|
|
[ "$url_arg" = 0 ] && url_arg=""
|
|
[ "$readonly" = 0 ] && readonly=""
|
|
[ "$check_origin" = 0 ] && check_origin=""
|
|
[ "$once" = 0 ] && once=""
|
|
[ "$ipv6" = 0 ] && ipv6=""
|
|
[ "$ssl" = 0 ] && ssl=""
|
|
|
|
procd_open_instance
|
|
procd_set_param command "$PROG" \
|
|
${port:+-p $port} \
|
|
${interface:+-i $interface} \
|
|
${credential:+-c $credential} \
|
|
${uid:+-u $uid} \
|
|
${gid:+-g $gid} \
|
|
${signal:+-s $signal} \
|
|
${url_arg:+-a} \
|
|
${readonly:+-R} \
|
|
${terminal_type:+-T $terminal_type} \
|
|
${check_origin:+-O} \
|
|
${max_clients:+-m $max_clients} \
|
|
${once:+-o} \
|
|
${index:+-I $index} \
|
|
${ipv6:+-6} \
|
|
${ssl:+-S} \
|
|
${ssl_cert:+-C $ssl_cert} \
|
|
${ssl_key:+-K $ssl_key} \
|
|
${ssl_ca:+-A $ssl_ca} \
|
|
${debug:+-d}
|
|
config_list_foreach "$1" client_option "procd_append_param command -t"
|
|
procd_append_param command $command
|
|
procd_set_param stdout 1
|
|
procd_set_param stderr 1
|
|
procd_close_instance
|
|
}
|
|
|
|
start_service() {
|
|
config_load "$NAME"
|
|
config_foreach validate_section_ttyd ttyd ttyd_instance
|
|
}
|
|
|
|
shutdown() {
|
|
# close all open connections
|
|
killall "$NAME"
|
|
}
|