4.0.0 • Published 1 year ago

@baseapp-frontend/authentication v4.0.0

Weekly downloads
-
License
MIT
Repository
github
Last release
1 year ago

@baseapp-frontend/authentication

Overview

This package includes authentication modules such as login, signup, reset password, multifactor authentication and more.

Installation

You can install the package via npm, yarn or pnpm:

npm install @baseapp-frontend/authentication
# or
yarn add @baseapp-frontend/authentication
# or
pnpm install @baseapp-frontend/authentication

What is in here?

useLogin

Handles login/mfa form and execute the login. Extends all ReactQuery's useMutation's options on loginOptions and mfaOptions fields.

Parameters

  • validationSchema (optional)

    • This is a validation schema used with Yup, a JavaScript object schema validator and builder. The default value for validationSchema is DEFAULT_VALIDATION_SCHEMA. This schema is used to validate the form values before submission.
  • defaultValues (optional)

    • This is an object representing the initial values for the form fields. The default value for defaultValues is DEFAULT_INITIAL_VALUES.
  • loginOptions (optional)

    • This object is used to provide additional configuration to the useMutation hook from react-query that handles the login request. By default, it's an empty object {}.
  • mfaOptions (optional)

    • This object provides additional configuration to the useMutation hook that handles the second step of login, which is the Multi-Factor Authentication (MFA) request. By default, it's an empty object {}.

Both options are just an shortcut for react-query's mutation's options

