This is an example of how to sign up, sign in, authenticate, send PIN code by email, sign in with Google and sign in with Twitter.
This project does not have a sign up process. If the account does not exist in the database when you sign in, it will be created automatically.
You can sign in with only your email address and PIN code. To confirm your email address, this project will email you a PIN code. You can also sign in with Google and sign in with Twitter.
- Local accounts via email
- Sign in with Google
- Sign in with Twitter
- MySQL Community Server 8.0.30 or higher
- Node.js 18.4.0 or higher
- npm 8.13.2 or higher
- Gmail account for sendmail
- Visit Google Account - Security
- Turn on 2-Step Verification
- Create an app password
Here are the steps:
- Get the project and setup:
# Clone the repo to your current directory
git clone https://github.com/sinProject-Inc/sveltekit-authentication-example.git
# Install the dependencies
cd /sveltekit-authentication-example
npm install
- Create a database named sveltekit_authentication
- Create a .env file by copying .env.example at the top level of the project
- rewrite the env file:
DATABASE_URL="mysql://user:password@localhost:3306/sveltekit_authentication"
GMAIL_USER="[email protected]"
GMAIL_PASS="google_app_password"
TWITTER_CLIENT_ID="(option)"
TWITTER_CLIENT_SECRET="(option)"
- Push the initial schema to the database:
npx prisma db push
# Start the server and open the app in a new browser tab
npm run dev -- --open
Insert roles and lifetimes settings:
visit http://localhost:5173/initialize_database
- Visit sign in page
- Enter your email address
- Check your PIN code in your emails
- Enter PIN code
Please report any issues here. Pull requests are encouraged especially as SvelteKit is evolving rapidly.