Я пытаюсь добавить пользовательский ввод (URL-адрес) в базу данных с помощью Mon goose, но также проверяю, существуют ли уже добавленные данные. Вместо этого кажется, что каждый раз создается новая модель.
На экране отображается разрешение json (ввод), а не тест json
var mongo = require('mongodb');
var mongoose = require('mongoose');
var cors = require('cors');
// Basic Configuration
var port = process.env.PORT || 3000;
process.env.DB_URI="omg it's my secret url"
// Connect to DB.
mongoose.connect(process.env.DB_URI, { useNewUrlParser: true, useUnifiedTopology: true }).
catch(error => handleError(error));
mongoose.connection.on('error', err => {
console.log(err);
});
app.use(cors());
//First we create a schema and Model in MongoDB.
const urlSchema = new mongoose.Schema({
original_url: String,
short_url: Number
});
const urlModel = mongoose.model('urlModel', urlSchema);
app.post(/PATH, function(req, res, done) {
//Now we check if the input-url was actually valid.
if(!/(^https:\/\/)/.test(req.body.url)){
res.json({error: "Invalid url"});
}
//If it's valid we will start creating a model in the DB.
else {
var userUrl = req.body.url;
var urlNumber = 0;
var input = new urlModel({
original_url: userUrl
});
//Now we check if the url was already added to the database and return a new or updated item.
urlSchema.pre('save', function (next) {
var query = {'original_url': userUrl };
urlModel.findOneAndUpdate(query, userUrl, {upsert: true}, function(err, doc) {
if (err) return res.send(500, {error: err});
res.json({'test': 'test'});
});
});
res.json(input);
urlNumber++;
input.save(function(err, data) {
if (err) return console.log(err);
done(null, data);
});
};
});
Как вы можете видеть, у меня также есть проблема с обновлением номера, который я хочу присоединить к URL-адресу в базе данных, поскольку я переназначаю 0 для urlNumber в начале вызова. Должно быть, потому что уже поздно, но я не могу найти способ правильно обновить этот номер. Я попробовал две переменные и сравнил их друг с другом и с if (urlNumber> 0), но эту проблему я все еще решаю. Кажется, это так просто ...
В любом случае, вопрос: почему findOneAndUpdate не обновляется? Возвращенный res. json (ввод) показывает новый _id каждый раз, что говорит мне, что он действительно создает новые модели при каждом запуске.
Пример возвращает
#1
{
_id: eksdjh3948wryeids293ren12;
original_url: "https://www.correct.com"
short_url: 0
}
#2
{
_id: eksdjh3948wryeids293ren13; // (<----- NEW NUMBER)
original_url: "https://www.correct.com"
short_url: 0
}