authkey.go 2.3 KB

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