dropbear.failsafe 992 B

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. #!/bin/sh
  2. _dropbear()
  3. {
  4. /usr/sbin/dropbear "$@" </dev/null >/dev/null 2>&1
  5. }
  6. _dropbearkey()
  7. {
  8. /usr/bin/dropbearkey "$@" </dev/null >/dev/null 2>&1
  9. }
  10. _ensurekey()
  11. {
  12. _dropbearkey -y -f "$1" && return
  13. rm -f "$1"
  14. _dropbearkey -f "$@" || {
  15. rm -f "$1"
  16. return 1
  17. }
  18. }
  19. ktype_all='ed25519 ecdsa rsa'
  20. failsafe_dropbear () {
  21. local kargs kcount ktype tkey
  22. kargs=
  23. kcount=0
  24. for ktype in ${ktype_all} ; do
  25. tkey="/tmp/dropbear_failsafe_${ktype}_host_key"
  26. case "${ktype}" in
  27. ed25519) _ensurekey "${tkey}" -t ed25519 ;;
  28. ecdsa) _ensurekey "${tkey}" -t ecdsa -s 256 ;;
  29. rsa) _ensurekey "${tkey}" -t rsa -s 1024 ;;
  30. *)
  31. echo "unknown key type: ${ktype}" >&2
  32. continue
  33. ;;
  34. esac
  35. [ -s "${tkey}" ] || {
  36. rm -f "${tkey}"
  37. continue
  38. }
  39. chmod 0400 "${tkey}"
  40. kargs="${kargs}${kargs:+ }-r ${tkey}"
  41. kcount=$((kcount+1))
  42. done
  43. [ "${kcount}" != 0 ] || {
  44. echo 'DROPBEAR IS BROKEN' >&2
  45. return 1
  46. }
  47. _dropbear ${kargs}
  48. }
  49. boot_hook_add failsafe failsafe_dropbear