MountainSlayer
MountainSlayer

Reputation: 321

My post operation is not working

I am working on a project that involves registering users into a mongodatabase.

I have my Mongoose Schema in a file called user.js, here is the code in it:

const express = require('express');
const mongoose = require('mongoose');
const bcrypt = require('bcrypt');
const passportLocalMongoose = require('passport-local-mongoose');

let Schema = mongoose.Schema;


let UserSchema = Schema({
  name: {
    type: String
  },

  username: {
    type: String,
    unique: true,
    required: true
  },

  profilePic: {
    type: String
  },

  email: {
    type: String,
    unique: true,
    required: true
  },

  password: {
    type: String,
    required: true,
  },

  usersRecipes: [{type: Schema.Types.ObjectId, ref:'Recipe'}],

  userComments: [{type: Schema.Types.ObjectId, ref: 'Recipe'}]

});

let User = mongoose.model('User', UserSchema);

module.exports = User;

And I here is the code for my file userRouter.js where my code is not working

const express = require('express');
const passport = require('passport');
const User = require('../models/user');
const jwt = require('jsonwebtoken');
const mongoose = require('mongoose');
const bcrypt = require('bcrypt');


router = express.Router();

router.get('/', (req, res, next) => {
    res.send('Here are the users!')
});

router.get('/:username', (req, res, next) => {
    let nameQuery = {username: req.params.username};

    User.findOne(nameQuery, (err, user) =>{
        if (err) throw err;
        res.json(user);

    })
});

router.post('/register', function(req, res, next, err){

    User.create({
        username: req.body.username,
        password: req.body.password,
        name: req.body.name,
        email: req.body.email,
        profilePic: req.body.profilePic
    }, (err, user) => {
        if (err) return err;

        res.json(user);
    }); 
});
module.exports = router;

Everytime I try to add a user in postman, I get this error: enter image description here

Here is my app.js file:

let express = require('express');
let mongoose = require('mongoose');
let path = require('path');
let bodyParser = require('body-parser');
let recipeRouter = require('./routes/recipeRouter');
let userRouter = require('./routes/userRouter');
let bcrypt = require('bcrypt');
let passport = require('passport');
let LocalStrategy = require('passport-local').Strategy;
let config = require('./config');

mongoose.connect(mongodb://localhost:27017);

let db = mongoose.connection;

db.on('error', console.error.bind(console, 'connection error:'));

db.once('open', function () {
    // we're connected!
    console.log("Connected correctly to server");
});

const app = express();

const port = 3000;

app.listen(port);


app.use(express.static(path.join(__dirname, 'public')));

app.use(bodyParser.json());

app.set('views', path.join(__dirname, 'views'));

app.use('/users', userRouter);
app.use('/recipes',recipeRouter);

app.get('/', function(req, res){
  res.send('Hey, this is your database!')
});


module.exports = app;

What am I doing wrong?

Upvotes: 1

Views: 69

Answers (1)

robertklep
robertklep

Reputation: 203554

This is the problem:

router.post('/register', function(req, res, next, err) { ... })

Specifically, that fourth err argument. Passing a function that takes 4 arguments has an internal significance for Express, meaning that the function is an error handler, which it isn't in this case.

Use this instead:

router.post('/register', function(req, res, next) { ... })

Also, a bit later on in your code:

if (err) return err;

You probably want to throw that error (or call return next(err)).

Upvotes: 1

Related Questions