authkey.go 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. package ganserv
  2. import (
  3. "bufio"
  4. "fmt"
  5. "log"
  6. "os"
  7. "os/exec"
  8. "os/user"
  9. "runtime"
  10. "strings"
  11. )
  12. func TryLoadorAskUserForAuthkey() string {
  13. //Check for zt auth token
  14. value, exists := os.LookupEnv("ZT_AUTH")
  15. if !exists {
  16. log.Println("Environment variable ZT_AUTH not defined. Trying to load authtoken from file.")
  17. } else {
  18. return value
  19. }
  20. authKey := ""
  21. if runtime.GOOS == "windows" {
  22. b, err := os.ReadFile("C:\\ProgramData\\ZeroTier\\One\\authtoken.secret")
  23. if err == nil {
  24. log.Println("Zerotier authkey loaded")
  25. authKey = string(b)
  26. } else {
  27. log.Println("Unable to read authkey at C:\\ProgramData\\ZeroTier\\One\\authtoken.secret: ", err.Error())
  28. }
  29. } else if runtime.GOOS == "linux" {
  30. if isRoot() {
  31. //Try to read from source using sudo
  32. ak, err := readAuthTokenAsRoot()
  33. if err == nil {
  34. log.Println("Zerotier authkey loaded")
  35. authKey = strings.TrimSpace(ak)
  36. } else {
  37. log.Println("Unable to read authkey at /var/lib/zerotier-one/authtoken.secret: ", err.Error())
  38. }
  39. } else {
  40. //Try read from source
  41. b, err := os.ReadFile("/var/lib/zerotier-one/authtoken.secret")
  42. if err == nil {
  43. log.Println("Zerotier authkey loaded")
  44. authKey = string(b)
  45. } else {
  46. log.Println("Unable to read authkey at /var/lib/zerotier-one/authtoken.secret: ", err.Error())
  47. }
  48. }
  49. } else if runtime.GOOS == "darwin" {
  50. b, err := os.ReadFile("/Library/Application Support/ZeroTier/One/authtoken.secret")
  51. if err == nil {
  52. log.Println("Zerotier authkey loaded")
  53. authKey = string(b)
  54. } else {
  55. log.Println("Unable to read authkey at /Library/Application Support/ZeroTier/One/authtoken.secret ", err.Error())
  56. }
  57. }
  58. authKey = strings.TrimSpace(authKey)
  59. if authKey == "" {
  60. //Ask user for input
  61. reader := bufio.NewReader(os.Stdin)
  62. fmt.Println("Please enter the Zerotier authtoken manually: ")
  63. input, _ := reader.ReadString('\n')
  64. return strings.TrimSpace(input)
  65. }
  66. return ""
  67. }
  68. //Use sudo to read auth token on linux like systems
  69. func readAuthTokenAsRoot() (string, error) {
  70. cmd := exec.Command("sudo", "cat", "/var/lib/zerotier-one/authtoken.secret")
  71. output, err := cmd.Output()
  72. if err != nil {
  73. return "", err
  74. }
  75. fmt.Println("CMDOUTPUT", string(output))
  76. return string(output), nil
  77. }
  78. //Check if the user is root on linux
  79. func isRoot() bool {
  80. currentUser, err := user.Current()
  81. if err != nil {
  82. return false
  83. }
  84. return currentUser.Username == "root"
  85. }