Returns

  • form (react-hook-form's instance)
    • This instance is important for building the form's inputs and already handles the onSubmit behavior.
  • mutation (react-query's mutation instance)
    • This instance can be used to execute the login at any time.
  • mfaForm (react-hook-form's instance)
    • This instance is utilized for the Multi-Factor Authentication (MFA) form. Like the form instance, it is used for creating the MFA form's inputs and handles the onSubmit behavior.
  • mfaMutation (react-query's mutation instance)
    • This instance is used for executing the MFA step of the login process when needed.

Usage

  • form usage example:
const { form } = useLogin()
return <form onSubmit={form.handleSubmit}>
  <InputField
    label="Email Address"
    name="email"
    type="email"
    placeholder="Email"
    form={form}
  />

  <PasswordField
    label="Password"
    name="password"
    form={form}
  />

  <button type="submit">Login</button>
</form>
  • mutation usage example, login after a successful signup:
const { mutation: loginMutation } = useLogin()
useSignUp({
  onSuccess: (response, variables) => {
    loginMutation.mutate({
      email: variables.email,
      password: variables.password,
    })
  },
})

useRecoverPassword

Handles password recovery form and sends a request for password recovery. Extends all ReactQuery's useMutation's options on options field.

Parameters

  • validationSchema (optional)

    • This is a validation schema used with Yup, a JavaScript object schema validator and builder. The default value for validationSchema is DEFAULT_VALIDATION_SCHEMA. This schema is used to validate the form values before submission.
  • defaultValues (optional)

    • This is an object representing the initial values for the form fields. The default value for defaultValues is DEFAULT_INITIAL_VALUES.
  • options (optional)

    • This object is used to provide additional configuration to the useMutation hook from react-query that handles the password recovery request. By default, it's an empty object {}.

Returns

Usage

  • form usage example:
const { form } = useRecoverPassword()
return <form onSubmit={form.handleSubmit}>
  <InputField
    label="Email Address"
    name="email"
    type="email"
    placeholder="Email"
    form={form}
  />

  <button type="submit">Recover password</button>
</form>

useResetPassword

Handles password reset form and sends a request for password reset. Extends all ReactQuery's useMutation's options on options field.

Parameters

  • validationSchema (optional)

    • This is a validation schema used with Yup, a JavaScript object schema validator and builder. The default value for validationSchema is DEFAULT_VALIDATION_SCHEMA. This schema is used to validate the form values before submission.
  • defaultValues (optional)

    • This is an object representing the initial values for the form fields. The default value for defaultValues is DEFAULT_INITIAL_VALUES.
  • options (optional)

    • This object is used to provide additional configuration to the useMutation hook from react-query that handles the password reset request. By default, it's an empty object {}.

Returns

Usage

  • form usage example:
const { form } = useResetPassword()
return <form onSubmit={form.handleSubmit}>
  <PasswordField
    label="New Password"
    name="newPassword"
    form={form}
  />

  <InputField
    label="Reset Token"
    name="token"
    type="text"
    placeholder="Token"
    form={form}
  />

  <button type="submit">Reset password</button>
</form>

useSignUp

Handles sign-up form and sends a request for registration. Extends all ReactQuery's useMutation's options on options field.

Parameters

  • validationSchema (optional)

    • This is a validation schema used with Yup, a JavaScript object schema validator and builder. The default value for validationSchema is DEFAULT_VALIDATION_SCHEMA. This schema is used to validate the form values before submission.
  • defaultValues (optional)

    • This is an object representing the initial values for the form fields. The default value for defaultValues is DEFAULT_INITIAL_VALUES.
  • options (optional)

    • This object is used to provide additional configuration to the useMutation hook from react-query that handles the registration request. By default, it's an empty object {}.

Returns

Usage

  • form usage example:
const { form } = useSignUp()
return <form onSubmit={form.handleSubmit}>
  <InputField
    label="Email Address"
    name="email"
    type="email"
    placeholder="Email"
    form={form}
  />

  <PasswordField
    label="Password"
    name="password"
    form={form}
  />

  <button type="submit">Sign up</button>
</form>

useUser

Retrieves the authenticated user's data. Extends all ReactQuery's useQuery's options on options field.

Parameters

  • options (optional)
    • This object is used to provide additional configuration to the useQuery hook from react-query that retrieves the user's data. By default, it's an empty object {}.

Returns

  • user
    • The data of the authenticated user.
  • ...rest
    • The rest of the properties returned by the useQuery hook, like status, error, isFetching, etc.

This hook also removes the user's token cookie and invalidates the user data cache if a 401 Unauthorized error occurs.

Usage

  • useUser usage example:
const { user, isLoading, isError, error } = useUser()

if (isLoading) {
  return <div>Loading...</div>
}

if (isError) {
  return <div>Error: {error.message}</div>
}

return <div>Hello, {user.name}</div>

useLogout

Invalidates the authenticated user's data and Multi-Factor Authentication (MFA) data in cache, and removes the user's token cookie.

Returns

  • logout
    • This is a function that, when called, performs the logout operation.

Usage

  • useLogout usage example:
const logout = useLogout()

return <button onClick={logout}>Logout</button>

useMfaActivate

This hook uses the activate method from the MfaApi to activate Multi-Factor Authentication (MFA) for a user.

Parameters

  • options (optional)
    • This object is used to provide additional configuration to the useMutation hook from react-query that handles the MFA activation request. By default, it's an empty object {}.

Returns

Usage

  • useMfaActivate usage example:
const { mutation: mutate: { activateMfa } } = useMfaActivate()

activateMfa.mutate({ method: 'your-method' })

useMfaActivateConfirm

Handles MFA activation confirmation by validating and submitting the form. It extends all ReactQuery's useMutation's options.

Parameters

  • method

    • This is the MFA method that the user selected for activation.
  • validationSchema (optional)

    • This is a validation schema used with Yup, a JavaScript object schema validator and builder. The default value for validationSchema is CODE_VALIDATION_SCHEMA. This schema is used to validate the form values before submission.
  • defaultValues (optional)

    • This is an object representing the initial values for the form fields. The default value for defaultValues is CODE_VALIDATION_INITIAL_VALUES.
  • options (optional)

    • This object is used to provide additional configuration to the useMutation hook from react-query that handles the MFA activation confirmation. By default, it's an empty object {}.

Returns

Usage

  • useMfaActivateConfirm usage example:
const { form, mutation: { activateMfaConfirm } } = useMfaActivateConfirm({ method: 'your-method' })

return <form onSubmit={form.handleSubmit}>
  <InputField
    label="Code"
    name="code"
    form={form}
  />

  <button type="submit">Confirm MFA Activation</button>
</form>

useMfaActiveMethods

Handles the fetching of the active MFA methods for the current user.

Parameters

  • options (optional)
    • This object is used to provide additional configuration to the useQuery hook from react-query that fetches the MFA active methods. By default, it's an empty object {}.
    • enabled (optional)
      • This is a boolean that defines if the query should run automatically when the component mounts. The default value is true.

Returns

  • activeMethods

    • This array contains the active MFA methods for the current user.
  • ...rest (All remaining properties from useQuery's result)

Usage

  • useMfaActiveMethods usage example:
const { activeMethods, isLoading, isError, error } = useMfaActiveMethods()

if (isLoading) {
  return <div>Loading...</div>
}

if (isError) {
  return <div>An error has occurred: {error.message}</div>
}

return (
  <div>
    Active MFA Methods:
    {activeMethods.map((method) => (
      <p key={method}>{method}</p>
    ))}
  </div>
)

useMfaConfiguration

Handles fetching the MFA configuration for the current user.

Parameters

  • options (optional)
    • This object is used to provide additional configuration to the useQuery hook from react-query that fetches the MFA configuration. By default, it's an empty object {}.
    • enabled (optional)
      • This is a boolean that defines if the query should run automatically when the component mounts. The default value is true.

Returns

  • configuration

    • This object contains the MFA configuration for the current user.
  • ...rest (All remaining properties from useQuery's result)

Usage

  • useMfaConfiguration usage example:
const { configuration, isLoading, isError, error } = useMfaConfiguration()

if (isLoading) {
  return <div>Loading...</div>
}

if (isError) {
  return <div>An error has occurred: {error.message}</div>
}

return (
  <div>
    MFA Configuration:
    <p>{configuration.methods}</p>
  </div>
)

useMfaDeactivate

Handles the deactivation of a Multi-Factor Authentication (MFA) method for the current user.

Parameters

  • options (optional)
    • This object is used to provide additional configuration to the useMutation hook from react-query that performs the MFA deactivation. By default, it's an empty object {}.

Returns

  • mutation
    • This object contains methods and data related to the mutation. It includes mutate, mutateAsync, isLoading, isError, error, status, and more. Check React Query's useMutation documentation for all available properties.

Usage

  • useMfaDeactivate usage example:
const { mutate: deactivateMfa } = useMfaDeactivate()

// to deactivate a method
deactivateMfa.mutate({ method: 'your-method', code: 'your-code' })
4.0.0

1 year ago

3.2.5

1 year ago

3.2.4

1 year ago

2.2.0

1 year ago

3.2.2

1 year ago

3.2.1

1 year ago

3.2.0

1 year ago

3.1.0

1 year ago

3.0.1

1 year ago

3.2.3

1 year ago

3.0.0

1 year ago

2.1.2

2 years ago

2.1.3

2 years ago

2.1.1

2 years ago

2.1.0

2 years ago

2.0.1

2 years ago

2.0.0

2 years ago

1.2.6

2 years ago

1.2.5

2 years ago

1.2.4

2 years ago

1.2.3

2 years ago

1.2.2

2 years ago

1.2.0

2 years ago

1.1.1

2 years ago

1.0.2

2 years ago

1.1.0

2 years ago

1.1.4

2 years ago

1.1.3

2 years ago

1.2.1

2 years ago

1.1.2

2 years ago

1.0.3

2 years ago

1.0.1

2 years ago

1.0.0

2 years ago