client.go 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. // Oauth2 google api for Drive api
  2. package gdrivefs
  3. import (
  4. "context"
  5. "encoding/json"
  6. "fmt"
  7. "io/ioutil"
  8. "net/http"
  9. "net/url"
  10. "os"
  11. "path/filepath"
  12. drive "google.golang.org/api/drive/v3"
  13. "golang.org/x/oauth2"
  14. "golang.org/x/oauth2/google"
  15. )
  16. func (d *GDriveFS) getClient(ctx context.Context, config *oauth2.Config) *http.Client {
  17. cacheFile, err := d.tokenCacheFile()
  18. if err != nil {
  19. log.Fatalf("Unable to get path to cached credential file. %v", err)
  20. }
  21. tok, err := d.tokenFromFile(cacheFile)
  22. if err != nil {
  23. tok = d.getTokenFromWeb(config)
  24. d.saveToken(cacheFile, tok)
  25. }
  26. return config.Client(ctx, tok)
  27. }
  28. func (d *GDriveFS) tokenCacheFile() (string, error) {
  29. tokenCacheDir := d.config.HomeDir
  30. err := os.MkdirAll(tokenCacheDir, 0700)
  31. return filepath.Join(tokenCacheDir, url.QueryEscape("auth.json")), err
  32. }
  33. func (d *GDriveFS) 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 (d *GDriveFS) 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 (d *GDriveFS) 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. // Init driveService
  79. func (d *GDriveFS) initClient() {
  80. configPath := d.config.HomeDir
  81. ctx := context.Background() // Context from GDriveFS
  82. b, err := ioutil.ReadFile(filepath.Join(configPath, "client_secret.json"))
  83. if err != nil {
  84. log.Fatalf("Unable to read client secret file: %v", err)
  85. }
  86. config, err := google.ConfigFromJSON(b, drive.DriveScope)
  87. if err != nil {
  88. log.Fatalf("Unable to parse client secret file: %v", err)
  89. }
  90. client := d.getClient(ctx, config)
  91. d.client, err = drive.New(client)
  92. if err != nil {
  93. log.Fatalf("Unable to retrieve drive Client: %v", err)
  94. }
  95. }