--- title: Overview --- import { SocialAuthGrid } from './SocialAuthGrid'; import DefaultBehaviour from './\_default-behaviour.md'; import OverrideIntro from './\_override-intro.md'; import GetUserFieldsType from './\_getuserfields-type.md'; Social login options (e.g., _Log in with Google_) are a great (maybe even the best) solution for handling user accounts. A famous old developer joke tells us _"The best auth system is the one you never have to make."_ Wasp wants to make adding social login options to your app as painless as possible. Using different social providers gives users a chance to sign into your app via their existing accounts on other platforms (Google, GitHub, etc.). This page goes through the common behaviors between all supported social login providers and shows you how to customize them. It also gives an overview of Wasp's UI helpers - the quickest possible way to get started with social auth. ## Available Providers Wasp currently supports the following social login providers: ## User Entity Wasp requires you to declare a `userEntity` for all `auth` methods (social or otherwise). This field tells Wasp which Entity represents the user. Here's what the full setup looks like: ```wasp title=main.wasp app myApp { wasp: { version: "^0.13.0" }, title: "My App", auth: { // highlight-next-line userEntity: User, methods: { google: {} }, onAuthFailedRedirectTo: "/login" }, } // highlight-next-line entity User {=psl id Int @id @default(autoincrement()) //... psl=} ``` ```wasp title=main.wasp app myApp { wasp: { version: "^0.13.0" }, title: "My App", auth: { // highlight-next-line userEntity: User, methods: { google: {} }, onAuthFailedRedirectTo: "/login" }, } // highlight-next-line entity User {=psl id Int @id @default(autoincrement()) //... psl=} ``` To learn more about what the fields on these entities represent, look at the [API Reference](#api-reference). ## Default Behavior ## Overrides By default, Wasp doesn't store any information it receives from the social login provider. It only stores the user's ID specific to the provider. If you wish to store more information about the user, you can override the default behavior. You can do this by defining the `userSignupFields` and `configFn` fields in `main.wasp` for each provider. You can create custom signup setups, such as allowing users to define a custom username after they sign up with a social provider. ### Example: Allowing User to Set Their Username If you want to modify the signup flow (e.g., let users choose their own usernames), you will need to go through three steps: 1. The first step is adding a `isSignupComplete` property to your `User` Entity. This field will signal whether the user has completed the signup process. 2. The second step is overriding the default signup behavior. 3. The third step is implementing the rest of your signup flow and redirecting users where appropriate. Let's go through both steps in more detail. #### 1. Adding the `isSignupComplete` Field to the `User` Entity ```wasp title=main.wasp entity User {=psl id Int @id @default(autoincrement()) username String? @unique // highlight-next-line isSignupComplete Boolean @default(false) psl=} ``` ```wasp title=main.wasp entity User {=psl id Int @id @default(autoincrement()) username String? @unique // highlight-next-line isSignupComplete Boolean @default(false) psl=} ``` #### 2. Overriding the Default Behavior Declare an import under `app.auth.methods.google.userSignupFields` (the example assumes you're using Google): ```wasp title=main.wasp app myApp { wasp: { version: "^0.13.0" }, title: "My App", auth: { userEntity: User, methods: { google: { // highlight-next-line userSignupFields: import { userSignupFields } from "@src/auth/google.js" } }, onAuthFailedRedirectTo: "/login" }, } // ... ``` And implement the imported function. ```js title=src/auth/google.js export const userSignupFields = { isSignupComplete: () => false, } ``` ```wasp title=main.wasp app myApp { wasp: { version: "^0.13.0" }, title: "My App", auth: { userEntity: User, methods: { google: { // highlight-next-line userSignupFields: import { userSignupFields } from "@src/auth/google.js" } }, onAuthFailedRedirectTo: "/login" }, } // ... ``` And implement the imported function: ```ts title=src/auth/google.ts import { defineUserSignupFields } from 'wasp/server/auth' export const userSignupFields = defineUserSignupFields({ isSignupComplete: () => false, }) ``` #### 3. Showing the Correct State on the Client You can query the user's `isSignupComplete` flag on the client with the [`useAuth()`](../../auth/overview) hook. Depending on the flag's value, you can redirect users to the appropriate signup step. For example: 1. When the user lands on the homepage, check the value of `user.isSignupComplete`. 2. If it's `false`, it means the user has started the signup process but hasn't yet chosen their username. Therefore, you can redirect them to `EditUserDetailsPage` where they can edit the `username` property. ```jsx title=src/HomePage.jsx import { useAuth } from 'wasp/client/auth' import { Redirect } from 'react-router-dom' export function HomePage() { const { data: user } = useAuth() if (user.isSignupComplete === false) { return } // ... } ``` ```tsx title=src/HomePage.tsx import { useAuth } from 'wasp/client/auth' import { Redirect } from 'react-router-dom' export function HomePage() { const { data: user } = useAuth() if (user.isSignupComplete === false) { return } // ... } ``` The same general principle applies to more complex signup procedures, just change the boolean `isSignupComplete` property to a property like `currentSignupStep` that can hold more values. ### Using the User's Provider Account Details Account details are provider-specific. Each provider has their own rules for defining the `userSignupFields` and `configFn` fields: ## UI Helpers :::tip Use Auth UI [Auth UI](../../auth/ui) is a common name for all high-level auth forms that come with Wasp. These include fully functional auto-generated login and signup forms with working social login buttons. If you're looking for the fastest way to get your auth up and running, that's where you should look. The UI helpers described below are lower-level and are useful for creating your custom forms. ::: Wasp provides sign-in buttons and URLs for each of the supported social login providers. ```jsx title=src/LoginPage.jsx import { GoogleSignInButton, googleSignInUrl, GitHubSignInButton, gitHubSignInUrl, } from 'wasp/client/auth' export const LoginPage = () => { return ( <> {/* or */} Sign in with Google Sign in with GitHub ) } ``` ```tsx title=src/LoginPage.tsx import { GoogleSignInButton, googleSignInUrl, GitHubSignInButton, gitHubSignInUrl, } from 'wasp/client/auth' export const LoginPage = () => { return ( <> {/* or */} Sign in with Google Sign in with GitHub ) } ``` If you need even more customization, you can create your custom components using `signInUrl`s. ## API Reference ### Fields in the `app.auth` Dictionary and Overrides For more information on: - Allowed fields in `app.auth` - `userSignupFields` and `configFn` functions Check the provider-specific API References: