Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/opensaasau/keystone-nextjs-auth
A package that add social auth to Keystone-6 (https://keystonejs.com/) by using next-authjs (https://next-auth.js.org/)
https://github.com/opensaasau/keystone-nextjs-auth
auth0 authentication hacktoberfest keystone nextauth nextjs
Last synced: 7 days ago
JSON representation
A package that add social auth to Keystone-6 (https://keystonejs.com/) by using next-authjs (https://next-auth.js.org/)
- Host: GitHub
- URL: https://github.com/opensaasau/keystone-nextjs-auth
- Owner: OpenSaasAU
- License: mit
- Archived: true
- Created: 2021-06-17T23:47:40.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2023-10-08T00:44:58.000Z (over 1 year ago)
- Last Synced: 2024-10-02T06:41:29.246Z (4 months ago)
- Topics: auth0, authentication, hacktoberfest, keystone, nextauth, nextjs
- Language: TypeScript
- Homepage:
- Size: 3.22 MB
- Stars: 75
- Watchers: 3
- Forks: 11
- Open Issues: 48
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
# Package now DEPRECIATED
This package now no longer works with the latest versions of Keystone and Next-Auth. For more background see https://github.com/keystonejs/keystone/pull/8582.
You can now implement Next-Auth directly in Keystone - see example https://github.com/keystonejs/keystone/tree/main/examples/custom-session-next-auth[![Open in Visual Studio Code](https://open.vscode.dev/badges/open-in-vscode.svg)](https://open.vscode.dev/OpenSaasAU/keystone-nextjs-auth)
[![Release](https://github.com/OpenSaasAU/keystone-nextjs-auth/actions/workflows/release.yml/badge.svg)](https://github.com/OpenSaasAU/keystone-nextjs-auth/actions/workflows/release.yml)# Keystone next auth
This package enables the addition of social auth to keystone-6.
## Contents
- [About](#about)
- [Adding to your project](#adding-to-your-project)
- [Configuration](#configuration)
- [Contributing](#contributing)## About
This uses NextAuth.js (https://next-auth.js.org/) project to add social auth to Keystone-6 (https://keystonejs.com/). Primary testing has been done with Auth0, happy for others to test other providers/give feedback or send through a PR.
## Adding to your project
Add package by `yarn add @opensaas/keystone-nextjs-auth` then add the following to your `keystone.ts`:
Add import...
```javascript
import { createAuth } from '@opensaas/keystone-nextjs-auth';
import Auth0 from '@opensaas/keystone-nextjs-auth/providers/auth0';
```Add you Auth configuration including providers
for Provider configuration see https://next-auth.js.org/providers/. For Provider configuration replace `next-auth/providers/` with `@opensaas/keystone-nextjs-auth/providers/````javascript
let sessionSecret = process.env.SESSION_SECRET;if (!sessionSecret) {
if (process.env.NODE_ENV === 'production') {
throw new Error(
'The SESSION_SECRET environment variable must be set in production'
);
} else {
sessionSecret = '-- DEV COOKIE SECRET; CHANGE ME --';
}
}const auth = createAuth({
listKey: 'User',
identityField: 'subjectId',
sessionData: `id name email`,
autoCreate: true,
resolver: async ({user, profile, account}) => {
const username = user.name as string;
const email = user.email as string;
return { email, username };
},
keystonePath: '/admin',
sessionSecret,
providers: [
Auth0({
clientId: process.env.AUTH0_CLIENT_ID || 'Auth0ClientID',
clientSecret: process.env.AUTH0_CLIENT_SECRET || 'Auth0ClientSecret',
domain: process.env.AUTH0_DOMAIN || 'opensaas.au.auth0.com',
}),
]
});
```Wrap your keystone config in `auth.withAuth`.
```javascript
export default auth.withAuth(
config({
server: {},
db: {},
ui: {},
lists,
...
});
```## Configuration
Provider configuration see https://next-auth.js.org/configuration/providers.
For Keystone-6 Configuration see https://keystonejs.com/
for example see the example [backend](./backend)- listKey - the list for authentication (generally `'User'`). Make sure any required fields are set using the `*Map` fields, see note below.
- identityField - The field that stores the identity/subjectId in keystone (generally `'subjectId'`). You will need to add this field to your list schema specified by `listKey`. An example can be found [here](./backend/schemas/User.ts).
- sessionData - Data to be stored in the session ( something like `'id name email'`),
- autoCreate - boolean to autocreate a user when they log in
- userMap: `key:value` pairs that define what is copied from the User object returned from NextAuth in the SignIn callback (https://next-auth.js.org/configuration/callbacks#sign-in-callback) Left side is Keystone side, right is what comes from NextAuth eg: `{ subjectId: 'id', name: 'name' }`
- accountMap - As Above but for the Account object
- profileMap - As Above but for the Profile object
- keystonePath - the path you want to access keystone from your frontend app (if required).Note: The Keystone `create-keystone-app` CLI app (generally run with `yarn create keystone-app`/`npm init keystone-app`) will set a required `password` field on the `User` list. If you've used this to set up your project you will need to modify your list schema to set the field as not required, or remove it entirely if you don't plan to use the default Keystone auth system at all.
## Contributing
If you want to run this package locally
After cloning run `yarn install` and either:- `yarn dev` to run both the frontend and backend or
- `yarn dev:backend` for just the backendThe [Demo App](./apps/ks-frontend-demo) is configured in `next.config.js` to proxy `/api/auth` to the the host setup using the environment variable `BACKEND_BASE_URL` in development set `export BACKEND_BASE_URL=http://localhost:3000` you will also need to set your `NEXTAUTH_URL` environment variable see https://next-auth.js.org/configuration/options for more information.