2
0

index.adoc 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. [[webflux-oauth2-client]]
  2. = OAuth 2.0 Client
  3. :page-section-summary-toc: 1
  4. The OAuth 2.0 Client features provide support for the Client role as defined in the https://tools.ietf.org/html/rfc6749#section-1.1[OAuth 2.0 Authorization Framework].
  5. At a high-level, the core features available are:
  6. .Authorization Grant support
  7. * xref:reactive/oauth2/client/authorization-grants.adoc#oauth2-client-authorization-code[Authorization Code]
  8. * xref:reactive/oauth2/client/authorization-grants.adoc#oauth2-client-refresh-token[Refresh Token]
  9. * xref:reactive/oauth2/client/authorization-grants.adoc#oauth2-client-client-credentials[Client Credentials]
  10. * xref:reactive/oauth2/client/authorization-grants.adoc#oauth2-client-password[Resource Owner Password Credentials]
  11. * xref:reactive/oauth2/client/authorization-grants.adoc#oauth2-client-jwt-bearer[JWT Bearer]
  12. * xref:reactive/oauth2/client/authorization-grants.adoc#oauth2-client-token-exchange[Token Exchange]
  13. .Client Authentication support
  14. * xref:reactive/oauth2/client/client-authentication.adoc#oauth2-client-authentication-jwt-bearer[JWT Bearer]
  15. .HTTP Client support
  16. * xref:reactive/oauth2/client/authorized-clients.adoc#oauth2-client-web-client[`WebClient` integration for Reactive Environments] (for requesting protected resources)
  17. The `ServerHttpSecurity.oauth2Client()` DSL provides a number of configuration options for customizing the core components used by OAuth 2.0 Client.
  18. The following code shows the complete configuration options provided by the `ServerHttpSecurity.oauth2Client()` DSL:
  19. .OAuth2 Client Configuration Options
  20. [tabs]
  21. ======
  22. Java::
  23. +
  24. [source,java,role="primary"]
  25. ----
  26. @Configuration
  27. @EnableWebFluxSecurity
  28. public class OAuth2ClientSecurityConfig {
  29. @Bean
  30. public SecurityWebFilterChain securityWebFilterChain(ServerHttpSecurity http) {
  31. http
  32. .oauth2Client(oauth2 -> oauth2
  33. .clientRegistrationRepository(this.clientRegistrationRepository())
  34. .authorizedClientRepository(this.authorizedClientRepository())
  35. .authorizationRequestRepository(this.authorizationRequestRepository())
  36. .authorizationRequestResolver(this.authorizationRequestResolver())
  37. .authenticationConverter(this.authenticationConverter())
  38. .authenticationManager(this.authenticationManager())
  39. );
  40. return http.build();
  41. }
  42. }
  43. ----
  44. Kotlin::
  45. +
  46. [source,kotlin,role="secondary"]
  47. ----
  48. @Configuration
  49. @EnableWebFluxSecurity
  50. class OAuth2ClientSecurityConfig {
  51. @Bean
  52. fun securityFilterChain(http: ServerHttpSecurity): SecurityWebFilterChain {
  53. http {
  54. oauth2Client {
  55. clientRegistrationRepository = clientRegistrationRepository()
  56. authorizedClientRepository = authorizedClientRepository()
  57. authorizationRequestRepository = authorizedRequestRepository()
  58. authorizationRequestResolver = authorizationRequestResolver()
  59. authenticationConverter = authenticationConverter()
  60. authenticationManager = authenticationManager()
  61. }
  62. }
  63. return http.build()
  64. }
  65. }
  66. ----
  67. ======
  68. The `ReactiveOAuth2AuthorizedClientManager` is responsible for managing the authorization (or re-authorization) of an OAuth 2.0 Client, in collaboration with one or more `ReactiveOAuth2AuthorizedClientProvider`(s).
  69. The following code shows an example of how to register a `ReactiveOAuth2AuthorizedClientManager` `@Bean` and associate it with a `ReactiveOAuth2AuthorizedClientProvider` composite that provides support for the `authorization_code`, `refresh_token`, `client_credentials` and `password` authorization grant types:
  70. [tabs]
  71. ======
  72. Java::
  73. +
  74. [source,java,role="primary"]
  75. ----
  76. @Bean
  77. public ReactiveOAuth2AuthorizedClientManager authorizedClientManager(
  78. ReactiveClientRegistrationRepository clientRegistrationRepository,
  79. ServerOAuth2AuthorizedClientRepository authorizedClientRepository) {
  80. ReactiveOAuth2AuthorizedClientProvider authorizedClientProvider =
  81. ReactiveOAuth2AuthorizedClientProviderBuilder.builder()
  82. .authorizationCode()
  83. .refreshToken()
  84. .clientCredentials()
  85. .password()
  86. .build();
  87. DefaultReactiveOAuth2AuthorizedClientManager authorizedClientManager =
  88. new DefaultReactiveOAuth2AuthorizedClientManager(
  89. clientRegistrationRepository, authorizedClientRepository);
  90. authorizedClientManager.setAuthorizedClientProvider(authorizedClientProvider);
  91. return authorizedClientManager;
  92. }
  93. ----
  94. Kotlin::
  95. +
  96. [source,kotlin,role="secondary"]
  97. ----
  98. @Bean
  99. fun authorizedClientManager(
  100. clientRegistrationRepository: ReactiveClientRegistrationRepository,
  101. authorizedClientRepository: ServerOAuth2AuthorizedClientRepository): ReactiveOAuth2AuthorizedClientManager {
  102. val authorizedClientProvider: ReactiveOAuth2AuthorizedClientProvider = ReactiveOAuth2AuthorizedClientProviderBuilder.builder()
  103. .authorizationCode()
  104. .refreshToken()
  105. .clientCredentials()
  106. .password()
  107. .build()
  108. val authorizedClientManager = DefaultReactiveOAuth2AuthorizedClientManager(
  109. clientRegistrationRepository, authorizedClientRepository)
  110. authorizedClientManager.setAuthorizedClientProvider(authorizedClientProvider)
  111. return authorizedClientManager
  112. }
  113. ----
  114. ======