package oauth2

Import Path
	golang.org/x/oauth2 (on go.dev)

Dependency Relation
	imports 17 packages, and imported by one package

Involved Source Files deviceauth.go Package oauth2 provides support for making OAuth2 authorized and authenticated HTTP requests, as specified in RFC 6749. It can additionally grant authorization with Bearer JWT. pkce.go token.go transport.go
Code Examples package main import ( "context" "fmt" "log" "golang.org/x/oauth2" ) func main() { ctx := context.Background() conf := &oauth2.Config{ ClientID: "YOUR_CLIENT_ID", ClientSecret: "YOUR_CLIENT_SECRET", Scopes: []string{"SCOPE1", "SCOPE2"}, Endpoint: oauth2.Endpoint{ AuthURL: "https://provider.com/o/oauth2/auth", TokenURL: "https://provider.com/o/oauth2/token", }, } // use PKCE to protect against CSRF attacks // https://www.ietf.org/archive/id/draft-ietf-oauth-security-topics-22.html#name-countermeasures-6 verifier := oauth2.GenerateVerifier() // Redirect user to consent page to ask for permission // for the scopes specified above. url := conf.AuthCodeURL("state", oauth2.AccessTypeOffline, oauth2.S256ChallengeOption(verifier)) fmt.Printf("Visit the URL for the auth dialog: %v", url) // Use the authorization code that is pushed to the redirect // URL. Exchange will do the handshake to retrieve the // initial access token. The HTTP Client returned by // conf.Client will refresh the token as necessary. var code string if _, err := fmt.Scan(&code); err != nil { log.Fatal(err) } tok, err := conf.Exchange(ctx, code, oauth2.VerifierOption(verifier)) if err != nil { log.Fatal(err) } client := conf.Client(ctx, tok) client.Get("...") } package main import ( "context" "fmt" "log" "net/http" "time" "golang.org/x/oauth2" ) func main() { ctx := context.Background() conf := &oauth2.Config{ ClientID: "YOUR_CLIENT_ID", ClientSecret: "YOUR_CLIENT_SECRET", Scopes: []string{"SCOPE1", "SCOPE2"}, Endpoint: oauth2.Endpoint{ TokenURL: "https://provider.com/o/oauth2/token", AuthURL: "https://provider.com/o/oauth2/auth", }, } // Redirect user to consent page to ask for permission // for the scopes specified above. url := conf.AuthCodeURL("state", oauth2.AccessTypeOffline) fmt.Printf("Visit the URL for the auth dialog: %v", url) // Use the authorization code that is pushed to the redirect // URL. Exchange will do the handshake to retrieve the // initial access token. The HTTP Client returned by // conf.Client will refresh the token as necessary. var code string if _, err := fmt.Scan(&code); err != nil { log.Fatal(err) } // Use the custom HTTP client when requesting a token. httpClient := &http.Client{Timeout: 2 * time.Second} ctx = context.WithValue(ctx, oauth2.HTTPClient, httpClient) tok, err := conf.Exchange(ctx, code) if err != nil { log.Fatal(err) } client := conf.Client(ctx, tok) _ = client }
Package-Level Type Names (total 9)
/* sort by: | */
An AuthCodeOption is passed to Config.AuthCodeURL. func S256ChallengeOption(verifier string) AuthCodeOption func SetAuthURLParam(key, value string) AuthCodeOption func VerifierOption(verifier string) AuthCodeOption func (*Config).AuthCodeURL(state string, opts ...AuthCodeOption) string func (*Config).DeviceAccessToken(ctx context.Context, da *DeviceAuthResponse, opts ...AuthCodeOption) (*Token, error) func (*Config).DeviceAuth(ctx context.Context, opts ...AuthCodeOption) (*DeviceAuthResponse, error) func (*Config).Exchange(ctx context.Context, code string, opts ...AuthCodeOption) (*Token, error) var AccessTypeOffline var AccessTypeOnline var ApprovalForce
AuthStyle represents how requests for tokens are authenticated to the server. const AuthStyleAutoDetect const AuthStyleInHeader const AuthStyleInParams
Config describes a typical 3-legged OAuth2 flow, with both the client application information and the server's endpoint URLs. For the client credentials 2-legged OAuth2 flow, see the [golang.org/x/oauth2/clientcredentials] package. ClientID is the application's ID. ClientSecret is the application's secret. Endpoint contains the authorization server's token endpoint URLs. These are constants specific to each server and are often available via site-specific packages, such as google.Endpoint or github.Endpoint. RedirectURL is the URL to redirect users going through the OAuth flow, after the resource owner's URLs. Scopes specifies optional requested permissions. AuthCodeURL returns a URL to OAuth 2.0 provider's consent page that asks for permissions for the required scopes explicitly. State is an opaque value used by the client to maintain state between the request and callback. The authorization server includes this value when redirecting the user agent back to the client. Opts may include [AccessTypeOnline] or [AccessTypeOffline], as well as [ApprovalForce]. To protect against CSRF attacks, opts should include a PKCE challenge (S256ChallengeOption). Not all servers support PKCE. An alternative is to generate a random state parameter and verify it after exchange. See https://datatracker.ietf.org/doc/html/rfc6749#section-10.12 (predating PKCE), https://www.oauth.com/oauth2-servers/pkce/ and https://www.ietf.org/archive/id/draft-ietf-oauth-v2-1-09.html#name-cross-site-request-forgery (describing both approaches) Client returns an HTTP client using the provided token. The token will auto-refresh as necessary. The underlying HTTP transport will be obtained using the provided context. The returned client and its Transport should not be modified. DeviceAccessToken polls the server to exchange a device code for a token. DeviceAuth returns a device auth struct which contains a device code and authorization information provided for users to enter on another device. Exchange converts an authorization code into a token. It is used after a resource provider redirects the user back to the Redirect URI (the URL obtained from AuthCodeURL). The provided context optionally controls which HTTP client is used. See the [HTTPClient] variable. The code will be in the [http.Request.FormValue]("code"). Before calling Exchange, be sure to validate [http.Request.FormValue]("state") if you are using it to protect against CSRF attacks. If using PKCE to protect against CSRF attacks, opts should include a VerifierOption. PasswordCredentialsToken converts a resource owner username and password pair into a token. Per the RFC, this grant type should only be used "when there is a high degree of trust between the resource owner and the client (e.g., the client is part of the device operating system or a highly privileged application), and when other authorization grant types are not available." See https://tools.ietf.org/html/rfc6749#section-4.3 for more info. The provided context optionally controls which HTTP client is used. See the [HTTPClient] variable. TokenSource returns a [TokenSource] that returns t until t expires, automatically refreshing it as necessary using the provided context. Most users will use [Config.Client] instead.
DeviceAuthResponse describes a successful RFC 8628 Device Authorization Response https://datatracker.ietf.org/doc/html/rfc8628#section-3.2 DeviceCode Expiry is when the device code and user code expire Interval is the duration in seconds that Poll should wait between requests UserCode is the code the user should enter at the verification uri VerificationURI is where user should enter the user code VerificationURIComplete (if populated) includes the user code in the verification URI. This is typically shown to the user in non-textual form, such as a QR code. ( DeviceAuthResponse) MarshalJSON() ([]byte, error) (*DeviceAuthResponse) UnmarshalJSON(data []byte) error DeviceAuthResponse : encoding/json.Marshaler *DeviceAuthResponse : encoding/json.Unmarshaler DeviceAuthResponse : github.com/goccy/go-json.Marshaler *DeviceAuthResponse : github.com/goccy/go-json.Unmarshaler func (*Config).DeviceAuth(ctx context.Context, opts ...AuthCodeOption) (*DeviceAuthResponse, error) func (*Config).DeviceAccessToken(ctx context.Context, da *DeviceAuthResponse, opts ...AuthCodeOption) (*Token, error)
Endpoint represents an OAuth 2.0 provider's authorization and token endpoint URLs. AuthStyle optionally specifies how the endpoint wants the client ID & client secret sent. The zero value means to auto-detect. AuthURL string DeviceAuthURL string TokenURL string
RetrieveError is the error returned when the token endpoint returns a non-2XX HTTP status code or populates RFC 6749's 'error' parameter. https://datatracker.ietf.org/doc/html/rfc6749#section-5.2 Body []byte ErrorCode string ErrorDescription string ErrorURI string Response *http.Response (*RetrieveError) Error() string *RetrieveError : error
Token represents the credentials used to authorize the requests to access protected resources on the OAuth 2.0 provider's backend. Most users of this package should not access fields of Token directly. They're exported mostly for use by related packages implementing derivative OAuth2 flows. AccessToken is the token that authorizes and authenticates the requests. ExpiresIn is the OAuth2 wire format "expires_in" field, which specifies how many seconds later the token expires, relative to an unknown time base approximately around "now". It is the application's responsibility to populate `Expiry` from `ExpiresIn` when required. Expiry is the optional expiration time of the access token. If zero, [TokenSource] implementations will reuse the same token forever and RefreshToken or equivalent mechanisms for that TokenSource will not be used. RefreshToken is a token that's used by the application (as opposed to the user) to refresh the access token if it expires. TokenType is the type of token. The Type method returns either this or "Bearer", the default. Extra returns an extra field. Extra fields are key-value pairs returned by the server as a part of the token retrieval response. SetAuthHeader sets the Authorization header to r using the access token in t. This method is unnecessary when using [Transport] or an HTTP Client returned by this package. Type returns t.TokenType if non-empty, else "Bearer". Valid reports whether t is non-nil, has an AccessToken, and is not expired. WithExtra returns a new [Token] that's a clone of t, but using the provided raw extra map. This is only intended for use by packages implementing derivative OAuth2 flows. func (*Config).DeviceAccessToken(ctx context.Context, da *DeviceAuthResponse, opts ...AuthCodeOption) (*Token, error) func (*Config).Exchange(ctx context.Context, code string, opts ...AuthCodeOption) (*Token, error) func (*Config).PasswordCredentialsToken(ctx context.Context, username, password string) (*Token, error) func (*Token).WithExtra(extra any) *Token func TokenSource.Token() (*Token, error) func ReuseTokenSource(t *Token, src TokenSource) TokenSource func ReuseTokenSourceWithExpiry(t *Token, src TokenSource, earlyExpiry time.Duration) TokenSource func StaticTokenSource(t *Token) TokenSource func (*Config).Client(ctx context.Context, t *Token) *http.Client func (*Config).TokenSource(ctx context.Context, t *Token) TokenSource
A TokenSource is anything that can return a token. Token returns a token or an error. Token must be safe for concurrent use by multiple goroutines. The returned Token must not be modified. func ReuseTokenSource(t *Token, src TokenSource) TokenSource func ReuseTokenSourceWithExpiry(t *Token, src TokenSource, earlyExpiry time.Duration) TokenSource func StaticTokenSource(t *Token) TokenSource func (*Config).TokenSource(ctx context.Context, t *Token) TokenSource func NewClient(ctx context.Context, src TokenSource) *http.Client func ReuseTokenSource(t *Token, src TokenSource) TokenSource func ReuseTokenSourceWithExpiry(t *Token, src TokenSource, earlyExpiry time.Duration) TokenSource
Transport is an [http.RoundTripper] that makes OAuth 2.0 HTTP requests, wrapping a base [http.RoundTripper] and adding an Authorization header with a token from the supplied [TokenSource]. Transport is a low-level mechanism. Most code will use the higher-level [Config.Client] method instead. Base is the base RoundTripper used to make HTTP requests. If nil, http.DefaultTransport is used. Source supplies the token to add to outgoing requests' Authorization headers. CancelRequest does nothing. It used to be a legacy cancellation mechanism but now only it only logs on first use to warn that it's deprecated. Deprecated: use contexts for cancellation instead. RoundTrip authorizes and authenticates the request with an access token from Transport's Source. *Transport : net/http.RoundTripper
Package-Level Functions (total 10)
GenerateVerifier generates a PKCE code verifier with 32 octets of randomness. This follows recommendations in RFC 7636. A fresh verifier should be generated for each authorization. The resulting verifier should be passed to [Config.AuthCodeURL] or [Config.DeviceAuth] with [S256ChallengeOption], and to [Config.Exchange] or [Config.DeviceAccessToken] with [VerifierOption].
NewClient creates an [*http.Client] from a [context.Context] and [TokenSource]. The returned client is not valid beyond the lifetime of the context. Note that if a custom [*http.Client] is provided via the [context.Context] it is used only for token acquisition and is not used to configure the [*http.Client] returned from NewClient. As a special case, if src is nil, a non-OAuth2 client is returned using the provided context. This exists to support related OAuth2 packages.
RegisterBrokenAuthHeaderProvider previously did something. It is now a no-op. Deprecated: this function no longer does anything. Caller code that wants to avoid potential extra HTTP requests made during auto-probing of the provider's auth style should set Endpoint.AuthStyle.
ReuseTokenSource returns a [TokenSource] which repeatedly returns the same token as long as it's valid, starting with t. When its cached token is invalid, a new token is obtained from src. ReuseTokenSource is typically used to reuse tokens from a cache (such as a file on disk) between runs of a program, rather than obtaining new tokens unnecessarily. The initial token t may be nil, in which case the [TokenSource] is wrapped in a caching version if it isn't one already. This also means it's always safe to wrap ReuseTokenSource around any other [TokenSource] without adverse effects.
ReuseTokenSourceWithExpiry returns a [TokenSource] that acts in the same manner as the [TokenSource] returned by [ReuseTokenSource], except the expiry buffer is configurable. The expiration time of a token is calculated as t.Expiry.Add(-earlyExpiry).
S256ChallengeFromVerifier returns a PKCE code challenge derived from verifier with method S256. Prefer to use [S256ChallengeOption] where possible.
S256ChallengeOption derives a PKCE code challenge derived from verifier with method S256. It should be passed to [Config.AuthCodeURL] or [Config.DeviceAuth] only.
SetAuthURLParam builds an [AuthCodeOption] which passes key/value parameters to a provider's authorization endpoint.
StaticTokenSource returns a [TokenSource] that always returns the same token. Because the provided token t is never refreshed, StaticTokenSource is only useful for tokens that never expire.
VerifierOption returns a PKCE code verifier [AuthCodeOption]. It should only be passed to [Config.Exchange] or [Config.DeviceAccessToken].
Package-Level Variables (total 5)
AccessTypeOnline and AccessTypeOffline are options passed to the Options.AuthCodeURL method. They modify the "access_type" field that gets sent in the URL returned by AuthCodeURL. Online is the default if neither is specified. If your application needs to refresh access tokens when the user is not present at the browser, then use offline. This will result in your application obtaining a refresh token the first time your application exchanges an authorization code for a user.
ApprovalForce forces the users to view the consent dialog and confirm the permissions request at the URL returned from AuthCodeURL, even if they've already done so.
HTTPClient is the context key to use with [context.WithValue] to associate a [*http.Client] value with a context.
NoContext is the default context you should supply if not using your own [context.Context]. Deprecated: Use [context.Background] or [context.TODO] instead.
Package-Level Constants (total 3)
AuthStyleAutoDetect means to auto-detect which authentication style the provider wants by trying both ways and caching the successful way for the future.
AuthStyleInHeader sends the client_id and client_password using HTTP Basic Authorization. This is an optional style described in the OAuth2 RFC 6749 section 2.3.1.
AuthStyleInParams sends the "client_id" and "client_secret" in the POST body as application/x-www-form-urlencoded parameters.