Jon Rumsey
An online markdown blog and knowledge repository.
Project maintained by nojronatron
Hosted on GitHub Pages — Theme by mattgraham
Spring Tutorial on OAuth
Read the tutorial and optionally walk through the tutorial in code (not required).
Reference
Spring Tutorial on OAuth
Note: All aspects of this summary were derived from article "Spring Boot and OAuth2" by the SpringIO dev team.
There is Apache 2.0 licensed open-source code available on GitHub
Spring Boot and OAuth2
Requirements: OAuth 2.0 (native in) Spring Boot
SSO providers like Google and GitHub can be integrated into your authentication flow.
OAuth with Spring Boot can be applied to simple websites - the demo code is just a couple web pages including a static home/index page.
SSO with GitHub
- Add Spring Security as a dependency.
- Include Spring OAuth 2.0 Client Starter.
- Create a home/splash page and add the JS canned code suggested in the reference article.
- Add a new GitHub app => New OAuth App => (enter app homepage e.g. localhost:8080) => add callback URL e.g. 'http://localhost:8080/login/oauth2/code/github' => Register App
- Config 'application.yml' (see demo code at source webiste).
- github-client-id and github-client-secret are placeholders, so replace them with the OAuth 2.0 creds created with GitHub, above.
- SSO enables sign-on through browser sessions close/openings, etc.
- Clear your browser cache => local credentials: This clears the SSO cache that was set via 'Set-Cookie' and 'JSESSIONID'.
- Add a Welcome! page by marking some HTML elements with "container unauthenticated", "/oaugh2/authoriation/github", "container authenticated", and 'user'.
- The '/user' endpoint is server-side and returns the currently-logged-in user. SocialApplication.java code is included in the reference article.
- Note Annotations '@RestController', '@GetMapping', 'OAuth2User' are injects to the handler above.
- Enable a public homepage by extending WebSecurityConfigurerAdapter in SocialApplication.java. See the code in the reference site.
- The '@SpringBootAnnotation' annotation attaches security filter chain configuration for the OAuth 2.0 processor.
- Allow '/', '/error', '/webjars/**' for general operation of the website.
- Configure AJAX endpoints to respond with 401 (instead of defaulting to redirect to login page) => Configure 'authenticationEntryPoint' to do this.
- Add a Logout button client-side (via JS) that will ask the server to cancel the OAuth cookie. Review the code at the referenced website.
- Add a logout endpoint '/logout' (clears session and invalidates cookie) via the WebSecurityConfigureAdapter.java.configure() method. Keep in mind the logout is a POST call. See the reference page code block.
- Add a filter to create a cookie that emulates the XSRF-TOKEN type cookie, within the WebSecurityConfigurerAdapter.java.config() method. See the code.
- Add js-cookie library to enable adding CSRF Token (via the backend), then reference it in the index.html file using some ajax. See code on the site.
SSO with Google API?
- Setup a project in the Google API Console to get OAuth 2.0 credentials.
- Follow the "Open ID Connect" instructions to set up OAuth 2.
- Supply the Redirect URI e.g. 'http://localhost:8080/login/oauth2/code/google'
- Update application.yaml to utilize 'google-client-id' and 'google-client-secret'. See example at the reference website.
- Add the registration path link to index.html (like what was done for GitHub, in fact alongside it if using GitHub too).
- Add a local user-db via Spring Repositories and a custom user object, then implement and expose OAuth2UserService to talk to both Auth Server and your user DB. The return type will be your custom User object that implements OAuth2User.
Add an Error Page for Unauthed Users
- Utilize class "container text-danger error" div to hold the unauthenticated message for the user.
- Call '/error' path and populate above div with the content. A code sample of an error function is available on the reference website.
- Capture the error message when authentication fails by configuring AuthenticationFailureHandler configure method. See the code at the ref'd site.
- A simple ErrorController.java can then get the Session Attribute of "error.message" and return it as a String message. See the code sample at the ref'd site.
- Spring Security generates an HTTP 401 when a user fails to authenticate (token grant is rejected). This can be extended (via auth rule) to reject users not in the correct organization - a la GitHub orgs. GH has an API for this! Instantiate '@Bean' type OAuth2UserService to ID the user principal, then leverage the principal to throw an exception if not in the correct organization. There is sample code posted at the Spring website that demonstrates implmenting this.
- WebClient is used to access the GH API. It has to be created as an @Bean. See the sample code, where the rules are applied via WebClient.builder() filter functions.
Spring Security Defaults
- Ships with default provider selector page: Point to '/login' instead of '/oauth2/authorization/{reg-id}'
Attributions
All aspects of this summary were derived from [Spring IO Tutorial of Spring Boot OAuth2, access June 7th and 8th 2022]
Back to Root Readme