Class GoogleTokenProvider
java.lang.Object
io.helidon.security.spi.SynchronousProvider
io.helidon.security.providers.google.login.GoogleTokenProvider
- All Implemented Interfaces:
AuthenticationProvider,OutboundSecurityProvider,SecurityProvider
public final class GoogleTokenProvider
extends SynchronousProvider
implements AuthenticationProvider, OutboundSecurityProvider
Provider supporting login button from front-end.
This expects the token to be sent in a header.
By default, Authorization header with bearer is expected, e.g.:
Authorization: bearer abcdefg_google_id_token_from_login_button_callback.
Configure login button as described here:
https://developers.google.com/identity/sign-in/web/sign-in
See google-login example.-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic final classFluent API builder to buildGoogleTokenProviderinstance. -
Method Summary
Modifier and TypeMethodDescriptionstatic GoogleTokenProvider.Builderbuilder()Fluent API builder to buildGoogleTokenProviderinstance.static GoogleTokenProviderCreate an instance from configuration.booleanisOutboundSupported(ProviderRequest providerRequest, SecurityEnvironment outboundEnv, EndpointConfig outboundConfig) Check if the path to be executed is supported by this security provider.protected AuthenticationResponsesyncAuthenticate(ProviderRequest providerRequest) Synchronous authentication.protected OutboundSecurityResponsesyncOutbound(ProviderRequest providerRequest, SecurityEnvironment outboundEnv, EndpointConfig outboundEndpointConfig) Synchronous outbound security.Methods inherited from class io.helidon.security.spi.SynchronousProvider
authenticate, authorize, outboundSecurity, syncAuthorizeMethods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface io.helidon.security.spi.AuthenticationProvider
authenticateMethods inherited from interface io.helidon.security.spi.OutboundSecurityProvider
outboundSecurityMethods inherited from interface io.helidon.security.spi.SecurityProvider
supportedAnnotations, supportedAttributes, supportedConfigKeys, supportedCustomObjects
-
Method Details
-
create
Create an instance from configuration. Used by Security when configuring this provider from configuration by class name.- Parameters:
config- Configuration located on the provider's key- Returns:
- Instance configured from the configuration instance
-
builder
Fluent API builder to buildGoogleTokenProviderinstance.- Returns:
- Builder with just default values
-
syncAuthenticate
Description copied from class:SynchronousProviderSynchronous authentication.- Overrides:
syncAuthenticatein classSynchronousProvider- Parameters:
providerRequest- context with environment, subject(s) etc.- Returns:
- authentication response
- See Also:
-
isOutboundSupported
public boolean isOutboundSupported(ProviderRequest providerRequest, SecurityEnvironment outboundEnv, EndpointConfig outboundConfig) Description copied from interface:OutboundSecurityProviderCheck if the path to be executed is supported by this security provider. Defaults to true.- Specified by:
isOutboundSupportedin interfaceOutboundSecurityProvider- Parameters:
providerRequest- context with environment, subject(s) etc. that was receivedoutboundEnv- environment for outbound calloutboundConfig- outbound endpoint configuration- Returns:
- true if this identity propagator can generate required headers for the path defined
-
syncOutbound
protected OutboundSecurityResponse syncOutbound(ProviderRequest providerRequest, SecurityEnvironment outboundEnv, EndpointConfig outboundEndpointConfig) Description copied from class:SynchronousProviderSynchronous outbound security.- Overrides:
syncOutboundin classSynchronousProvider- Parameters:
providerRequest- context with environment, subject(s) etc.outboundEnv- environment of this outbound calloutboundEndpointConfig- endpoint config for outbound call- Returns:
- outbound response
- See Also:
-