前提・実現したいこと
passport.jsを使って認証機能を実現しようとしています。ログイン情報をフォームから送信したあと、その情報を元にmongodbからuserのデータをフェッチしようと試みていますが、下記のエラーが発生します。
発生している問題・エラーメッセージ
serializeUserにemailが渡されたあと数秒後エラーが発生しています。
test@yahoo.co.jp config/account.js:37 エラー MongooseError: Operation `user.findOne()` buffering timed out after 10000ms
該当のソースコード
Javascript
1const passport = require("passport"); 2const LocalStrategy = require("passport-local").Strategy; 3const User = require("../models/m_user.js"); 4const mongoose = require("mongoose"); 5const { DATABASEURL, OPTIONS } = require("../config/mongo.config.js"); 6 7passport.use( 8 "emailAndPasswordStrategy", 9 new LocalStrategy({ usernameField: "email", passReqToCallback: true }, async (req, email, password, done) => { 10 await mongoose.connect(DATABASEURL, OPTIONS); 11 const db = mongoose.connection; 12 db.on("error", (err) => { 13 done(err); 14 }); 15 User.findOne({ 16 email, 17 password, 18 }) 19 .then((user) => { 20 if (!user) { 21 done(null, false, req.flash("notFoundUser", "メールアドレスもしくはパスワードを正しく入力してください。")); 22 return; 23 } 24 done(null, user.email); 25 }) 26 .catch((err) => { 27 done(err); 28 }) 29 .then(() => { 30 db.close(); 31 }); 32 }) 33); 34 35passport.serializeUser((email, done) => { 36 done(null, email); 37 console.log(email); 38}); 39 40passport.deserializeUser((email, done) => { 41 User.findOne({ email }) 42 .then((user) => { 43 done(null, user); 44 }) 45 .catch((err) => { 46 done(err); 47 }); 48}); 49 50const initialize = () => { 51 return [passport.initialize(), passport.session()]; 52}; 53 54module.exports = { 55 initialize, 56}; 57
試したこと
ググって見ましたが、データベースにコネクションする前にModelを動作させると起こるエラーのようです。
しかし、ソースコードを見ていただければ分かるように、async/awaitで制御を行っています。
制御方法のやり方が違うのでしょうか?
補足情報(FW/ツールのバージョンなど)
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。