hsaddress.sh 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. #!/usr/bin/env bash
  2. #
  3. # Usage:
  4. # tools/hsaddress.sh [hs_node]
  5. # Output: for each HS outputs its onion address. If the argument node is
  6. # specified, it only shows the onion address of that node.
  7. # Examples: tools/hsaddress.sh
  8. # tools/hsaddress.sh 025h
  9. if [ ! -d "$CHUTNEY_PATH" -o ! -x "$CHUTNEY_PATH/chutney" ]; then
  10. # looks like a broken path: use the path to this tool instead
  11. TOOLS_PATH=`dirname "$0"`
  12. export CHUTNEY_PATH=`dirname "$TOOLS_PATH"`
  13. fi
  14. if [ -d "$PWD/$CHUTNEY_PATH" -a -x "$PWD/$CHUTNEY_PATH/chutney" ]; then
  15. # looks like a relative path: make chutney path absolute
  16. export CHUTNEY_PATH="$PWD/$CHUTNEY_PATH"
  17. fi
  18. NAME=$(basename "$0")
  19. DEST="$CHUTNEY_PATH/net/nodes"
  20. TARGET=hidden_service/hostname
  21. function usage() {
  22. echo "Usage: $NAME [hs_node]"
  23. exit 1
  24. }
  25. function show_address() {
  26. cat "$1"
  27. }
  28. [ -d "$DEST" ] || { echo "$NAME: no nodes available"; exit 1; }
  29. if [ $# -eq 0 ];
  30. then
  31. # support hOLD
  32. for dir in "$DEST"/*h*;
  33. do
  34. FILE="${dir}/$TARGET"
  35. [ -e "$FILE" ] || continue
  36. echo -n "Node `basename ${dir}`: "
  37. show_address "$FILE"
  38. done
  39. elif [ $# -eq 1 ];
  40. then
  41. [ -d "$DEST/$1" ] || { echo "$NAME: $1 not found"; exit 1; }
  42. # support hOLD
  43. [[ "$1" =~ .*h.* ]] || { echo "$NAME: $1 is not a HS"; exit 1; }
  44. FILE="$DEST/$1/$TARGET"
  45. [ -e "$FILE" ] || { echo "$NAME: $FILE not found"; exit 1; }
  46. show_address "$FILE"
  47. else
  48. usage
  49. fi