| oauth2_third_party_app {webfakes} | R Documentation | 
App representing the third-party app
Description
The webfakes package comes with two fake apps that allow to imitate the
OAuth2.0 flow in your test cases. (See Aaron Parecki’s tutorial for a good
introduction to OAuth2.0.) One app (oauth2_resource_app()) is the API
server that serves both as the resource and provides authorization.
oauth2_third_party_app() plays the role of the third-party app. They
are useful when testing or demonstrating code handling OAuth2.0
authorization, token caching, etc. in a package. The apps can be used in
your tests directly, or you could adapt one or both of them to better
mimic a particular OAuth2.0 flow.
Usage
oauth2_third_party_app(name = "Third-Party app")
Arguments
| name | Name of the third-party app | 
Details
Endpoints:
-  POST /login/configUse this endpoint to configure the client ID and the client secret of the app, received fromoauth2_resource_app()(or another resource app). You need to send in a JSON or URL encoded body:-  auth_url, the authorization URL of the resource app.
-  token_url, the token URL of the resource app.
-  client_id, the client ID, received from the resource app.
-  client_secretthe client secret, received from the resource app.
 
-  
-  GET /loginUse this endpoint to start the login process. It will redirect to the resource app for authorization and after the OAuth2.0 dance to/login/redirect.
-  GET /login/redirect,POST /login/redirectThis is the redirect URI of the third party app. (Some HTTP clients redirect aPOSTto aGET, others don't, so it has both.) This endpoint is used by the resource app, and it received thecodethat can be exchanged to an access token and thestatewhich was generated in/login. It contacts the resource app to get an access token, and then stores the token in itsapp$localslocal variables. It fails with HTTP code 500 if it cannot obtain an access token. On success it returns a JSON dictionary withaccess_token,expiryandrefresh_token(optionally) by default. This behavior can be changed by redefining theapp$redirect_hook()function.
-  GET /localsreturns the tokens that were obtained from the resource app.
-  GET /datais an endpoint that uses the obtained token(s) to connect to the/dataendpoint of the resource app. The/dataendpoint of the resource app needs authorization. It responds with the response of the resource app. It tries to refresh the access token of the app if needed.
For more details see vignette("oauth", package = "webfakes").
Value
webfakes app
See Also
Other OAuth2.0 functions: 
oauth2_httr_login(),
oauth2_login(),
oauth2_resource_app()