Next.js初心者です
next.jsでログイン機能を作ろうと
next-auth-example
Template
コピーして始めたのですが、
mysqlにデータベースを設定し、
メールアドレスを登録を登録しようとしたのですがこのようなエラーが出ました、、
コレはどこに何が足りないのでしょうか、、
https://next-auth.js.org/errors#adapter_connection_error (node:3472) UnhandledPromiseRejectionWarning: TypeError: Cannot destructure property 'manager' of 'connection' as it is null. at Object.<anonymous> (/Users/user/projects/matching/node_modules/next-auth/dist/adapters/typeorm/index.js:102:9) at Generator.next (<anonymous>) at asyncGeneratorStep (/Users/user/projects/matching/node_modules/next-auth/dist/adapters/typeorm/index.js:28:103) at _next (/Users/user/projects/matching/node_modules/next-auth/dist/adapters/typeorm/index.js:30:194) at runMicrotasks (<anonymous>) at processTicksAndRejections (internal/process/task_queues.js:97:5) (node:3472) UnhandledPromiseRejectionWarning: Unhandled promise rejection. This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). To terminate the node process on unhandled promise rejection, use the CLI flag `--unhandled-rejections=strict` (see https://nodejs.org/api/cli.html#cli_unhandled_rejections_mode). (rejection id: 6)
データベースの変更はgithubを参考にやらせてもらったつもりです
メールアドレス登録時のユーアールエル https://next-auth-example.now.sh/api/auth/signin?callbackUrl=https%3A%2F%2Fnext-auth-example.now.sh%2F
[next-auth-example].js import NextAuth from 'next-auth' import Providers from 'next-auth/providers' // For more information on each option (and a full list of options) go to // https://next-auth.js.org/configuration/options const options = { // https://next-auth.js.org/configuration/providers providers: [ Providers.Email({ server: process.env.EMAIL_SERVER, from: process.env.EMAIL_FROM, }), Providers.Apple({ clientId: process.env.APPLE_ID, clientSecret: { appleId: process.env.APPLE_ID, teamId: process.env.APPLE_TEAM_ID, privateKey: process.env.APPLE_PRIVATE_KEY, keyId: process.env.APPLE_KEY_ID, } }), Providers.Auth0({ clientId: process.env.AUTH0_ID, clientSecret: process.env.AUTH0_SECRET, domain: process.env.AUTH0_DOMAIN }), Providers.Facebook({ clientId: process.env.FACEBOOK_ID, clientSecret: process.env.FACEBOOK_SECRET }), Providers.GitHub({ clientId: process.env.GITHUB_ID, clientSecret: process.env.GITHUB_SECRET }), Providers.Google({ clientId: process.env.GOOGLE_ID, clientSecret: process.env.GOOGLE_SECRET }), Providers.Twitter({ clientId: process.env.TWITTER_ID, clientSecret: process.env.TWITTER_SECRET }), ], // Database optional. MySQL, Maria DB, Postgres and MongoDB are supported. // https://next-auth.js.org/configuration/database // // Notes: // * You must to install an appropriate node_module for your database // * The Email provider requires a database (OAuth providers do not) database: process.env.DATABASE_URL, // The secret should be set to a reasonably long random string. // It is used to sign cookies and to sign and encrypt JSON Web Tokens, unless // a seperate secret is defined explicitly for encrypting the JWT. secret: process.env.SECRET, session: { // Use JSON Web Tokens for session instead of database sessions. // This option can be used with or without a database for users/accounts. // Note: `jwt` is automatically set to `true` if no database is specified. jwt: true, // Seconds - How long until an idle session expires and is no longer valid. // maxAge: 30 * 24 * 60 * 60, // 30 days // Seconds - Throttle how frequently to write to database to extend a session. // Use it to limit write operations. Set to 0 to always update the database. // Note: This option is ignored if using JSON Web Tokens // updateAge: 24 * 60 * 60, // 24 hours }, // JSON Web tokens are only used for sessions if the `jwt: true` session // option is set - or by default if no database is specified. // https://next-auth.js.org/configuration/options#jwt jwt: { // A secret to use for key generation (you should set this explicitly) // secret: 'INp8IvdIyeMcoGAgFGoA61DdBglwwSqnXJZkgz8PSnw', // Set to true to use encryption (default: false) // encryption: true, // You can define your own encode/decode functions for signing and encryption // if you want to override the default behaviour. // encode: async ({ secret, token, maxAge }) => {}, // decode: async ({ secret, token, maxAge }) => {}, }, // You can define custom pages to override the built-in pages. // The routes shown here are the default URLs that will be used when a custom // pages is not specified for that route. // https://next-auth.js.org/configuration/pages pages: { // signIn: '/api/auth/signin', // Displays signin buttons // signOut: '/api/auth/signout', // Displays form with sign out button // error: '/api/auth/error', // Error code passed in query string as ?error= // verifyRequest: '/api/auth/verify-request', // Used for check email page // newUser: null // If set, new users will be directed here on first sign in }, // Callbacks are asynchronous functions you can use to control what happens // when an action is performed. // https://next-auth.js.org/configuration/callbacks callbacks: { // signIn: async (user, account, profile) => { return Promise.resolve(true) }, // redirect: async (url, baseUrl) => { return Promise.resolve(baseUrl) }, // session: async (session, user) => { return Promise.resolve(session) }, // jwt: async (token, user, account, profile, isNewUser) => { return Promise.resolve(token) } }, // Events are useful for logging // https://next-auth.js.org/configuration/events events: { }, // Enable debug messages in the console if you are having problems debug: false, } export default (req, res) => NextAuth(req, res, options)
.env.local NEXTAUTH_URL=http://localhost:3000 SECRET= AUTH0_ID= AUTH0_SECRET= AUTH0_DOMAIN= FACEBOOK_ID= FACEBOOK_SECRET= GITHUB_ID= GITHUB_SECRET= GOOGLE_ID= GOOGLE_SECRET= TWITTER_ID= TWITTER_SECRET= EMAIL_SERVER=smtp://username:password@smtp.example.com.com:587 EMAIL_FROM=NextAuth <noreply@example.com> DATABASE_URL=mysql://username:password@127.0.0.1:3306/database_name?synchronize=true
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。