oauth2/google/appenginevm.go

58 lines
1.5 KiB
Go
Raw Normal View History

// +build !appengine
2014-06-17 09:53:08 -04:00
package google
import (
"strings"
"github.com/golang/oauth2"
"google.golang.org/appengine"
)
2014-06-22 17:39:35 -04:00
// AppEngineConfig represents a configuration for an
// App Engine application's Google service account.
2014-06-17 09:53:08 -04:00
type AppEngineConfig struct {
context appengine.Context
scopes []string
cache oauth2.Cache
}
2014-06-22 17:39:35 -04:00
// NewAppEngineConfig creates a new AppEngineConfig for the
// provided auth scopes.
2014-06-17 09:53:08 -04:00
func NewAppEngineConfig(context appengine.Context, scopes []string) *AppEngineConfig {
return &AppEngineConfig{context: context, scopes: scopes}
}
2014-06-22 17:39:35 -04:00
// NewTransport returns a transport that authorizes
// the requests with the application's service account.
2014-06-17 09:53:08 -04:00
func (c *AppEngineConfig) NewTransport() oauth2.Transport {
return oauth2.NewAuthorizedTransport(c, nil)
}
2014-06-22 17:39:35 -04:00
// NewTransport returns a token-caching transport that authorizes
// the requests with the application's service account.
2014-06-17 09:53:08 -04:00
func (c *AppEngineConfig) NewTransportWithCache(cache oauth2.Cache) (oauth2.Transport, error) {
token, err := cache.Read()
if err != nil {
return nil, err
}
c.cache = cache
return oauth2.NewAuthorizedTransport(c, token), nil
}
2014-06-22 17:39:35 -04:00
// FetchToken fetches a new access token for the provided scopes.
2014-06-17 09:53:08 -04:00
func (c *AppEngineConfig) FetchToken(existing *oauth2.Token) (*oauth2.Token, error) {
token, expiry, err := appengine.AccessToken(c.context, strings.Join(c.scopes, " "))
if err != nil {
return nil, err
}
return &oauth2.Token{
AccessToken: token,
Expiry: expiry,
}, nil
}
func (c *AppEngineConfig) Cache() oauth2.Cache {
return c.cache
}