Ошибка: отсутствует код аутентификации (Mon goose -шифрование) - PullRequest
0 голосов
/ 20 апреля 2020

я получаю эту ошибку при входе зарегистрированного пользователя конечно я получил эту ошибку после использования dotenv пакета для защиты моего ключа шифрования базы данных

но proccess.env.SECRET работает правильно

Я думаю, моя проблема здесь:

userSchema.plugin(encrypt, {           
    secret: process.env.SECRET,         
    encryptedFields: ["password"],     
});

приложение. js:

require("dotenv").config();

const express = require("express");
const bodyParser = require("body-parser");
const ejs = require("ejs");
const mongoose = require("mongoose");
const encrypt = require("mongoose-encryption");

const app = express();

app.use(express.static("public"));
app.set("view engine", "ejs");
app.use(bodyParser.urlencoded({ extended: true }));

mongoose.connect("mongodb://localhost:27017/userDB", {
    useUnifiedTopology: true,
    useNewUrlParser: true,
});

const userSchema = new mongoose.Schema({
    email: String,
    password: String,
});

                                         //_
//     encrypting password field         // | 
userSchema.plugin(encrypt, {             // | i guess problem is here
    secret: process.env.SECRET,          // |
    encryptedFields: ["password"],       //_|
});

const User = mongoose.model("User", userSchema);

ошибка:

Error: Authentication code missing
    at Object.schema.methods.authenticateSync (C:\Users\Amir\Desktop\security\node_modules\mongoose-encryption\lib\plugins\mongoose-encryption.js:419:23)
    at model.<anonymous> (C:\Users\Amir\Desktop\security\node_modules\mongoose-encryption\lib\plugins\mongoose-encryption.js:239:47)
    at Kareem.execPreSync (C:\Users\Amir\Desktop\security\node_modules\kareem\index.js:115:16)
    at model.syncWrapper [as $__init] (C:\Users\Amir\Desktop\security\node_modules\kareem\index.js:232:12)
    at model.Document.init (C:\Users\Amir\Desktop\security\node_modules\mongoose\lib\document.js:513:8)
    at completeOne (C:\Users\Amir\Desktop\security\node_modules\mongoose\lib\query.js:2853:12)
    at model.Query.Query._completeOne (C:\Users\Amir\Desktop\security\node_modules\mongoose\lib\query.js:2094:7)
    at Immediate.<anonymous> (C:\Users\Amir\Desktop\security\node_modules\mongoose\lib\query.js:2138:10)
    at Immediate.<anonymous> (C:\Users\Amir\Desktop\security\node_modules\mquery\lib\utils.js:116:16)
    at processImmediate (internal/timers.js:456:21)
...