oauth2/google/appengine.go

54 lines
1.4 KiB
Go
Raw Normal View History

2014-06-17 09:53:08 -04:00
// +build appengine
package google
import (
"github.com/golang/oauth2"
2014-07-09 01:27:34 -04:00
"appengine"
"appengine/urlfetch"
2014-06-17 09:53:08 -04:00
)
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 {
// Transport represents the default transport to be used while constructing
// oauth2.Transport instances from this configuration.
Transport *urlfetch.Transport
context appengine.Context
scopes []string
2014-06-17 09:53:08 -04:00
}
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{
Transport: &urlfetch.Transport{
Context: context,
Deadline: 0,
AllowInvalidServerCertificate: false,
},
context: context,
scopes: scopes,
}
2014-06-17 09:53:08 -04:00
}
2014-06-22 17:39:35 -04:00
// NewTransport returns a transport that authorizes
// the requests with the application's service account.
func (c *AppEngineConfig) NewTransport() *oauth2.Transport {
return oauth2.NewTransport(c.Transport, c, nil)
2014-06-17 09:53:08 -04:00
}
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) {
2014-08-05 15:25:29 -04:00
token, expiry, err := appengine.AccessToken(c.context, c.scopes...)
2014-06-17 09:53:08 -04:00
if err != nil {
return nil, err
}
return &oauth2.Token{
AccessToken: token,
Expiry: expiry,
}, nil
}