You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

143 lines
4.7 KiB

  1. #!/bin/sh
  2. ##############################################################################
  3. #
  4. # This program is free software; you can redistribute it and/or modify
  5. # it under the terms of the GNU General Public License version 2 as
  6. # published by the Free Software Foundation.
  7. #
  8. # This program is distributed in the hope that it will be useful,
  9. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. # GNU General Public License for more details.
  12. #
  13. # Copyright (C) 2016 Eric Luehrsen
  14. #
  15. ##############################################################################
  16. #
  17. # This script facilitates alternate installation of Unbound+odhcpd and no
  18. # need for dnsmasq. There are some limitations, but it works and is small.
  19. # The lease file is parsed to make "zone-data:" and "local-data:" entries.
  20. #
  21. # config odhcpd 'odhcpd'
  22. # option leasetrigger '/usr/lib/unbound/odhcpd.sh'
  23. #
  24. ##############################################################################
  25. odhcpd_zonedata() {
  26. . /lib/functions.sh
  27. . /usr/lib/unbound/defaults.sh
  28. local dhcp_link=$( uci_get unbound.@unbound[0].dhcp_link )
  29. local dhcp4_slaac6=$( uci_get unbound.@unbound[0].dhcp4_slaac6 )
  30. local dhcp_domain=$( uci_get unbound.@unbound[0].domain )
  31. local dhcp_origin=$( uci_get dhcp.@odhcpd[0].leasefile )
  32. if [ -f "$UB_TOTAL_CONF" ] && [ -f "$dhcp_origin" ] \
  33. && [ "$dhcp_link" = "odhcpd" ] && [ -n "$dhcp_domain" ] ; then
  34. local longconf dateconf dateoldf
  35. local dns_ls_add=$UB_VARDIR/dhcp_dns.add
  36. local dns_ls_del=$UB_VARDIR/dhcp_dns.del
  37. local dns_ls_new=$UB_VARDIR/dhcp_dns.new
  38. local dns_ls_old=$UB_VARDIR/dhcp_dns.old
  39. local dhcp_ls_new=$UB_VARDIR/dhcp_lease.new
  40. if [ ! -f $UB_DHCP_CONF ] || [ ! -f $dns_ls_old ] ; then
  41. # no old files laying around
  42. touch $dns_ls_old
  43. sort $dhcp_origin > $dhcp_ls_new
  44. longconf=freshstart
  45. else
  46. # incremental at high load or full refresh about each 5 minutes
  47. dateconf=$(( $( date +%s ) - $( date -r $UB_DHCP_CONF +%s ) ))
  48. dateoldf=$(( $( date +%s ) - $( date -r $dns_ls_old +%s ) ))
  49. if [ $dateconf -gt 300 ] ; then
  50. touch $dns_ls_old
  51. sort $dhcp_origin > $dhcp_ls_new
  52. longconf=longtime
  53. elif [ $dateoldf -gt 1 ] ; then
  54. touch $dns_ls_old
  55. sort $dhcp_origin > $dhcp_ls_new
  56. longconf=increment
  57. else
  58. # odhcpd is rapidly updating leases a race condition could occur
  59. longconf=skip
  60. fi
  61. fi
  62. case $longconf in
  63. freshstart)
  64. awk -v conffile=$UB_DHCP_CONF -v pipefile=$dns_ls_new \
  65. -v domain=$dhcp_domain -v bslaac=$dhcp4_slaac6 \
  66. -v bisolt=0 -v bconf=1 \
  67. -f /usr/lib/unbound/odhcpd.awk $dhcp_ls_new
  68. cp $dns_ls_new $dns_ls_add
  69. cp $dns_ls_new $dns_ls_old
  70. cat $dns_ls_add | $UB_CONTROL_CFG local_datas
  71. rm -f $dns_ls_new $dns_ls_del $dns_ls_add $dhcp_ls_new
  72. ;;
  73. longtime)
  74. awk -v conffile=$UB_DHCP_CONF -v pipefile=$dns_ls_new \
  75. -v domain=$dhcp_domain -v bslaac=$dhcp4_slaac6 \
  76. -v bisolt=0 -v bconf=1 \
  77. -f /usr/lib/unbound/odhcpd.awk $dhcp_ls_new
  78. awk '{ print $1 }' $dns_ls_old | sort | uniq > $dns_ls_del
  79. cp $dns_ls_new $dns_ls_add
  80. cp $dns_ls_new $dns_ls_old
  81. cat $dns_ls_del | $UB_CONTROL_CFG local_datas_remove
  82. cat $dns_ls_add | $UB_CONTROL_CFG local_datas
  83. rm -f $dns_ls_new $dns_ls_del $dns_ls_add $dhcp_ls_new
  84. ;;
  85. increment)
  86. # incremental add and prepare the old list for delete later
  87. # unbound-control can be slow so high DHCP rates cannot run a full list
  88. awk -v conffile=$UB_DHCP_CONF -v pipefile=$dns_ls_new \
  89. -v domain=$dhcp_domain -v bslaac=$dhcp4_slaac6 \
  90. -v bisolt=0 -v bconf=0 \
  91. -f /usr/lib/unbound/odhcpd.awk $dhcp_ls_new
  92. sort $dns_ls_new $dns_ls_old $dns_ls_old | uniq -u > $dns_ls_add
  93. sort $dns_ls_new $dns_ls_old | uniq > $dns_ls_old
  94. cat $dns_ls_add | $UB_CONTROL_CFG local_datas
  95. rm -f $dns_ls_new $dns_ls_del $dns_ls_add $dhcp_ls_new
  96. ;;
  97. *)
  98. echo "do nothing" >/dev/null
  99. ;;
  100. esac
  101. fi
  102. }
  103. ##############################################################################
  104. UB_ODHPCD_LOCK=/tmp/unbound_odhcpd.lock
  105. if [ ! -f $UB_ODHPCD_LOCK ] ; then
  106. # imperfect but it should avoid collisions
  107. touch $UB_ODHPCD_LOCK
  108. odhcpd_zonedata
  109. rm -f $UB_ODHPCD_LOCK
  110. else
  111. UB_ODHCPD_LOCK_AGE=$(( $( date +%s ) - $( date -r $UB_ODHPCD_LOCK +%s ) ))
  112. if [ $UB_ODHCPD_LOCK_AGE -gt 100 ] ; then
  113. # unlock because something likely broke but do not write this time through
  114. rm -f $UB_ODHPCD_LOCK
  115. fi
  116. fi
  117. ##############################################################################