udp2raw.init 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132
  1. #!/bin/sh /etc/rc.common
  2. START=88
  3. STOP=15
  4. NAME=udp2raw
  5. _log() {
  6. logger -p "daemon.$1" -t "$NAME" "$2"
  7. }
  8. has_valid_server() {
  9. local server
  10. for server in $@; do
  11. [ "$(uci_get $NAME $server)" = "servers" ] && return 0
  12. done
  13. return 1
  14. }
  15. create_config() {
  16. local config_file="$1"
  17. echo "# auto-generated config file from /etc/config/udp2raw" > $config_file
  18. echo "-c" >> $config_file
  19. echo "-l ${listen_addr:=127.0.0.1}:${listen_port:=2080}" >> $config_file
  20. echo "-r ${server_addr}:${server_port:=8080}" >> $config_file
  21. [ -n "$raw_mode" ] && echo "--raw-mode ${raw_mode}" >> $config_file
  22. [ -n "$key" ] && echo "--key ${key}" >> $config_file
  23. [ -n "$cipher_mode" ] && echo "--cipher-mode ${cipher_mode}" >> $config_file
  24. [ -n "$auth_mode" ] && echo "--auth-mode ${auth_mode}" >> $config_file
  25. [ $auto_rule -eq 1 ] && echo "--auto-rule" >> $config_file
  26. [ $auto_rule -eq 1 -a $keep_rule -eq 1 ] && echo "--keep-rule" >> $config_file
  27. [ -n "$seq_mode" ] && echo "--seq-mode ${seq_mode}" >> $config_file
  28. [ -n "$lower_level" ] && echo "--lower-level ${lower_level}" >> $config_file
  29. [ -n "$source_ip" ] && echo "--source-ip ${source_ip}" >> $config_file
  30. [ -n "$source_port" ] && echo "--source-port ${source_port}" >> $config_file
  31. [ -n "$log_level" ] && echo "--log-level ${log_level}" >> $config_file
  32. echo "--disable-color" >> $config_file
  33. echo "--wait-lock" >> $config_file
  34. }
  35. validate_config_section() {
  36. local ret=$(/sbin/validate_data "$NAME" general "$1" \
  37. 'server:uciname' \
  38. 'daemon_user:string:root' \
  39. 2> /dev/null)
  40. [ $? -ne 0 ] && return 1
  41. eval "$ret"
  42. }
  43. validate_server_section() {
  44. local ret=$(/sbin/validate_data "$NAME" servers "$1" \
  45. 'server_addr:host' \
  46. 'server_port:port:8080' \
  47. 'listen_addr:ipaddr:127.0.0.1' \
  48. 'listen_port:port:2080' \
  49. 'raw_mode:or("faketcp", "udp", "icmp"):faketcp' \
  50. 'key:string' \
  51. 'cipher_mode:or("aes128cbc", "xor", "none"):aes128cbc' \
  52. 'auth_mode:or("md5", "crc32", "simple", "none"):md5' \
  53. 'auto_rule:bool:1' \
  54. 'keep_rule:bool:0' \
  55. 'seq_mode:range(0,4)' \
  56. 'lower_level:string' \
  57. 'source_ip:ipaddr' \
  58. 'source_port:port' \
  59. 'log_level:range(0,6)' \
  60. 2> /dev/null)
  61. [ $? -ne 0 ] && return 1
  62. eval "$ret"
  63. }
  64. start_instance() {
  65. local server="$1"
  66. if [ -z "$server" -o "$server" == "nil" ]; then
  67. return 0
  68. elif ! validate_server_section "$server"; then
  69. _log "err" "Server config validation failed."
  70. return 1
  71. fi
  72. /sbin/validate_data "ipaddr" "$server_addr" >/dev/null 2>&1
  73. [ $? -ne 0 ] && server_addr=$(nslookup "$server_addr" | \
  74. sed -n 's/^Address[[:space:]]*[0-9]*:[[:space:]]*\(\([0-9]\{1,3\}\.\)\{3\}[0-9]\{1,3\}\)$/\1/p')
  75. if [ -z "$server_addr" ]; then
  76. _log "err" "Server address validation failed."
  77. return 1
  78. fi
  79. [ -d /var/etc ] || mkdir -p /var/etc
  80. local config_file="/var/etc/${NAME}.${server}.conf"
  81. create_config "$config_file" || return 1
  82. [ -d "/var/log/${NAME}" ] || mkdir -p "/var/log/${NAME}"
  83. /usr/bin/udp2raw --conf-file "$config_file" >> "/var/log/${NAME}/${NAME}.${server}.log" &
  84. echo $! > "/var/run/${NAME}.${server}.pid"
  85. return 0
  86. }
  87. start() {
  88. pgrep "/usr/bin/${NAME}" >/dev/null 2>&1 && return
  89. if ! validate_config_section "general" ; then
  90. _log "err" "Config validate failed."
  91. return 1
  92. fi
  93. has_valid_server $server || return 1
  94. for srv in $server; do
  95. start_instance $srv
  96. done
  97. }
  98. stop() {
  99. local pids=$(pgrep "/usr/bin/${NAME}" 2> /dev/null)
  100. [ $? -ne 0 ] && return
  101. for pid in $pids; do
  102. kill $pid >/dev/null 2>&1
  103. done
  104. return 0
  105. }
  106. restart() {
  107. stop
  108. sleep 1
  109. start
  110. }