omcproxy.init 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166
  1. #!/bin/sh /etc/rc.common
  2. # Copyright (C) 2018 OpenWrt.org
  3. START=99
  4. USE_PROCD=1
  5. PROG=/usr/sbin/omcproxy
  6. # Uncomment to enable verbosity
  7. #OPTIONS="-v"
  8. PROXIES=""
  9. omcproxy_add_proxy() {
  10. local proxy scope uplink updevice downlinks
  11. config_get uplink $1 uplink
  12. [ -n "$uplink" ] || return
  13. network_get_device updevice "$uplink" || {
  14. procd_append_param error "$uplink is not up"
  15. return;
  16. }
  17. config_get downlinks $1 downlink
  18. for downlink in $downlinks; do
  19. local device
  20. network_get_device device "$downlink" || {
  21. procd_append_param error "$downlink is not up"
  22. continue;
  23. }
  24. proxy="$proxy,$device"
  25. # Disable in-kernel querier while ours is active, default is 1.
  26. [ -f /sys/class/net/$device/bridge/multicast_querier ] && \
  27. echo 0 > /sys/class/net/$device/bridge/multicast_querier
  28. done
  29. [ -n "$proxy" ] || return 0
  30. config_get scope $1 scope
  31. [ -n "$scope" ] && proxy="$proxy,scope=$scope"
  32. PROXIES="$PROXIES $updevice$proxy"
  33. }
  34. omcproxy_add_network_triggers() {
  35. local uplink downlinks
  36. config_get uplink $1 uplink
  37. config_get downlinks $1 downlink
  38. for link in $uplink $downlinks; do
  39. local duplicate=0
  40. for l in $LINKS; do
  41. [ "$l" = "$link" ] && duplicate=1
  42. done
  43. [ "$duplicate" = 0 ] && {
  44. LINKS="$LINKS $link"
  45. procd_add_interface_trigger "interface.*" $link /etc/init.d/omcproxy restart
  46. }
  47. done
  48. }
  49. omcproxy_add_firewall_rules() {
  50. local uplink downlinks
  51. config_get uplink $1 uplink
  52. config_get downlinks $1 downlink
  53. upzone=$(fw3 -q network $uplink 2>/dev/null)
  54. [ -n "$upzone" ] || return 0
  55. json_add_object ""
  56. json_add_string type rule
  57. json_add_string src "$upzone"
  58. json_add_string family ipv4
  59. json_add_string proto igmp
  60. json_add_string target ACCEPT
  61. json_close_object
  62. json_add_object ""
  63. json_add_string type rule
  64. json_add_string family ipv6
  65. json_add_string src "$upzone"
  66. json_add_string proto icmp
  67. json_add_string src_ip fe80::/10
  68. json_add_array icmp_type
  69. json_add_string "" 130/0
  70. json_add_string "" 131/0
  71. json_add_string "" 132/0
  72. json_add_string "" 143/0
  73. json_close_array
  74. json_add_string target ACCEPT
  75. json_close_object
  76. for downlink in $downlinks; do
  77. downzone=$(fw3 -q network $downlink 2>/dev/null)
  78. [ -n "$downzone" ] || continue
  79. json_add_object ""
  80. json_add_string type rule
  81. json_add_string src "$upzone"
  82. json_add_string dest "$downzone"
  83. json_add_string family ipv4
  84. json_add_string proto udp
  85. json_add_string dest_ip "224.0.0.0/4"
  86. json_add_string target ACCEPT
  87. json_close_object
  88. json_add_object ""
  89. json_add_string type rule
  90. json_add_string src "$upzone"
  91. json_add_string dest "$downzone"
  92. json_add_string family ipv6
  93. json_add_string proto udp
  94. json_add_string dest_ip "ff00::/8"
  95. json_add_string target ACCEPT
  96. json_close_object
  97. done
  98. }
  99. service_triggers() {
  100. LINKS=""
  101. procd_add_reload_trigger "omcproxy"
  102. config_foreach omcproxy_add_network_triggers proxy
  103. }
  104. start_service() {
  105. . /lib/functions/network.sh
  106. config_load omcproxy
  107. config_foreach omcproxy_add_proxy proxy
  108. [ -n "$PROXIES" ] || return 0
  109. procd_open_instance
  110. procd_set_param command $PROG
  111. [ -n "$OPTIONS" ] && procd_append_param command $OPTIONS
  112. procd_append_param command $PROXIES
  113. procd_set_param respawn
  114. procd_open_data
  115. json_add_array firewall
  116. config_foreach omcproxy_add_firewall_rules proxy
  117. json_close_array
  118. procd_close_data
  119. procd_close_instance
  120. # Increase maximum IPv4 group memberships per socket, default is 100.
  121. echo 128 > /proc/sys/net/ipv4/igmp_max_memberships
  122. }
  123. service_running() {
  124. procd_set_config_changed firewall
  125. }
  126. stop_service() {
  127. procd_set_config_changed firewall
  128. }