client.go 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. package gdrivefs
  2. import (
  3. "context"
  4. "encoding/json"
  5. "fmt"
  6. "io/ioutil"
  7. "net/http"
  8. "net/url"
  9. "os"
  10. "path/filepath"
  11. "dev.hexasoftware.com/hxs/cloudmount/core"
  12. drive "google.golang.org/api/drive/v3"
  13. "golang.org/x/oauth2"
  14. "golang.org/x/oauth2/google"
  15. )
  16. func getClient(ctx context.Context, config *oauth2.Config) *http.Client {
  17. cacheFile, err := tokenCacheFile()
  18. if err != nil {
  19. log.Fatalf("Unable to get path to cached credential file. %v", err)
  20. }
  21. tok, err := tokenFromFile(cacheFile)
  22. if err != nil {
  23. tok = getTokenFromWeb(config)
  24. saveToken(cacheFile, tok)
  25. }
  26. return config.Client(ctx, tok)
  27. }
  28. func tokenCacheFile() (string, error) {
  29. tokenCacheDir := core.Config.WorkDir
  30. err := os.MkdirAll(tokenCacheDir, 0700)
  31. return filepath.Join(tokenCacheDir, url.QueryEscape("auth.json")), err
  32. }
  33. func getTokenFromWeb(config *oauth2.Config) *oauth2.Token {
  34. authURL := config.AuthCodeURL("state-token", oauth2.AccessTypeOffline)
  35. fmt.Printf(
  36. `Go to the following link in your browser:
  37. ----------------------------------------------------------------------------------------------
  38. %v
  39. ----------------------------------------------------------------------------------------------
  40. type the authorization code: `, authURL)
  41. var code string
  42. if _, err := fmt.Scan(&code); err != nil {
  43. log.Fatalf("Unable to read authorization code %v", err)
  44. }
  45. tok, err := config.Exchange(oauth2.NoContext, code)
  46. if err != nil {
  47. log.Fatalf("Unable to retrieve token from web: %v", err)
  48. }
  49. return tok
  50. }
  51. func tokenFromFile(file string) (*oauth2.Token, error) {
  52. f, err := os.Open(file)
  53. if err != nil {
  54. return nil, err
  55. }
  56. defer f.Close()
  57. t := &oauth2.Token{}
  58. err = json.NewDecoder(f).Decode(t)
  59. return t, err
  60. }
  61. func saveToken(file string, token *oauth2.Token) {
  62. log.Printf("Saving credential file to: %s\n", file)
  63. f, err := os.OpenFile(file, os.O_RDWR|os.O_CREATE|os.O_TRUNC, 0600)
  64. if err != nil {
  65. log.Fatalf("Unable to cache oauth token: %v\n", err)
  66. }
  67. defer f.Close()
  68. json.NewEncoder(f).Encode(token)
  69. }
  70. /*func getConfigPath() (string, error) {
  71. usr, err := user.Current()
  72. if err != nil {
  73. return "", err
  74. }
  75. configDir := filepath.Join(usr.HomeDir, ".gdrivemount")
  76. return configDir, nil
  77. }*/
  78. func GetDriveService() *drive.Service {
  79. configPath := core.Config.WorkDir
  80. ctx := context.Background()
  81. b, err := ioutil.ReadFile(filepath.Join(configPath, "client_secret.json"))
  82. if err != nil {
  83. log.Fatalf("Unable to read client secret file: %v", err)
  84. }
  85. config, err := google.ConfigFromJSON(b, drive.DriveScope)
  86. if err != nil {
  87. log.Fatalf("Unable to parse client secret file: %v", err)
  88. }
  89. client := getClient(ctx, config)
  90. srv, err := drive.New(client)
  91. if err != nil {
  92. log.Fatalf("Unable to retrieve drive Client: %v", err)
  93. }
  94. return srv
  95. }