OAuthProvider

Struct OAuthProvider 

Source
pub struct OAuthProvider { /* private fields */ }
Expand description

Builder-like representation of an OAuth identity provider.

The provider stores configuration (scopes, custom parameters, language hints) and creates OAuthRequest instances that can be routed through the popup or redirect handlers registered on Auth.

Implementations§

Source§

impl OAuthProvider

Source

pub fn new( provider_id: impl Into<String>, authorization_endpoint: impl Into<String>, ) -> Self

Creates a new provider with the given ID and authorization endpoint.

Source

pub fn provider_id(&self) -> &str

Returns the provider identifier (e.g. google.com).

Source

pub fn authorization_endpoint(&self) -> &str

Returns the full authorization endpoint URL.

Source

pub fn scopes(&self) -> &[String]

Returns the configured OAuth scopes.

Source

pub fn custom_parameters(&self) -> &HashMap<String, String>

Returns any custom query parameters used when initiating flows.

Source

pub fn display_name(&self) -> Option<&str>

Returns an optional user-facing display name for the provider.

Source

pub fn language_code(&self) -> Option<&str>

Returns the preferred language hint for provider UX.

Source

pub fn add_scope(&mut self, scope: impl Into<String>)

Adds a scope to the provider if it has not been added yet.

Source

pub fn set_scopes<I, S>(&mut self, scopes: I)
where I: IntoIterator<Item = S>, S: Into<String>,

Replaces the provider scopes with the provided list.

Source

pub fn set_custom_parameters( &mut self, parameters: HashMap<String, String>, ) -> &mut Self

Overwrites the custom parameters included in authorization requests.

Source

pub fn set_display_name(&mut self, value: impl Into<String>) -> &mut Self

Sets the user-visible display name.

Source

pub fn set_language_code(&mut self, value: impl Into<String>) -> &mut Self

Sets the preferred language hint passed to the provider.

Source

pub fn build_request(&self, auth: &Auth) -> AuthResult<OAuthRequest>

Builds the OAuthRequest that will be passed to popup/redirect handlers.

Source

pub fn sign_in_with_popup(&self, auth: &Auth) -> AuthResult<UserCredential>

Runs the configured popup handler and returns the produced credential. Executes the sign-in flow using a popup handler.

Links the current user with this provider using a popup flow.

Source

pub fn sign_in_with_redirect(&self, auth: &Auth) -> AuthResult<()>

Delegates to the redirect handler to start a redirect based flow.

Initiates a redirect flow to link the current user with this provider.

Source

pub fn get_redirect_result(auth: &Auth) -> AuthResult<Option<UserCredential>>

Completes a redirect flow using the registered redirect handler.

The provider does not influence result parsing at this stage; the handler is responsible for decoding whichever callback mechanism the hosting platform uses.

Trait Implementations§

Source§

impl Clone for OAuthProvider

Source§

fn clone(&self) -> OAuthProvider

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for OAuthProvider

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<T> ErasedDestructor for T
where T: 'static,