client.go 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  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. drive "google.golang.org/api/drive/v3"
  12. "golang.org/x/oauth2"
  13. "golang.org/x/oauth2/google"
  14. )
  15. func (d *GDriveFS) getClient(ctx context.Context, config *oauth2.Config) *http.Client {
  16. cacheFile, err := d.tokenCacheFile()
  17. if err != nil {
  18. log.Fatalf("Unable to get path to cached credential file. %v", err)
  19. }
  20. tok, err := d.tokenFromFile(cacheFile)
  21. if err != nil {
  22. tok = d.getTokenFromWeb(config)
  23. d.saveToken(cacheFile, tok)
  24. }
  25. return config.Client(ctx, tok)
  26. }
  27. func (d *GDriveFS) tokenCacheFile() (string, error) {
  28. tokenCacheDir := d.core.Config.HomeDir
  29. err := os.MkdirAll(tokenCacheDir, 0700)
  30. return filepath.Join(tokenCacheDir, url.QueryEscape("auth.json")), err
  31. }
  32. func (d *GDriveFS) getTokenFromWeb(config *oauth2.Config) *oauth2.Token {
  33. authURL := config.AuthCodeURL("state-token", oauth2.AccessTypeOffline)
  34. fmt.Printf(
  35. `Go to the following link in your browser:
  36. ----------------------------------------------------------------------------------------------
  37. %v
  38. ----------------------------------------------------------------------------------------------
  39. type the authorization code: `, authURL)
  40. var code string
  41. if _, err := fmt.Scan(&code); err != nil {
  42. log.Fatalf("Unable to read authorization code %v", err)
  43. }
  44. tok, err := config.Exchange(oauth2.NoContext, code)
  45. if err != nil {
  46. log.Fatalf("Unable to retrieve token from web: %v", err)
  47. }
  48. return tok
  49. }
  50. func (d *GDriveFS) tokenFromFile(file string) (*oauth2.Token, error) {
  51. f, err := os.Open(file)
  52. if err != nil {
  53. return nil, err
  54. }
  55. defer f.Close()
  56. t := &oauth2.Token{}
  57. err = json.NewDecoder(f).Decode(t)
  58. return t, err
  59. }
  60. func (d *GDriveFS) saveToken(file string, token *oauth2.Token) {
  61. log.Printf("Saving credential file to: %s\n", file)
  62. f, err := os.OpenFile(file, os.O_RDWR|os.O_CREATE|os.O_TRUNC, 0600)
  63. if err != nil {
  64. log.Fatalf("Unable to cache oauth token: %v\n", err)
  65. }
  66. defer f.Close()
  67. json.NewEncoder(f).Encode(token)
  68. }
  69. /*func getConfigPath() (string, error) {
  70. usr, err := user.Current()
  71. if err != nil {
  72. return "", err
  73. }
  74. configDir := filepath.Join(usr.HomeDir, ".gdrivemount")
  75. return configDir, nil
  76. }*/
  77. // Init driveService
  78. func (d *GDriveFS) initClient() {
  79. configPath := d.core.Config.HomeDir
  80. ctx := context.Background() // Context from GDriveFS
  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 := d.getClient(ctx, config)
  90. d.client, err = drive.New(client)
  91. if err != nil {
  92. log.Fatalf("Unable to retrieve drive Client: %v", err)
  93. }
  94. }